Skip to main content

rust_web_server/
lib.rs

1//! # rust-web-server
2//!
3//! A static file web server and HTTP toolkit written in Rust.
4//! Supports HTTP/3 (QUIC), HTTP/2, and HTTP/1.1.
5//!
6//! ## Use as a library
7//!
8//! Add to `Cargo.toml`:
9//!
10//! ```toml
11//! [dependencies]
12//! rust-web-server = "17"
13//! ```
14//!
15//! ## Quick start: add a custom route
16//!
17//! ```rust,no_run
18//! use rust_web_server::controller::Controller;
19//! use rust_web_server::request::{METHOD, Request};
20//! use rust_web_server::response::{Response, STATUS_CODE_REASON_PHRASE};
21//! use rust_web_server::range::Range;
22//! use rust_web_server::mime_type::MimeType;
23//! use rust_web_server::server::ConnectionInfo;
24//!
25//! pub struct PingController;
26//!
27//! impl Controller for PingController {
28//!     fn is_matching(request: &Request, _: &ConnectionInfo) -> bool {
29//!         request.method == METHOD.get && request.request_uri == "/ping"
30//!     }
31//!
32//!     fn process(_: &Request, mut response: Response, _: &ConnectionInfo) -> Response {
33//!         response.status_code = *STATUS_CODE_REASON_PHRASE.n200_ok.status_code;
34//!         response.reason_phrase = STATUS_CODE_REASON_PHRASE.n200_ok.reason_phrase.to_string();
35//!         response.content_range_list = vec![
36//!             Range::get_content_range(b"pong".to_vec(), MimeType::TEXT_PLAIN.to_string())
37//!         ];
38//!         response
39//!     }
40//! }
41//! ```
42//!
43//! See [DEVELOPER.md](https://github.com/bohdaq/rust-web-server/blob/main/DEVELOPER.md)
44//! for the full building blocks reference and use case examples.
45
46pub mod app;
47pub mod compression;
48pub mod cookie;
49pub mod metrics;
50pub mod application;
51pub mod body;
52pub mod client_hint;
53pub mod controller;
54pub mod core;
55pub mod cors;
56pub mod entry_point;
57pub mod ext;
58pub mod header;
59pub mod http;
60pub mod json;
61pub mod language;
62pub mod log;
63pub mod mime_type;
64pub mod null;
65pub mod range;
66pub mod request;
67pub mod response;
68pub mod server;
69pub mod symbol;
70pub mod thread_pool;
71pub mod url;
72
73#[cfg(feature = "http2")]
74#[doc(hidden)]
75pub mod tls;
76
77#[cfg(feature = "http2")]
78#[doc(hidden)]
79pub mod h2_handler;
80
81#[cfg(feature = "http3")]
82#[doc(hidden)]
83pub mod h3_handler;