Crate clatter

Source
Expand description

§Clatter 🔊

no_std compatible, pure Rust implementation of the Noise framework with support for Post Quantum (PQ) extensions as presented by Yawning Angel, Benjamin Dowling, Andreas Hülsing, Peter Schwabe, and Fiona Johanna Weber.

From user perspective, everything in this crate is built around three types:

Users will pick and instantiate the desired handshake state machine with the crypto primitives and handshakepattern::HandshakePattern they wish to use and complete the handshake using the methods provided by the common Handshaker trait:

Handshake messages are exchanged by the peers until the handshake is completed. After completion, Handshaker::finalize is called and the handshake state machine is consumed into a transportstate::TransportState instance, which can be used to decrypt and encrypt communication between the peers.

§Handshake Patterns

Selected fundamental Noise and PQNoise patterns are available pre-made in the handshakepattern module. Utilities in that module can also be used to craft additional handshake patterns.

§Crypto Vendors

Currently Clatter has frozen the vendor selection for DH, Cipher and Hash algorithms, but users can select from multiple KEM vendors.

Concrete implementations of the crypto algorithms are in the crypto module and it is even possible to use custom implementations using the definitions in the traits module.

§Features

To improve build times and produce more optimized binaries, Clatter can be heavily configured by enabling and disabling crate features. Below is a listing of the available features:

Feature flagDescriptionDefaultDetails
use-25519Enable X25519 DHyes
use-aes-gcmEnable AES-GCM cipheryes
use-chacha20poly1305Enable ChaCha20-Poly1305 cipheryes
use-shaEnable SHA-256 and SHA-512 hashingyes
use-blake2Enable BLAKE2 hashingyes
use-rust-crypto-ml-kemEnable ML-KEM (Kyber) KEMs by RustCryptoyes
use-pqclean-kyberEnable Kyber KEMs by PQCleanyes
stdEnable standard library supportnoEnables std for supported dependencies
allocEnable allocator supportno

§Example

Simplified example with the most straightforward (and unsecure) PQ handshake pattern and no handshake payload data at all:

use clatter::crypto::cipher::ChaChaPoly;
use clatter::crypto::hash::Sha512;
use clatter::crypto::kem::rust_crypto_ml_kem::MlKem512;
use clatter::handshakepattern::noise_pqnn;
use clatter::traits::Handshaker;
use clatter::PqHandshake;

let mut rng_alice = rand::thread_rng();

// Instantiate initiator handshake
let mut alice = PqHandshake::<MlKem512, MlKem512, ChaChaPoly, Sha512, _>::new(
    noise_pqnn(),   // Handshake pattern
    &[],            // Prologue data
    true,           // Are we the initiator
    None,           // Pre-shared keys..
    None,           // ..
    None,           // ..
    None,           // ..
    &mut rng_alice, // RNG instance
).unwrap();

let mut buf_alice_send = [0u8; 4096];

// Send and receive handshake messages until the handshake is completed
loop {
    if alice.is_write_turn() {
        // Write handshake message to buf_alice_send
        let n = alice.write_message(&[], &mut buf_alice_send).unwrap();
        // --> Deliver buf_alice_send[..n] to peer
    } else {
        // <-- Receive message from peer to &buf_alice_receive
        let buf_alice_receive = [0u8];
        // Process received handshake message
        let _ = alice.read_message(&buf_alice_receive, &mut[]).unwrap();
    }

    if alice.is_finished() {
        break;
    }
}

// Move to transport state
let mut alice = alice.finalize().unwrap();

// All done! Use .send() and .receive() on the transport state to encrypt
// and decrypt communication with the peer
let n = alice.send(b"Hello from Alice", &mut buf_alice_send).unwrap();
// --> Send &buf_alice_send[..n]) to peer

Re-exports§

pub use traits::Handshaker;

Modules§

bytearray
Generic array utilities used throughout the crate
cipherstate
Cipherstate implementation
constants
Common constants and hard limits
crypto
Concrete crypto implementations
error
Error types used by Clatter
handshakepattern
Pre-made Noise handshake patterns and tools for defining new ones
traits
Common traits used throughout the crate
transportstate
Transport state implementation

Structs§

DualLayerHandshake
Dual layer handshake
KeyPair
A zeroize-on-drop container for keys
NqHandshake
Non-post-quantum Noise handshake
PqHandshake
Post-quantum Noise handshake