generic_server.rs: Added support for logging X-Forwarded-For header.
Fixes: #460
This commit is contained in:
parent
fba8224cf0
commit
94d70bec69
@ -125,7 +125,26 @@ impl<A: ApiHandler> ApiServer<A> {
|
|||||||
addr: SocketAddr,
|
addr: SocketAddr,
|
||||||
) -> Result<Response<Body>, GarageError> {
|
) -> Result<Response<Body>, GarageError> {
|
||||||
let uri = req.uri().clone();
|
let uri = req.uri().clone();
|
||||||
info!("{} {} {}", addr, req.method(), uri);
|
|
||||||
|
let has_forwarded_for_header = req.headers().contains_key("x-forwarded-for");
|
||||||
|
if has_forwarded_for_header {
|
||||||
|
let forwarded_for_ip_addr = &req
|
||||||
|
.headers()
|
||||||
|
.get("x-forwarded-for")
|
||||||
|
.expect("Could not parse X-Forwarded-For header")
|
||||||
|
.to_str()
|
||||||
|
.unwrap_or_default();
|
||||||
|
|
||||||
|
info!(
|
||||||
|
"{} (via {}) {} {}",
|
||||||
|
forwarded_for_ip_addr,
|
||||||
|
addr,
|
||||||
|
req.method(),
|
||||||
|
uri
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
info!("{} {} {}", addr, req.method(), uri);
|
||||||
|
}
|
||||||
debug!("{:?}", req);
|
debug!("{:?}", req);
|
||||||
|
|
||||||
let tracer = opentelemetry::global::tracer("garage");
|
let tracer = opentelemetry::global::tracer("garage");
|
||||||
|
Loading…
Reference in New Issue
Block a user