From effcef28cc32d45ad224c0fbbab7127d6a180cba Mon Sep 17 00:00:00 2001 From: taco-paco Date: Tue, 22 Oct 2024 18:20:30 +0300 Subject: [PATCH] feat: log headers to see if X-Forward-For or X-Real-IP present --- api/src/metrics.rs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/api/src/metrics.rs b/api/src/metrics.rs index 9663467..50fdc75 100644 --- a/api/src/metrics.rs +++ b/api/src/metrics.rs @@ -3,6 +3,7 @@ use prometheus::{Encoder, GaugeVec, IntCounter, IntCounterVec, Opts, Registry, T use rocket::fairing::{Fairing, Info, Kind}; use rocket::http::Method; use rocket::{Data, Request, State}; +use tracing::debug; use tracing::instrument; use crate::errors::CoreError; @@ -29,8 +30,17 @@ impl Fairing for Metrics { } } + #[instrument(skip(self, req, _data))] async fn on_request(&self, req: &mut Request<'_>, _data: &mut Data<'_>) { self.requests_total.inc(); + if let Some(val) = req.client_ip() { + let ip = val.to_string(); + let ip = ip.as_str(); + debug!("Plugin launched by: {}", ip); + debug!("Headers: {:?}", req.headers()); + + self.num_distinct_users.with_label_values(&[ip]).inc(); + } match req.method() { Method::Options => {} @@ -41,14 +51,6 @@ impl Fairing for Metrics { impl Metrics { fn update_metrics(&self, req: &mut Request<'_>) { - if let Some(val) = req.client_ip() { - let ip = val.to_string(); - let ip = ip.as_str(); - info!("Plugin launched by: {}", ip); - - self.num_distinct_users.with_label_values(&[ip]).inc(); - } - match req.uri().path().as_str() { "/compile" | "/compile-async" => self.num_of_compilations.inc(), "/on-plugin-launched" => self.num_plugin_launches.inc(),