Hkdf

Struct Hkdf 

Source
pub struct Hkdf<T: HashEngine> { /* private fields */ }
Expand description

HMAC-based Extract-and-Expand Key Derivation Function (HKDF).

Implementations§

Source§

impl<T> Hkdf<T>
where T: Default + HashEngine,

Source

pub fn new(salt: &[u8], ikm: &[u8]) -> Self

Initializes a HKDF by performing the extract step.

Source

pub fn expand(&self, info: &[u8], okm: &mut [u8]) -> Result<(), MaxLengthError>

Expand the key to generate output key material in okm.

Expand may be called multiple times to derive multiple keys, but the info must be independent from the ikm for security.

Source

pub fn expand_to_len( &self, info: &[u8], len: usize, ) -> Result<Vec<u8>, MaxLengthError>

Expand the key to specified length.

Expand may be called multiple times to derive multiple keys, but the info must be independent from the ikm for security.

Trait Implementations§

Source§

impl<T: Clone + HashEngine> Clone for Hkdf<T>
where T::Hash: Clone,

Source§

fn clone(&self) -> Hkdf<T>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: HashEngine> Debug for Hkdf<T>

Source§

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

Formats the value using the given formatter. Read more
Source§

impl<T: Copy + HashEngine> Copy for Hkdf<T>
where T::Hash: Copy,

Auto Trait Implementations§

§

impl<T> Freeze for Hkdf<T>
where <T as HashEngine>::Hash: Freeze,

§

impl<T> RefUnwindSafe for Hkdf<T>
where <T as HashEngine>::Hash: RefUnwindSafe,

§

impl<T> Send for Hkdf<T>
where <T as HashEngine>::Hash: Send,

§

impl<T> Sync for Hkdf<T>
where <T as HashEngine>::Hash: Sync,

§

impl<T> Unpin for Hkdf<T>
where <T as HashEngine>::Hash: Unpin,

§

impl<T> UnwindSafe for Hkdf<T>
where <T as HashEngine>::Hash: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

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

Performs the conversion.