Expand description
§RustCrypto: TurboSHAKE
Implementation of the TurboSHAKE family of extendable-output functions (XOFs).
§Examples
SHAKE functions have an extendable output, so finalization method returns
XOF reader from which results of arbitrary length can be read. Note that
these functions do not implement Digest, so lower-level traits have to
be imported:
TurboSHAKE supports limited customization using “domain separator” value.
This implementation handles it using the const generic parameter DS.
With the default domain separator:
use turboshake::TurboShake128;
use turboshake::digest::{Update, ExtendableOutput, XofReader};
use hex_literal::hex;
let mut hasher = TurboShake128::default();
hasher.update(b"abc");
let mut reader = hasher.finalize_xof();
let mut buf = [0u8; 10];
reader.read(&mut buf);
assert_eq!(buf, hex!("dcf1646dfe993a8eb6b7"));
reader.read(&mut buf);
assert_eq!(buf, hex!("82d1faaca6d82416a5dc"));With a custom domain separator:
use turboshake::CTurboShake128;
use turboshake::digest::{Update, ExtendableOutput, XofReader};
use hex_literal::hex;
let mut hasher = CTurboShake128::<0x10>::default();
hasher.update(b"abc");
let mut reader = hasher.finalize_xof();
let mut buf = [0u8; 10];
reader.read(&mut buf);
assert_eq!(buf, hex!("6702f7b19ea87087ed0f"));
reader.read(&mut buf);
assert_eq!(buf, hex!("45a2fa692bc18c3526d3"));See the digest crate docs for additional examples.
§License
The crate is licensed under either of:
at your option.
§Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Re-exports§
pub use digest;
Structs§
- Turbo
Shake - TurboSHAKE hasher generic over rate and domain separator.
- Turbo
Shake Reader - Generic TurboSHAKE XOF reader
Constants§
- DEFAULT_
DS - Default domain separator value.
Type Aliases§
- CTurbo
Shake128 - TurboSHAKE128 hasher with a custom domain separator.
- CTurbo
Shake256 - TurboSHAKE256 hasher with a custom domain separator.
- Turbo
Shake128 - TurboSHAKE128 hasher with the default domain separator.
- Turbo
Shake256 - TurboSHAKE256 hasher with the default domain separator.
- Turbo
Shake128 Reader - TurboSHAKE128 XOF reader.
- Turbo
Shake256 Reader - TurboSHAKE256 XOF reader.