Struct ring::aead::SealingKey[][src]

pub struct SealingKey<N: NonceSequence> { /* fields omitted */ }
Expand description

An AEAD key for encrypting and signing (“sealing”), bound to a nonce sequence.

Intentionally not Clone or Copy since cloning would allow duplication of the nonce sequence.

Implementations

impl<N: NonceSequence> SealingKey<N>[src]

pub fn seal_in_place<A, InOut>(
    &mut self,
    aad: Aad<A>,
    in_out: &mut InOut
) -> Result<(), Unspecified> where
    A: AsRef<[u8]>,
    InOut: AsMut<[u8]> + for<'in_out> Extend<&'in_out u8>, 
[src]

👎 Deprecated:

Renamed to seal_in_place_append_tag.

Deprecated. Renamed to [seal_in_place_append_tag()].

pub fn seal_in_place_append_tag<A, InOut>(
    &mut self,
    aad: Aad<A>,
    in_out: &mut InOut
) -> Result<(), Unspecified> where
    A: AsRef<[u8]>,
    InOut: AsMut<[u8]> + for<'in_out> Extend<&'in_out u8>, 
[src]

Encrypts and signs (“seals”) data in place, appending the tag to the resulting ciphertext.

key.seal_in_place_append_tag(aad, in_out) is equivalent to:

key.seal_in_place_separate_tag(aad, in_out.as_mut())
    .map(|tag| in_out.extend(tag.as_ref()))

pub fn seal_in_place_separate_tag<A>(
    &mut self,
    aad: Aad<A>,
    in_out: &mut [u8]
) -> Result<Tag, Unspecified> where
    A: AsRef<[u8]>, 
[src]

Encrypts and signs (“seals”) data in place.

aad is the additional authenticated data (AAD), if any. This is authenticated but not encrypted. The type A could be a byte slice &[u8], a byte array [u8; N] for some constant N, Vec<u8>, etc. If there is no AAD then use Aad::empty().

The plaintext is given as the input value of in_out. seal_in_place() will overwrite the plaintext with the ciphertext and return the tag. For most protocols, the caller must append the tag to the ciphertext. The tag will be self.algorithm.tag_len() bytes long.

Trait Implementations

impl<N: NonceSequence> BoundKey<N> for SealingKey<N>[src]

fn new(key: UnboundKey, nonce_sequence: N) -> Self[src]

Constructs a new key from the given UnboundKey and NonceSequence.

fn algorithm(&self) -> &'static Algorithm[src]

The key’s AEAD algorithm.

impl<N: NonceSequence> Debug for SealingKey<N>[src]

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>[src]

Formats the value using the given formatter. Read more

Auto Trait Implementations

impl<N> Send for SealingKey<N> where
    N: Send

impl<N> Sync for SealingKey<N> where
    N: Sync

impl<N> Unpin for SealingKey<N> where
    N: Unpin

Blanket Implementations

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

pub fn type_id(&self) -> TypeId[src]

Gets the TypeId of self. Read more

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

pub fn borrow(&self) -> &T[src]

Immutably borrows from an owned value. Read more

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

pub fn borrow_mut(&mut self) -> &mut T[src]

Mutably borrows from an owned value. Read more

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

pub fn from(t: T) -> T[src]

Performs the conversion.

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

pub fn into(self) -> U[src]

Performs the conversion.

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.

pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]

Performs the conversion.

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.

pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]

Performs the conversion.