22 releases

0.11.0-pre.4 Jul 27, 2024
0.11.0-pre.2 Jan 19, 2024
0.10.4 Sep 2, 2022
0.10.1 Feb 17, 2022
0.3.0 Nov 17, 2016

#2695 in Cryptography

Download history 28088/week @ 2024-09-14 30111/week @ 2024-09-21 26832/week @ 2024-09-28 18207/week @ 2024-10-05 29718/week @ 2024-10-12 34725/week @ 2024-10-19 33996/week @ 2024-10-26 32386/week @ 2024-11-02 22900/week @ 2024-11-09 35426/week @ 2024-11-16 37446/week @ 2024-11-23 44350/week @ 2024-11-30 46274/week @ 2024-12-07 44430/week @ 2024-12-14 10237/week @ 2024-12-21 10585/week @ 2024-12-28

117,782 downloads per month
Used in 30 crates (21 directly)

MIT/Apache

63KB
2.5K SLoC

RustCrypto: Whirlpool

crate Docs Apache2/MIT licensed Rust Version Project Chat Build Status

Pure Rust implementation of the Whirlpool cryptographic hash algorithm.

This is the algorithm recommended by NESSIE (New European Schemes for Signatures, Integrity and Encryption; an European research project).

The constants used by Whirlpool were changed twice (2001 and 2003) - this crate only implements the most recent standard. The two older Whirlpool implementations (sometimes called Whirlpool-0 (pre 2001) and Whirlpool-T (pre 2003)) were not used much anyway (both have never been recommended by NESSIE).

For details see this page.

Examples

use whirlpool::{Whirlpool, Digest};
use hex_literal::hex;

let mut hasher = Whirlpool::new();
hasher.update(b"Hello Whirlpool");
let hash = hasher.finalize();

assert_eq!(hash, hex!(
    "8eaccdc136903c458ea0b1376be2a5fc9dc5b8ce8892a3b4f43366e2610c206c"
    "a373816495e63db0fff2ff25f75aa7162f332c9f518c3036456502a8414d300a"
));

// Hex-encode hash using https://docs.rs/base16ct
let hex_hash = base16ct::lower::encode_string(&hash);
assert_eq!(
    hex_hash,
    "8eaccdc136903c458ea0b1376be2a5fc9dc5b8ce8892a3b4f43366e2610c206c\
     a373816495e63db0fff2ff25f75aa7162f332c9f518c3036456502a8414d300a",
);

Also, see the examples section in the RustCrypto/hashes readme.

Minimum Supported Rust Version

Rust 1.71 or higher.

Minimum supported Rust version can be changed in the future, but it will be done with a minor version bump.

SemVer Policy

  • All on-by-default features of this library are covered by SemVer
  • MSRV is considered exempt from SemVer as noted above

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.

Dependencies

~305–465KB
~11K SLoC