#hash #digest #semver #version #crypto

no-std ripemd

Pure Rust implementation of the RIPEMD hash functions

6 releases

0.2.0-pre.4 Sep 22, 2024
0.1.3 Sep 23, 2022
0.1.1 Feb 17, 2022
0.1.0 Dec 7, 2021
0.0.0 Feb 13, 2017

#1783 in Cryptography

Download history 107222/week @ 2024-07-19 113275/week @ 2024-07-26 111132/week @ 2024-08-02 113720/week @ 2024-08-09 114574/week @ 2024-08-16 113328/week @ 2024-08-23 120158/week @ 2024-08-30 124384/week @ 2024-09-06 117114/week @ 2024-09-13 122512/week @ 2024-09-20 120515/week @ 2024-09-27 132371/week @ 2024-10-04 127375/week @ 2024-10-11 154671/week @ 2024-10-18 162832/week @ 2024-10-25 127719/week @ 2024-11-01

598,463 downloads per month
Used in 940 crates (102 directly)

MIT/Apache

74KB
1K SLoC

RustCrypto: RIPEMD

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

Pure Rust implementation of the RIPEMD cryptographic hash.

This crate implements only the modified 1996 versions, not the original one from 1992.

Note that RIPEMD-256 provides only the same security as RIPEMD-128, and RIPEMD-320 provides only the same security as RIPEMD-160.

Examples

use ripemd::{Ripemd160, Ripemd320, Digest};
use hex_literal::hex;

let mut hasher = Ripemd160::new();
hasher.update(b"Hello world!");
let hash160 = hasher.finalize();

assert_eq!(hash160, hex!("7f772647d88750add82d8e1a7a3e5c0902a346a3"));

// Hex-encode hash using https://docs.rs/base16ct
let hex_hash160 = base16ct::lower::encode_string(&hash160);
assert_eq!(hex_hash160, "7f772647d88750add82d8e1a7a3e5c0902a346a3");

// Same example for RIPEMD-320
let mut hasher = Ripemd320::new();
hasher.update(b"Hello world!");
let hash320 = hasher.finalize();

assert_eq!(hash320, hex!(
    "f1c1c231d301abcf2d7daae0269ff3e7bc68e623"
    "ad723aa068d316b056d26b7d1bb6f0cc0f28336d"
));

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

~300–520KB
~12K SLoC