Expand description
Set and propagate request ids.
§Example
use rama_http::layer::request_id::{
SetRequestIdLayer, PropagateRequestIdLayer, MakeRequestId, RequestId,
};
use rama_http::{Body, Request, Response, header::HeaderName};
use rama_core::service::service_fn;
use rama_core::{Context, Service, Layer};
use rama_core::error::BoxError;
use std::sync::{Arc, atomic::{AtomicU64, Ordering}};
// A `MakeRequestId` that increments an atomic counter
#[derive(Clone, Default)]
struct MyMakeRequestId {
counter: Arc<AtomicU64>,
}
impl MakeRequestId for MyMakeRequestId {
fn make_request_id<B>(&self, request: &Request<B>) -> Option<RequestId> {
let request_id = self.counter
.fetch_add(1, Ordering::AcqRel)
.to_string()
.parse()
.unwrap();
Some(RequestId::new(request_id))
}
}
let x_request_id = HeaderName::from_static("x-request-id");
let mut svc = (
// set `x-request-id` header on all requests
SetRequestIdLayer::new(
x_request_id.clone(),
MyMakeRequestId::default(),
),
// propagate `x-request-id` headers from request to response
PropagateRequestIdLayer::new(x_request_id),
).layer(handler);
let request = Request::new(Body::empty());
let response = svc.serve(Context::default(), request).await?;
assert_eq!(response.headers()["x-request-id"], "0");
Structs§
- A
MakeRequestId
that generatesUUID
s. - Propagate request ids from requests to responses.
- Propagate request ids from requests to responses.
- An identifier for a request.
- Set request id headers and extensions on requests.
- Set request id headers and extensions on requests.
Traits§
- Trait for producing
RequestId
s.