[][src]Struct orion::aead::SecretKey

#[must_use]
pub struct SecretKey { /* fields omitted */ }

A type to represent a secret key.

As default it will randomly generate a SecretKey of 32 bytes.

Note:

Due to the return type of the Default trait, the default() method cannot let the caller handle a failing CSPRNG. If the CSPRNG fails, that function panics. If handling a failing CSPRNG's error is needed, use instead generate().

Exceptions:

An exception will be thrown if:

  • slice is empty.
  • The OsRng fails to initialize or read from its source.
  • length is 0.
  • length is not less than u32::max_value().

Security:

  • Avoid using unprotected_as_bytes() whenever possible, as it breaks all protections that the type implements.

Methods

impl SecretKey[src]

#[must_use]
pub fn from_slice(slice: &[u8]) -> Result<SecretKey, UnknownCryptoError>
[src]

Make an object from a given byte slice.

#[must_use]
pub fn unprotected_as_bytes(&self) -> &[u8]
[src]

Return the object as byte slice. Warning: Should not be used unless strictly needed. This breaks protections that the type implements.

pub fn get_length(&self) -> usize[src]

Return the length of the object.

#[must_use]
pub fn generate(length: usize) -> Result<SecretKey, UnknownCryptoError>
[src]

Randomly generate using a CSPRNG. Not available in no_std context.

Trait Implementations

impl Drop for SecretKey[src]

impl PartialEq<SecretKey> for SecretKey[src]

#[must_use]
fn ne(&self, other: &Rhs) -> bool
1.0.0
[src]

This method tests for !=.

impl Default for SecretKey[src]

#[must_use]
fn default() -> SecretKey
[src]

Randomly generate using a CSPRNG with recommended size. Not available in no_std context.

impl Debug for SecretKey[src]

Auto Trait Implementations

impl Send for SecretKey

impl Sync for SecretKey

Blanket Implementations

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

impl<T> From for T[src]

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

type Error = !

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

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

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

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

🔬 This is a nightly-only experimental API. (try_from)

The type returned in the event of a conversion error.

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

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

impl<T> Clear for T where
    T: InitializableFromZeroed + ?Sized
[src]

impl<T> InitializableFromZeroed for T where
    T: Default
[src]