hkdf

Struct Hkdf

source
pub struct Hkdf<H: BitcoinHash> {
    pub(crate) prk: Hmac<H>,
}
Expand description

Implements the RFC5869 hash based key derivation function using the hash function H.

Fields§

§prk: Hmac<H>

Implementations§

source§

impl<H: BitcoinHash> Hkdf<H>

source

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

Run HKDF-extract and keep the resulting pseudo random key as internal state

§Inputs
  • ikm: Input keying material, secret key material our keys will be derived from
  • salt: Optional salt value, if not required set to &[0; H::LEN]. As noted in the RFC the salt value can also be a secret.
source

pub fn from_prk(prk: Hmac<H>) -> Self

Construct the HKDF from a pseudo random key that has the correct distribution and length already (e.g. because it’s the output of a previous HKDF round), skipping the HKDF-extract step. If in doubt, please use Hkdf::new instead!

See also Hkdf::derive_hmac.

source

pub fn derive<const LEN: usize>(&self, info: &[u8]) -> [u8; LEN]

Run HKDF-expand to generate new key material

§Inputs
  • info: Defines which key to derive. Different values lead to different keys.
  • LEN: Defines the length of the key material to generate in octets. Note that LEN <= H::LEN * 255 has to be true.
§Panics

If LEN > H::LEN * 255.

source

pub fn derive_hmac(&self, info: &[u8]) -> Hmac<H>

Run HKDF-expand to generate new key material with L = H::LEN

See Hkdf::derive for more information.

Trait Implementations§

source§

impl<H: Clone + BitcoinHash> Clone for Hkdf<H>

source§

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

Returns a copy of the value. Read more
1.0.0 · source§

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

Performs copy-assignment from source. Read more

Auto Trait Implementations§

§

impl<H> Freeze for Hkdf<H>
where H: Freeze,

§

impl<H> RefUnwindSafe for Hkdf<H>
where H: RefUnwindSafe,

§

impl<H> Send for Hkdf<H>
where H: Send,

§

impl<H> Sync for Hkdf<H>
where H: Sync,

§

impl<H> Unpin for Hkdf<H>
where H: Unpin,

§

impl<H> UnwindSafe for Hkdf<H>
where H: 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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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.