1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
//! HTTP server implementation for Reinhardt framework.
//!
//! This module provides HTTP/1.1 and HTTP/2 server implementations based on Hyper.
//!
//! ## Basic Usage
//!
//! ```rust,no_run,ignore
//! # use reinhardt_server::{HttpServer, serve};
//! # use std::net::SocketAddr;
//! # use std::sync::Arc;
//! # #[tokio::main]
//! # async fn main() -> Result<(), Box<dyn std::error::Error>> {
//! // let addr: SocketAddr = "127.0.0.1:8000".parse()?;
//! // let handler = Arc::new(MyHandler);
//! //
//! // let server = HttpServer::new(handler.clone());
//! //
//! // // Start server
//! // serve(addr, handler).await?;
//! # Ok(())
//! # }
//! ```
//!
//! ## Accessing Handler
//!
//! Use the `handler()` method to get a clone of the server's handler:
//!
//! ```rust,no_run,ignore
//! # use reinhardt_server::HttpServer;
//! # use std::sync::Arc;
//! # let handler = Arc::new(());
//! // let server = HttpServer::new(handler);
//! // let handler_clone = server.handler(); // Returns Arc<dyn Handler>
//! ```
/// HTTP/1.1 server implementation based on Hyper.
/// HTTP/2 server implementation with TLS support.
/// Rate limiting handler for controlling request throughput.
/// Graceful shutdown coordination for server instances.
/// Request timeout handler for enforcing maximum execution time.
/// GraphQL request handler integration (requires `graphql` feature).
/// WebSocket server support with broadcast capabilities (requires `websocket` feature).
pub use ;
pub use ;
pub use ;
pub use ;
pub use TimeoutHandler;
pub use ;
pub use ;
// Re-export types needed for server trait
pub use ;
/// Common server trait that all server types implement