Skip to main content

CShake

Struct CShake 

Source
pub struct CShake<Rate: BlockSizes> { /* private fields */ }
Expand description

cSHAKE hasher generic over rate.

Rate MUST be either U168 or U136 for cSHAKE128 and cSHAKE256 respectively.

Implementations§

Source§

impl<Rate: BlockSizes> CShake<Rate>

Source

pub fn new_with_function_name( function_name: &[u8], customization: &[u8], ) -> Self

Creates a new cSHAKE instance with the given function name and customization.

Note that the function name is intended for use by NIST and should only be set to values defined by NIST. You probably don’t need to use this function.

Trait Implementations§

Source§

impl<Rate: BlockSizes> AlgorithmName for CShake<Rate>

Source§

fn write_alg_name(f: &mut Formatter<'_>) -> Result

Write algorithm name into f. Read more
Source§

impl<Rate: BlockSizes> BlockSizeUser for CShake<Rate>

Source§

type BlockSize = Rate

Size of the block in bytes.
Source§

fn block_size() -> usize

Return block size in bytes.
Source§

impl<Rate: Clone + BlockSizes> Clone for CShake<Rate>

Source§

fn clone(&self) -> CShake<Rate>

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<Rate: BlockSizes> CustomizedInit for CShake<Rate>

Source§

fn new_customized(customization: &[u8]) -> Self

Create new hasher instance with the given customization string.
Source§

impl<Rate: BlockSizes> Debug for CShake<Rate>

Source§

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

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

impl<Rate: BlockSizes> Default for CShake<Rate>

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl<Rate: BlockSizes> Drop for CShake<Rate>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<Rate: BlockSizes> ExtendableOutput for CShake<Rate>

Source§

type Reader = CShakeReader<Rate>

Reader
Source§

fn finalize_xof(self) -> Self::Reader

Retrieve XOF reader and consume hasher instance.
Source§

fn finalize_xof_into(self, out: &mut [u8])

Finalize XOF and write result into out.
Source§

fn digest_xof(input: impl AsRef<[u8]>, output: &mut [u8])
where Self: Default,

Compute hash of data and write it into output.
Source§

fn finalize_boxed(self, output_size: usize) -> Box<[u8]>

Available on crate feature alloc only.
Retrieve result into a boxed slice of the specified size and consume the hasher. Read more
Source§

impl<Rate: BlockSizes> Update for CShake<Rate>

Source§

fn update(&mut self, data: &[u8])

Update state using the provided data.
Source§

fn chain(self, data: impl AsRef<[u8]>) -> Self
where Self: Sized,

Digest input data in a chained manner.
Source§

impl<Rate: BlockSizes> HashMarker for CShake<Rate>

Source§

impl<Rate: BlockSizes> ZeroizeOnDrop for CShake<Rate>

Available on crate feature zeroize only.

Auto Trait Implementations§

§

impl<Rate> Freeze for CShake<Rate>
where <Rate as ArraySize>::ArrayType<u8>: Freeze,

§

impl<Rate> RefUnwindSafe for CShake<Rate>
where <Rate as ArraySize>::ArrayType<u8>: RefUnwindSafe,

§

impl<Rate> Send for CShake<Rate>

§

impl<Rate> Sync for CShake<Rate>

§

impl<Rate> Unpin for CShake<Rate>
where <Rate as ArraySize>::ArrayType<u8>: Unpin,

§

impl<Rate> UnsafeUnpin for CShake<Rate>
where <Rate as ArraySize>::ArrayType<u8>: UnsafeUnpin,

§

impl<Rate> UnwindSafe for CShake<Rate>
where <Rate as ArraySize>::ArrayType<u8>: 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> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> SmallBlockSizeUser for T

Source§

type _BlockSize = <T as BlockSizeUser>::BlockSize

Helper associated type equal to <Self as BlockSizeUser>::BlockSize.
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.