Expand description
An implementation of the BLAKE2 hash functions.
Usage
Blake2b
can be used in the following way:
use blake2::{Blake2b, Blake2s, Digest};
use hex_literal::hex;
// create a Blake2b object
let mut hasher = Blake2b::new();
// write input message
hasher.update(b"hello world");
// read hash digest and consume hasher
let res = hasher.finalize();
assert_eq!(res[..], hex!("
021ced8799296ceca557832ab941a50b4a11f83478cf141f51f933f653ab9fbc
c05a037cddbed06e309bf334942c4e58cdf1a46e237911ccd7fcf9787cbc7fd0
")[..]);
// same example for `Blake2s`:
let mut hasher = Blake2s::new();
hasher.update(b"hello world");
let res = hasher.finalize();
assert_eq!(res[..], hex!("
9aec6806794561107e594b1f6a8a6b0c92a0cba9acf5e5e93cca06f781813b0b
")[..]);
Also see RustCrypto/hashes readme.
Variable output size
If you need variable sized output you can use VarBlake2b
and VarBlake2s
which support variable output sizes through VariableOutput
trait. Update
trait has to be imported as well.
use blake2::VarBlake2b;
use blake2::digest::{Update, VariableOutput};
let mut hasher = VarBlake2b::new(10).unwrap();
hasher.update(b"my_input");
hasher.finalize_variable(|res| {
assert_eq!(res, [44, 197, 92, 132, 228, 22, 146, 78, 100, 0])
})
Message Authentication Code (MAC)
BLAKE2 can be used as a MAC without any additional constructs:
use blake2::Blake2b;
use blake2::crypto_mac::{Mac, NewMac};
let mut hasher = Blake2b::new_varkey(b"my key").unwrap();
hasher.update(b"hello world");
// `result` has type `crypto_mac::Output` which is a thin wrapper around
// a byte array and provides a constant time equality check
let result = hasher.finalize();
// To get underlying array use the `into_bytes` method, but be careful,
// since incorrect use of the code value may permit timing attacks which
// defeat the security provided by the `crypto_mac::Output`
let code_bytes = result.into_bytes();
// To verify the message it's recommended to use `verify` method
let mut hasher = Blake2b::new_varkey(b"my key").unwrap();
hasher.update(b"hello world");
// `verify` return `Ok(())` if code is correct, `Err(MacError)` otherwise
hasher.verify(&code_bytes).unwrap();
Acknowledgment
Based on the blake2-rfc crate.
Re-exports
pub use crypto_mac;
pub use digest;
Structs
Blake2b instance with a fixed output.
Blake2s instance with a fixed output.
Blake2b instance with a variable output.
Blake2s instance with a variable output.
Traits
The Digest
trait specifies an interface common for digest functions.