#noise-protocol #authenticated-encryption #noise

tokio-noise

A Noise protocol encryption layer on top of tokio streams

4 releases

0.0.4 Jun 20, 2024
0.0.3 Apr 12, 2024
0.0.2 Apr 12, 2024
0.0.1 Apr 10, 2024

#10 in #noise-protocol

Download history 5/week @ 2024-06-24 12/week @ 2024-07-29 9/week @ 2024-08-26 31/week @ 2024-09-02 24/week @ 2024-09-09 8/week @ 2024-09-16 33/week @ 2024-09-23 22/week @ 2024-09-30 3/week @ 2024-10-07

66 downloads per month
Used in hyper-noise

Unlicense

57KB
1K SLoC

tokio-noise

An authenticated encryption layer on top of tokio streams, driven by the Noise Protocol Framework.

This library is sponsored by DLC.Link.

Usage

use tokio::net::{TcpListener, TcpStream};
use tokio_noise::{NoiseError, NoiseTcpStream};

const PSK: [u8; 32] = [0xFF; 32];

async fn run_noise_server(tcp_stream: TcpStream) -> Result<(), NoiseError> {
    let mut noise_stream = NoiseTcpStream::handshake_responder_psk0(tcp_stream, &PSK).await?;
    let mut buf = [0u8; 1024];
    let n = noise_stream.recv(&mut buf).await?;
    assert_eq!(&buf[..n], b"hello world");
    Ok(())
}

#[tokio::main]
async fn main() -> Result<(), NoiseError> {
    let listener = TcpListener::bind("127.0.0.1:0").await?;
    let addr = listener.local_addr()?;

    let srv = tokio::task::spawn(async move {
        let (tcp_stream, _) = listener.accept().await?;
        run_noise_server(tcp_stream).await
    });

    // Client
    let tcp_stream = TcpStream::connect(&addr).await?;
    let mut noise_stream = NoiseTcpStream::handshake_initiator_psk0(tcp_stream, &PSK).await?;
    noise_stream.send(b"hello world").await?;

    // Wait for server to finish
    srv.await.unwrap()?;

    Ok(())
}

Dependencies

~3–11MB
~100K SLoC