From c37de84a1ab96c368e07723a64b4b582edc81f6b Mon Sep 17 00:00:00 2001 From: Adam Cattermole Date: Tue, 19 Mar 2024 16:37:42 +0000 Subject: [PATCH] Propagate opentelemetry tracing headers in requests to limitador --- src/filter/http_context.rs | 18 +++++++++++++++++- src/filter/root_context.rs | 1 + 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/src/filter/http_context.rs b/src/filter/http_context.rs index 4ec5d350..c7c95e02 100644 --- a/src/filter/http_context.rs +++ b/src/filter/http_context.rs @@ -21,6 +21,7 @@ pub struct Filter { pub context_id: u32, pub config: Rc, pub response_headers_to_add: Vec<(String, String)>, + pub tracing_headers: Vec<(String, String)>, } impl Filter { @@ -51,11 +52,17 @@ impl Filter { let rl_req_serialized = Message::write_to_bytes(&rl_req).unwrap(); // TODO(rahulanand16nov): Error Handling + let rl_tracing_headers = self + .tracing_headers + .iter() + .map(|(header, value)| (header.as_str(), value.as_bytes())) + .collect(); + match self.dispatch_grpc_call( rlp.service.as_str(), RATELIMIT_SERVICE_NAME, RATELIMIT_METHOD_NAME, - Vec::new(), + rl_tracing_headers, Some(&rl_req_serialized), Duration::from_secs(5), ) { @@ -207,6 +214,15 @@ impl HttpContext for Filter { fn on_http_request_headers(&mut self, _: usize, _: bool) -> Action { info!("on_http_request_headers #{}", self.context_id); + let req_headers = self.get_http_request_headers(); + for (header, value) in req_headers.iter() { + match header.as_str() { + "traceparent" | "tracestate" | "baggage" => { + self.tracing_headers.push((header.clone(), value.clone())) + } + _ => (), + } + } match self .config .index diff --git a/src/filter/root_context.rs b/src/filter/root_context.rs index a0740946..1302d15f 100644 --- a/src/filter/root_context.rs +++ b/src/filter/root_context.rs @@ -22,6 +22,7 @@ impl RootContext for FilterRoot { context_id, config: Rc::clone(&self.config), response_headers_to_add: Vec::default(), + tracing_headers: Vec::default(), })) }