Trait snow::types::Cipher

source ·
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, Error>; 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§