crypto_common

Trait KeyInit

Source
pub trait KeyInit: KeySizeUser + Sized {
    // Required method
    fn new(key: &Key<Self>) -> Self;

    // Provided methods
    fn new_from_slice(key: &[u8]) -> Result<Self, InvalidLength> { ... }
    fn generate_key(rng: impl CryptoRng + RngCore) -> Key<Self> { ... }
}
Expand description

Types which can be initialized from key.

Required Methods§

Source

fn new(key: &Key<Self>) -> Self

Create new value from fixed size key.

Provided Methods§

Source

fn new_from_slice(key: &[u8]) -> Result<Self, InvalidLength>

Create new value from variable size key.

Source

fn generate_key(rng: impl CryptoRng + RngCore) -> Key<Self>

Generate random key using the provided CryptoRng.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§

Source§

impl<T> KeyInit for T
where T: InnerInit, T::Inner: KeyInit,