pub fn bind_rustls(
addr: SocketAddr,
config: RustlsConfig,
) -> Server<RustlsAcceptor>
Available on crate feature
tls-rustls
only.Expand description
Creates a TLS server that binds to the provided address using the rustls library.
Examples found in repository?
examples/rustls_server.rs (line 22)
10async fn main() {
11 let app = Router::new().route("/", get(|| async { "Hello, world!" }));
12
13 let config = RustlsConfig::from_pem_file(
14 "examples/self-signed-certs/cert.pem",
15 "examples/self-signed-certs/key.pem",
16 )
17 .await
18 .unwrap();
19
20 let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
21 println!("listening on {}", addr);
22 hyper_server::bind_rustls(addr, config)
23 .serve(app.into_make_service())
24 .await
25 .unwrap();
26}
More examples
examples/http_and_https.rs (line 48)
36async fn https_server() {
37 let app = Router::new().route("/", get(|| async { "Hello, world!" }));
38
39 let config = RustlsConfig::from_pem_file(
40 "examples/self-signed-certs/cert.pem",
41 "examples/self-signed-certs/key.pem",
42 )
43 .await
44 .unwrap();
45
46 let addr = SocketAddr::from(([127, 0, 0, 1], 3443));
47 println!("https listening on {}", addr);
48 hyper_server::bind_rustls(addr, config)
49 .serve(app.into_make_service())
50 .await
51 .unwrap();
52}
examples/rustls_reload.rs (line 30)
15async fn main() {
16 let app = Router::new().route("/", get(|| async { "Hello, world!" }));
17
18 let config = RustlsConfig::from_pem_file(
19 "examples/self-signed-certs/cert.pem",
20 "examples/self-signed-certs/key.pem",
21 )
22 .await
23 .unwrap();
24
25 // Spawn a task to reload tls.
26 tokio::spawn(reload(config.clone()));
27
28 let addr = SocketAddr::from(([127, 0, 0, 1], 3000));
29 println!("listening on {}", addr);
30 hyper_server::bind_rustls(addr, config)
31 .serve(app.into_make_service())
32 .await
33 .unwrap();
34}