rama-boring-tokio

Crates.iorama-boring-tokio
lib.rsrama-boring-tokio
version0.4.0
created_at2025-03-19 20:17:14.007611+00
updated_at2025-08-05 09:35:59.319009+00
descriptionAn implementation of SSL streams for Tokio backed by BoringSSL in function of Rama
homepagehttps://github.com/plabayo/rama-boring
repositoryhttps://github.com/plabayo/rama-boring
max_upload_size
id1598564
size77,374
Glen De Cauwsemaecker (GlenDC)

documentation

https://docs.rs/rama-boring-tokio

README

rama-boring-tokio

An implementation of SSL streams for Tokio backed by BoringSSL in function of Rama.

Documentation

Usage

First, add this to your Cargo.toml:

cargo add rama-boring-tokio

Then, use either accept or connect as appropriate.

use rama_boring::ssl;
use tokio::net::TcpListener;

#[tokio::main]
async fn main() -> anyhow::Result<()> {
    let listener = TcpListener::bind("127.0.0.1:8080").await?;
    let (tcp_stream, _addr) = listener.accept().await?;

    let server = ssl::SslMethod::tls_server();
    let mut ssl_builder = rama_boring::ssl::SslAcceptor::mozilla_modern(server)?;
    ssl_builder.set_default_verify_paths()?;
    ssl_builder.set_verify(ssl::SslVerifyMode::PEER);
    let acceptor = ssl_builder.build();
    let _ssl_stream = rama_boring_tokio::accept(&acceptor, tcp_stream).await?;
    Ok(())
}

This library is an implementation of TLS streams using BoringSSL for negotiating the connection. 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.

rama-boring-tokio exports this ability through [accept] and [connect]. accept should be used by servers, and connect by clients. These augment the functionality provided by the [boring] crate, on which this crate is built. Configuration of TLS parameters is still primarily done through the [boring] crate.

License

This project is licensed under either of

at your option.

Contribution

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

Accolades

The project is based on a tokio-boring which itself is based on a fork of tokio-openssl.

Commit count: 3296

cargo fmt