33 releases (19 breaking)
0.23.0 | May 19, 2023 |
---|---|
0.22.1 | Sep 16, 2022 |
0.22.0 | Jun 21, 2022 |
0.21.0 | Jul 17, 2020 |
0.7.1 | Jul 1, 2019 |
#819 in Cryptography
2,577 downloads per month
Used in 47 crates
(11 directly)
255KB
5.5K
SLoC
merkle
merkle is a lightweight Rust implementation of a Merkle tree.
Features
- external dependency agnostic
std::hash::Hasher
compatibility- standard types hasher implementations
#[derive(Hashable)]
support for simple struct- customizable merkle leaf/node hashing algorithm
- support for custom hash types (e.g. [u8; 16], [u64; 4], [u128; 2], struct)
- customizable hashing algorithm
- linear memory layout, no nodes on heap
- buildable from iterator, objects or hashes
- certificate transparency style merkle hashing support
- SPV support included (via proof type)
- supports power of 2 arity merkletrees (only)
- supports compound merkletrees (a tree of merkletrees)
- supports compound-compound merkletrees (a tree of compound merkletrees)
Documentation
Documentation is available.
Examples
The most relevant examples are located in the following files:
test_common.rs
: custom hash example xor128, misc shared utilstest_xor128.rs
: most comprehensive tests for library featuresproof.rs
: contains impl and tests for proofs across pow2 arity trees
Building and testing
# Run tests in release mode
cargo test --release --all
# Run ignored tests in release mode
cargo test --release --all -- --ignored
Bug Reporting
Please report bugs either as pull requests or as issues in the issue tracker. merkle has a full disclosure vulnerability policy. Please do NOT attempt to report any security vulnerability in this code privately to anybody.
License
See LICENSE.
Dependencies
~4–14MB
~180K SLoC