Struct dryoc::generichash::GenericHash
source · pub struct GenericHash<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> { /* private fields */ }
Expand description
Provides a generic hash function implementation based on Blake2b. Compatible with libsodium’s generic hash.
Implementations
sourceimpl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
impl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
sourcepub fn new<Key: ByteArray<KEY_LENGTH>>(key: Option<&Key>) -> Result<Self, Error>
pub fn new<Key: ByteArray<KEY_LENGTH>>(key: Option<&Key>) -> Result<Self, Error>
Returns a new hasher instance, with key
.
sourcepub fn update<Input: Bytes + ?Sized>(&mut self, input: &Input)
pub fn update<Input: Bytes + ?Sized>(&mut self, input: &Input)
Updates the hasher state from input
.
sourcepub fn finalize<Output: NewByteArray<OUTPUT_LENGTH>>(
self
) -> Result<Output, Error>
pub fn finalize<Output: NewByteArray<OUTPUT_LENGTH>>(
self
) -> Result<Output, Error>
Computes and returns the final hash value.
sourcepub fn finalize_to_vec(self) -> Result<Vec<u8>, Error>
pub fn finalize_to_vec(self) -> Result<Vec<u8>, Error>
Computes and returns the final hash value as a Vec
. Provided for
convenience.
sourcepub fn hash<Input: Bytes + ?Sized, Key: ByteArray<KEY_LENGTH>, Output: NewByteArray<OUTPUT_LENGTH>>(
input: &Input,
key: Option<&Key>
) -> Result<Output, Error>
pub fn hash<Input: Bytes + ?Sized, Key: ByteArray<KEY_LENGTH>, Output: NewByteArray<OUTPUT_LENGTH>>(
input: &Input,
key: Option<&Key>
) -> Result<Output, Error>
Onet-time interface for the generic hash function. Computes the hash for
input
with optional key
. The output length is determined by the type
signature of Output
.
Example
use base64::encode;
use dryoc::generichash::{GenericHash, Hash};
let output: Hash =
GenericHash::hash(b"hello", Some(b"a very secret key")).expect("hash failed");
assert_eq!(
encode(&output),
"AECDe+XJsB6nOkbCsbS/OPXdzpcRm3AolW/Bg1LFY9A="
);
sourceimpl GenericHash<CRYPTO_GENERICHASH_KEYBYTES, CRYPTO_GENERICHASH_BYTES>
impl GenericHash<CRYPTO_GENERICHASH_KEYBYTES, CRYPTO_GENERICHASH_BYTES>
sourcepub fn new_with_defaults<Key: ByteArray<CRYPTO_GENERICHASH_KEYBYTES>>(
key: Option<&Key>
) -> Result<Self, Error>
pub fn new_with_defaults<Key: ByteArray<CRYPTO_GENERICHASH_KEYBYTES>>(
key: Option<&Key>
) -> Result<Self, Error>
Returns an instance of GenericHash
with the default output and key
length parameters.
Auto Trait Implementations
impl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> RefUnwindSafe for GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
impl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> Send for GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
impl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> Sync for GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
impl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> Unpin for GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
impl<const KEY_LENGTH: usize, const OUTPUT_LENGTH: usize> UnwindSafe for GenericHash<KEY_LENGTH, OUTPUT_LENGTH>
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more