pub struct RequestIdMiddleware { /* private fields */ }Expand description
Middleware that adds unique request IDs to requests and responses.
This middleware:
- Checks for an existing X-Request-ID header from the client
- If present and valid, uses it; otherwise generates a new ID
- Stores the ID in request extensions for handlers to access
- Adds the ID to response headers
§Example
ⓘ
use fastapi_core::middleware::RequestIdMiddleware;
let mut stack = MiddlewareStack::new();
stack.push(RequestIdMiddleware::new());
// In your handler:
async fn handler(ctx: &RequestContext, req: &Request) -> Response {
if let Some(request_id) = req.get_extension::<RequestId>() {
println!("Request ID: {}", request_id);
}
Response::ok()
}Implementations§
Source§impl RequestIdMiddleware
impl RequestIdMiddleware
Sourcepub fn new() -> RequestIdMiddleware
pub fn new() -> RequestIdMiddleware
Creates a new request ID middleware with default configuration.
Examples found in repository?
examples/getting_started.rs (line 57)
24fn main() {
25 println!("Getting Started Guide - Code Validation\n");
26
27 // === Basic App Example ===
28 println!("1. Basic app with two routes:");
29 let app = App::builder()
30 .get("/", hello)
31 .get("/health", health)
32 .build();
33
34 println!(" Routes: {}", app.route_count());
35 let client = TestClient::new(app);
36
37 let response = client.get("/").send();
38 println!(
39 " GET / -> {} ({})",
40 response.status().as_u16(),
41 response.text()
42 );
43 assert_eq!(response.status().as_u16(), 200);
44 assert_eq!(response.text(), "Hello, World!");
45
46 let response = client.get("/health").send();
47 println!(
48 " GET /health -> {} ({})",
49 response.status().as_u16(),
50 response.text()
51 );
52 assert_eq!(response.status().as_u16(), 200);
53
54 // === App with Middleware ===
55 println!("\n2. App with middleware:");
56 let app = App::builder()
57 .middleware(RequestIdMiddleware::new())
58 .middleware(SecurityHeaders::new())
59 .get("/", hello)
60 .build();
61
62 let client = TestClient::new(app);
63 let response = client.get("/").send();
64 println!(" GET / -> {}", response.status().as_u16());
65 assert_eq!(response.status().as_u16(), 200);
66
67 // === App with Configuration ===
68 println!("\n3. App with configuration:");
69 let config = AppConfig::new()
70 .name("My API")
71 .version("1.0.0")
72 .debug(true)
73 .max_body_size(10 * 1024 * 1024)
74 .request_timeout_ms(30_000);
75
76 let app = App::builder().config(config).get("/", hello).build();
77
78 println!(" App name: {}", app.config().name);
79 println!(" Version: {}", app.config().version);
80 assert_eq!(app.config().name, "My API");
81 assert_eq!(app.config().version, "1.0.0");
82
83 // === 404 for unknown routes ===
84 println!("\n4. 404 for unknown routes:");
85 let app = App::builder().get("/", hello).build();
86
87 let client = TestClient::new(app);
88 let response = client.get("/nonexistent").send();
89 println!(" GET /nonexistent -> {}", response.status().as_u16());
90 assert_eq!(response.status().as_u16(), 404);
91
92 println!("\nAll getting started examples validated successfully!");
93}Sourcepub fn with_config(config: RequestIdConfig) -> RequestIdMiddleware
pub fn with_config(config: RequestIdConfig) -> RequestIdMiddleware
Creates a new request ID middleware with the given configuration.
Trait Implementations§
Source§impl Clone for RequestIdMiddleware
impl Clone for RequestIdMiddleware
Source§fn clone(&self) -> RequestIdMiddleware
fn clone(&self) -> RequestIdMiddleware
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for RequestIdMiddleware
impl Debug for RequestIdMiddleware
Source§impl Default for RequestIdMiddleware
impl Default for RequestIdMiddleware
Source§fn default() -> RequestIdMiddleware
fn default() -> RequestIdMiddleware
Returns the “default value” for a type. Read more
Source§impl Middleware for RequestIdMiddleware
impl Middleware for RequestIdMiddleware
Source§fn before<'a>(
&'a self,
_ctx: &'a RequestContext,
req: &'a mut Request,
) -> Pin<Box<dyn Future<Output = ControlFlow> + Send + 'a>>
fn before<'a>( &'a self, _ctx: &'a RequestContext, req: &'a mut Request, ) -> Pin<Box<dyn Future<Output = ControlFlow> + Send + 'a>>
Called before the handler executes. Read more
Auto Trait Implementations§
impl Freeze for RequestIdMiddleware
impl RefUnwindSafe for RequestIdMiddleware
impl Send for RequestIdMiddleware
impl Sync for RequestIdMiddleware
impl Unpin for RequestIdMiddleware
impl UnwindSafe for RequestIdMiddleware
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, _span: NoopSpan) -> Self
fn instrument(self, _span: NoopSpan) -> Self
Instruments this future with a span (no-op when disabled).
Source§fn in_current_span(self) -> Self
fn in_current_span(self) -> Self
Instruments this future with the current span (no-op when disabled).