diff options
author | Shav Kinderlehrer <[email protected]> | 2024-04-07 21:06:21 -0400 |
---|---|---|
committer | Shav Kinderlehrer <[email protected]> | 2024-04-07 21:06:46 -0400 |
commit | 938be8949fbb9735953309611c73589be04a2ccb (patch) | |
tree | 3a9c88ea1643ff17873ca7ec53cf7a85a0c87451 | |
parent | 2faf2898295bbc4b4712b2ad82292f90c1c92f32 (diff) | |
download | chela-938be8949fbb9735953309611c73589be04a2ccb.tar.gz chela-938be8949fbb9735953309611c73589be04a2ccb.zip |
Use proper IP address when behind proxyv1.2.0
-rw-r--r-- | Cargo.lock | 2 | ||||
-rw-r--r-- | Cargo.toml | 2 | ||||
-rw-r--r-- | src/get.rs | 16 |
3 files changed, 17 insertions, 3 deletions
@@ -194,7 +194,7 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "chela" -version = "1.1.0" +version = "1.2.0" dependencies = [ "axum", "color-eyre", @@ -1,6 +1,6 @@ [package] name = "chela" -version = "1.1.0" +version = "1.2.0" edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html @@ -41,7 +41,21 @@ pub async fn id_unix( Extension(state): Extension<ServerState>, Path(id): Path<String>, ) -> impl IntoResponse { - let ip = format!("{:?}", addr.peer_addr); + let ip = if state.behind_proxy { + match headers.get("x-real-ip") { + Some(it) => { + if let Ok(i) = it.to_str() { + Some(i.to_string()) + } else { + None + } + } + None => None, + } + } else { + Some(format!("{:?}", addr.peer_addr)) + } + .unwrap_or_default(); run_id(headers, ip, state, id).await } |