[][src]Struct tink_aead::subtle::EncryptThenAuthenticate

pub struct EncryptThenAuthenticate { /* fields omitted */ }

EncryptThenAuthenticate performs an encrypt-then-MAC operation on plaintext and additional authenticated data (aad). The MAC is computed over (aad || ciphertext || size of aad). This implementation is based on http://tools.ietf.org/html/draft-mcgrew-aead-aes-cbc-hmac-sha2-05.

Implementations

impl EncryptThenAuthenticate[src]

pub fn new(
    ind_cpa_cipher: Box<dyn IndCpaCipher>,
    mac: Box<dyn Mac>,
    tag_size: usize
) -> Result<EncryptThenAuthenticate, TinkError>
[src]

Return a new instance of EncryptThenAuthenticate.

Trait Implementations

impl Aead for EncryptThenAuthenticate[src]

pub fn encrypt(
    &self,
    plaintext: &[u8],
    additional_data: &[u8]
) -> Result<Vec<u8>, TinkError>
[src]

Encrypt plaintext with additional_data as additional authenticated data. The resulting ciphertext allows for checking authenticity and integrity of additional data, but does not guarantee its secrecy.

The plaintext is encrypted with an IndCpaCipher, then MAC is computed over (additional_data || ciphertext || n) where n is additional_data's length in bits represented as a 64-bit bigendian unsigned integer. The final ciphertext format is (IND-CPA ciphertext || mac).

pub fn decrypt(
    &self,
    ciphertext: &[u8],
    additional_data: &[u8]
) -> Result<Vec<u8>, TinkError>
[src]

Decrypt ciphertext with additional_data as additional authenticated data.

impl Clone for EncryptThenAuthenticate[src]

Manual implementation of Clone relying on the trait bounds for primitives to provide .box_clone() methods.

Auto Trait Implementations

Blanket Implementations

impl<T> AeadBoxClone for T where
    T: 'static + Aead + Clone
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<V, T> VZip<V> for T where
    V: MultiLane<T>,