Function aggligator_util::net::tls_server
source · pub async fn tls_server<F>(
addr: SocketAddr,
tls_server_cfg: Arc<ServerConfig>,
work_fn: impl Fn(Stream) -> F + Send + 'static
) -> Result<()>where
F: Future<Output = ()> + Send + 'static,Available on crate features
tls and tcp only.Expand description
Runs a TCP server accepting connections of aggregated links, which are encrypted and authenticated using TLS.
The TCP server listens on addr and accepts connections of aggregated TCP links.
For each new connection the work function work_fn is spawned onto a new
Tokio task.
Each incoming link is encrypted using TLS with the configuration specified
in tls_server_cfg.
Example
This example listens on all interfaces on port 5901.
If the server has multiple interfaces, all IP addresses should be registered in DNS so that clients can discover them and establish multiple links.
use std::net::{Ipv6Addr, SocketAddr};
use std::sync::Arc;
use aggligator_util::net::tls_server;
use rustls::ServerConfig;
#[tokio::main]
async fn main() -> std::io::Result<()> {
let tls_certs = todo!("load certificate tree");
let tls_key = todo!("load private key");
let tls_cfg = Arc::new(
ServerConfig::builder()
.with_safe_defaults()
.with_no_client_auth()
.with_single_cert(tls_certs, tls_key)
.unwrap()
);
tls_server(
SocketAddr::new(Ipv6Addr::UNSPECIFIED.into(), 5901),
tls_cfg,
|stream| async move {
// use the incoming connection
}
).await?;
Ok(())
}