Skip to content

Commit

Permalink
fix: use axum-client-ip to get the real client IP
Browse files Browse the repository at this point in the history
  • Loading branch information
geekbrother committed Oct 6, 2023
1 parent 46d1797 commit c6c822a
Show file tree
Hide file tree
Showing 6 changed files with 30 additions and 22 deletions.
3 changes: 2 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ wc = { git = "https://github.com/WalletConnect/utils-rs.git", tag = "v0.5.1", fe

tokio = { version = "1", features = ["full"] }
axum = { version = "0.6", features = ["json", "multipart", "tokio"] }
axum-client-ip = "0.4"
tower = "0.4"
tower-http = { version = "0.4", features = ["trace", "cors", "request-id", "propagate-header", "catch-panic"] }
hyper = "0.14"
Expand Down
10 changes: 5 additions & 5 deletions src/handlers/push_message.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#[cfg(feature = "analytics")]
use axum_client_ip::SecureClientIp;
use {
crate::{
analytics::message_info::MessageInfo,
Expand All @@ -23,8 +25,6 @@ use {
serde::{Deserialize, Serialize},
std::sync::Arc,
};
#[cfg(feature = "analytics")]
use {axum::extract::ConnectInfo, std::net::SocketAddr};

#[derive(Serialize, Deserialize, Debug, Clone, Eq, PartialEq)]
pub struct MessagePayload {
Expand All @@ -46,7 +46,7 @@ pub struct PushMessageBody {
}

pub async fn handler(
#[cfg(feature = "analytics")] ConnectInfo(addr): ConnectInfo<SocketAddr>,
#[cfg(feature = "analytics")] SecureClientIp(client_ip): SecureClientIp,
Path((tenant_id, id)): Path<(String, String)>,
StateExtractor(state): StateExtractor<Arc<AppState>>,
headers: HeaderMap,
Expand Down Expand Up @@ -104,7 +104,7 @@ pub async fn handler(
tokio::spawn(async move {
if let Some(analytics) = &state.analytics {
let (country, continent, region) = analytics
.lookup_geo_data(addr.ip())
.lookup_geo_data(client_ip)
.map_or((None, None, None), |geo| {
(geo.country, geo.continent, geo.region)
});
Expand All @@ -113,7 +113,7 @@ pub async fn handler(
%request_id,
%tenant_id,
client_id = %id,
ip = %addr.ip(),
ip = %client_ip,
"loaded geo data"
);

Expand Down
22 changes: 13 additions & 9 deletions src/handlers/register_client.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
#[cfg(feature = "analytics")]
use {crate::analytics::client_info::ClientInfo, axum::extract::ConnectInfo, std::net::SocketAddr};
use {crate::analytics::client_info::ClientInfo, axum_client_ip::SecureClientIp};
use {
crate::{
error::{
Expand Down Expand Up @@ -31,7 +31,7 @@ pub struct RegisterBody {
}

pub async fn handler(
#[cfg(feature = "analytics")] ConnectInfo(addr): ConnectInfo<SocketAddr>,
#[cfg(feature = "analytics")] SecureClientIp(client_ip): SecureClientIp,
Path(tenant_id): Path<String>,
StateExtractor(state): StateExtractor<Arc<AppState>>,
headers: HeaderMap,
Expand Down Expand Up @@ -89,11 +89,15 @@ pub async fn handler(

state
.client_store
.create_client(&tenant_id, &client_id, Client {
tenant_id: tenant_id.clone(),
push_type,
token: body.token,
})
.create_client(
&tenant_id,
&client_id,
Client {
tenant_id: tenant_id.clone(),
push_type,
token: body.token,
},
)
.await?;

info!(
Expand All @@ -108,7 +112,7 @@ pub async fn handler(
tokio::spawn(async move {
if let Some(analytics) = &state.analytics {
let (country, continent, region) = analytics
.lookup_geo_data(addr.ip())
.lookup_geo_data(client_ip)
.map_or((None, None, None), |geo| {
(geo.country, geo.continent, geo.region)
});
Expand All @@ -117,7 +121,7 @@ pub async fn handler(
%request_id,
%tenant_id,
%client_id,
ip = %addr.ip(),
ip = %client_ip,
"loaded geo data"
);

Expand Down
12 changes: 6 additions & 6 deletions src/handlers/single_tenant_wrappers.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
#[cfg(feature = "analytics")]
use axum_client_ip::SecureClientIp;
use {
crate::{
error::Result,
Expand All @@ -13,8 +15,6 @@ use {
hyper::HeaderMap,
std::sync::Arc,
};
#[cfg(feature = "analytics")]
use {axum::extract::ConnectInfo, std::net::SocketAddr};

#[cfg(feature = "multitenant")]
use crate::error::Error::MissingTenantId;
Expand All @@ -37,7 +37,7 @@ pub async fn delete_handler(
}

pub async fn push_handler(
#[cfg(feature = "analytics")] addr: ConnectInfo<SocketAddr>,
#[cfg(feature = "analytics")] SecureClientIp(client_ip): SecureClientIp,
Path(id): Path<String>,
state: StateExtractor<Arc<AppState>>,
headers: HeaderMap,
Expand All @@ -48,7 +48,7 @@ pub async fn push_handler(

#[cfg(all(not(feature = "multitenant"), feature = "analytics"))]
return crate::handlers::push_message::handler(
addr,
SecureClientIp(client_ip),
Path((DEFAULT_TENANT_ID.to_string(), id)),
state,
headers,
Expand All @@ -67,7 +67,7 @@ pub async fn push_handler(
}

pub async fn register_handler(
#[cfg(feature = "analytics")] addr: ConnectInfo<SocketAddr>,
#[cfg(feature = "analytics")] SecureClientIp(client_ip): SecureClientIp,
state: StateExtractor<Arc<AppState>>,
headers: HeaderMap,
body: Json<RegisterBody>,
Expand All @@ -77,7 +77,7 @@ pub async fn register_handler(

#[cfg(all(not(feature = "multitenant"), feature = "analytics"))]
return crate::handlers::register_client::handler(
addr,
SecureClientIp(client_ip),
Path(DEFAULT_TENANT_ID.to_string()),
state,
headers,
Expand Down
4 changes: 3 additions & 1 deletion src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ use {
routing::{delete, get, post},
Router,
},
axum_client_ip::SecureClientIpSource,
config::Config,
hyper::http::Method,
opentelemetry::{sdk::Resource, KeyValue},
Expand Down Expand Up @@ -210,7 +211,8 @@ pub async fn bootstap(mut shutdown: broadcast::Receiver<()>, config: Config) ->
hyper::http::header::CONTENT_TYPE,
hyper::http::header::AUTHORIZATION,
]),
);
)
.layer(SecureClientIpSource::ConnectInfo.into_extension());

#[cfg(feature = "multitenant")]
let app = {
Expand Down

0 comments on commit c6c822a

Please sign in to comment.