#tls #client #futures-rustls

futures-rustls

Asynchronous TLS/SSL streams for futures using Rustls

11 releases (6 breaking)

0.26.0 Mar 22, 2024
0.25.0 Dec 5, 2023
0.24.0 Apr 1, 2023
0.22.2 Aug 6, 2022
0.12.0-alpha Jun 1, 2019

#100 in Asynchronous

Download history 92028/week @ 2025-01-28 101861/week @ 2025-02-04 102370/week @ 2025-02-11 98744/week @ 2025-02-18 93157/week @ 2025-02-25 97619/week @ 2025-03-04 96541/week @ 2025-03-11 90688/week @ 2025-03-18 98137/week @ 2025-03-25 92800/week @ 2025-04-01 93567/week @ 2025-04-08 81460/week @ 2025-04-15 108510/week @ 2025-04-22 84381/week @ 2025-04-29 87993/week @ 2025-05-06 79762/week @ 2025-05-13

371,444 downloads per month
Used in 484 crates (45 directly)

MIT/Apache

56KB
1.5K SLoC

futures-rustls

crates docs.rs

Asynchronous TLS/SSL streams for futures using Rustls.

Basic Structure of a Client

use webpki::DNSNameRef;
use futures_rustls::{ TlsConnector, rustls::ClientConfig };

// ...

let mut config = ClientConfig::new();
config.root_store.add_server_trust_anchors(&webpki_roots::TLS_SERVER_ROOTS);
let config = TlsConnector::from(Arc::new(config));
let dnsname = DNSNameRef::try_from_ascii_str("www.rust-lang.org").unwrap();

let stream = TcpStream::connect(&addr).await?;
let mut stream = config.connect(dnsname, stream).await?;

// ...

License & Origin

This project is licensed under either of

at your option.

This started as a fork of tokio-rustls.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in futures-rustls by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~7–30MB
~715K SLoC