| Crates.io | ascon-hash256 |
| lib.rs | ascon-hash256 |
| version | 0.5.0-rc.1 |
| created_at | 2025-03-23 21:56:27.587634+00 |
| updated_at | 2026-01-24 17:10:53.42498+00 |
| description | Implementation of Ascon-Hash256 and Ascon-XOF256 |
| homepage | |
| repository | https://github.com/RustCrypto/hashes |
| max_upload_size | |
| id | 1603108 |
| size | 2,314,845 |
Pure Rust implementation of the lightweight cryptographic hash function Ascon-Hash256 and the extendable output functions (XOF) Ascon-XOF128.
No security audits of this crate have ever been performed.
USE AT YOUR OWN RISK!
Fixed output size hashing:
use ascon_hash256::{AsconHash256, Digest};
use hex_literal::hex;
let mut hasher = AsconHash256::new();
hasher.update(b"some bytes");
let hash = hasher.finalize();
assert_eq!(hash, hex!("e909c2f6da9cb3028423265c8f23fc2d26bfc0f3db704683ef16b787a945ed68"));
// Hex-encode hash using https://docs.rs/base16ct
let hex_hash = base16ct::lower::encode_string(&hash);
assert_eq!(hex_hash, "e909c2f6da9cb3028423265c8f23fc2d26bfc0f3db704683ef16b787a945ed68");
XOF hashing:
use ascon_hash256::{AsconXof128, ExtendableOutput, Update, XofReader};
use hex_literal::hex;
let mut xof = AsconXof128::default();
xof.update(b"some bytes");
let mut reader = xof.finalize_xof();
let mut dst = [0u8; 5];
reader.read(&mut dst);
assert_eq!(dst, hex!("8c7dd114a0"));
Also, see the examples section in the RustCrypto/hashes readme.
The crate is licensed under either of:
at your option.
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.