use crate::{ constants::*, count::RequestCount, crypto::{CryptoSource, ServerCryptoBase}, }; use hot_reload::ReloaderReceiver; use std::{net::SocketAddr, sync::Arc, time::Duration}; /// Global object containing proxy configurations and shared object like counters. /// But note that in Globals, we do not have Mutex and RwLock. It is indeed, the context shared among async tasks. pub struct Globals { /// Configuration parameters for proxy transport and request handlers pub proxy_config: ProxyConfig, /// Shared context - Counter for serving requests pub request_count: RequestCount, /// Shared context - Async task runtime handler pub runtime_handle: tokio::runtime::Handle, /// Shared context - Notify object to stop async tasks pub term_notify: Option>, /// Shared context - Certificate reloader service receiver pub cert_reloader_rx: Option>, } /// Configuration parameters for proxy transport and request handlers #[derive(PartialEq, Eq, Clone)] pub struct ProxyConfig { /// listen socket addresses pub listen_sockets: Vec, /// http port pub http_port: Option, /// https port pub https_port: Option, /// tcp listen backlog pub tcp_listen_backlog: u32, /// Idle timeout as an HTTP server, used as the keep alive interval and timeout for reading request header pub proxy_idle_timeout: Duration, /// Idle timeout as an HTTP client, used as the keep alive interval for upstream connections pub upstream_idle_timeout: Duration, pub max_clients: usize, // when serving requests pub max_concurrent_streams: u32, // when instantiate server pub keepalive: bool, // when instantiate server // experimentals pub sni_consistency: bool, // Handler #[cfg(feature = "cache")] pub cache_enabled: bool, #[cfg(feature = "cache")] pub cache_dir: Option, #[cfg(feature = "cache")] pub cache_max_entry: usize, #[cfg(feature = "cache")] pub cache_max_each_size: usize, #[cfg(feature = "cache")] pub cache_max_each_size_on_memory: usize, // All need to make packet acceptor #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub http3: bool, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub h3_alt_svc_max_age: u32, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub h3_request_max_body_size: usize, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub h3_max_concurrent_bidistream: u32, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub h3_max_concurrent_unistream: u32, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub h3_max_concurrent_connections: u32, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] pub h3_max_idle_timeout: Option, } impl Default for ProxyConfig { fn default() -> Self { Self { listen_sockets: Vec::new(), http_port: None, https_port: None, tcp_listen_backlog: TCP_LISTEN_BACKLOG, // TODO: Reconsider each timeout values proxy_idle_timeout: Duration::from_secs(PROXY_IDLE_TIMEOUT_SEC), upstream_idle_timeout: Duration::from_secs(UPSTREAM_IDLE_TIMEOUT_SEC), max_clients: MAX_CLIENTS, max_concurrent_streams: MAX_CONCURRENT_STREAMS, keepalive: true, sni_consistency: true, #[cfg(feature = "cache")] cache_enabled: false, #[cfg(feature = "cache")] cache_dir: None, #[cfg(feature = "cache")] cache_max_entry: MAX_CACHE_ENTRY, #[cfg(feature = "cache")] cache_max_each_size: MAX_CACHE_EACH_SIZE, #[cfg(feature = "cache")] cache_max_each_size_on_memory: MAX_CACHE_EACH_SIZE_ON_MEMORY, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] http3: false, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] h3_alt_svc_max_age: H3::ALT_SVC_MAX_AGE, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] h3_request_max_body_size: H3::REQUEST_MAX_BODY_SIZE, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] h3_max_concurrent_connections: H3::MAX_CONCURRENT_CONNECTIONS, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] h3_max_concurrent_bidistream: H3::MAX_CONCURRENT_BIDISTREAM, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] h3_max_concurrent_unistream: H3::MAX_CONCURRENT_UNISTREAM, #[cfg(any(feature = "http3-quinn", feature = "http3-s2n"))] h3_max_idle_timeout: Some(Duration::from_secs(H3::MAX_IDLE_TIMEOUT)), } } } /// Configuration parameters for backend applications #[derive(PartialEq, Eq, Clone)] pub struct AppConfigList where T: CryptoSource, { pub inner: Vec>, pub default_app: Option, } /// Configuration parameters for single backend application #[derive(PartialEq, Eq, Clone)] pub struct AppConfig where T: CryptoSource, { pub app_name: String, pub server_name: String, pub reverse_proxy: Vec, pub tls: Option>, } /// Configuration parameters for single reverse proxy corresponding to the path #[derive(PartialEq, Eq, Clone)] pub struct ReverseProxyConfig { pub path: Option, pub replace_path: Option, pub upstream: Vec, pub upstream_options: Option>, pub load_balance: Option, } /// Configuration parameters for single upstream destination from a reverse proxy #[derive(PartialEq, Eq, Clone)] pub struct UpstreamUri { pub inner: http::Uri, } /// Configuration parameters on TLS for a single backend application #[derive(PartialEq, Eq, Clone)] pub struct TlsConfig where T: CryptoSource, { pub inner: T, pub https_redirection: bool, }