pub trait Cipher: Send + Sync {
    fn name(&self) -> &'static str;
fn set(&mut self, key: &[u8]);
fn encrypt(
        &self,
        nonce: u64,
        authtext: &[u8],
        plaintext: &[u8],
        out: &mut [u8]
    ) -> usize;
fn decrypt(
        &self,
        nonce: u64,
        authtext: &[u8],
        ciphertext: &[u8],
        out: &mut [u8]
    ) -> Result<usize, ()>; fn rekey(&mut self) { ... } }
Expand description

Cipher operations

Required methods

The string that the Noise spec defines for the primitive

Set the key

Encrypt (with associated data) a given plaintext.

Decrypt (with associated data) a given ciphertext.

Provided methods

Rekey according to Section 4.2 of the Noise Specification, with a default implementation guaranteed to be secure for all ciphers.

Implementors