#tls-stream #async-io #native-tls #io-stream #async-tls #tokio #non-blocking

tokio-native-tls

An implementation of TLS/SSL streams for Tokio using native-tls giving an implementation of TLS for nonblocking I/O streams

4 releases (2 breaking)

0.3.1 Feb 7, 2023
0.3.0 Dec 24, 2020
0.2.0 Oct 16, 2020
0.1.0 Apr 3, 2020

#56 in Asynchronous

Download history 1037046/week @ 2024-09-19 1088866/week @ 2024-09-26 1487791/week @ 2024-10-03 1446273/week @ 2024-10-10 1538767/week @ 2024-10-17 1074211/week @ 2024-10-24 893765/week @ 2024-10-31 844427/week @ 2024-11-07 906332/week @ 2024-11-14 874937/week @ 2024-11-21 835823/week @ 2024-11-28 1080675/week @ 2024-12-05 1009500/week @ 2024-12-12 608129/week @ 2024-12-19 458641/week @ 2024-12-26 649755/week @ 2025-01-02

2,971,501 downloads per month
Used in 2,338 crates (191 directly)

MIT license

21KB
326 lines

tokio-tls

An implementation of TLS/SSL streams for Tokio built on top of the native-tls crate

License

This project is licensed under the MIT license.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Tokio by you, shall be licensed as MIT, without any additional terms or conditions.


lib.rs:

Async TLS streams

This library is an implementation of TLS streams using the most appropriate system library by default for negotiating the connection. That is, on Windows this library uses SChannel, on OSX it uses SecureTransport, and on other platforms it uses OpenSSL.

Each TLS stream implements the Read and Write traits to interact and interoperate with the rest of the futures I/O ecosystem. Client connections initiated from this crate verify hostnames automatically and by default.

This crate primarily exports this ability through two newtypes, TlsConnector and TlsAcceptor. These newtypes augment the functionality provided by the native-tls crate, on which this crate is built. Configuration of TLS parameters is still primarily done through the native-tls crate.

Dependencies

~2–13MB
~159K SLoC