eth-merkle-tree-rs
)A Rust library and command-line interface (CLI) for working with Ethereum's Merkle tree structure.
To include eth-merkle-tree-rs
in your project, add it to your Cargo.toml
:
toml
[dependencies]
petgraph = "0.6"
hex = "0.4"
rust-crypto = "0.2"
structopt = "0.3"
indicatif = "0.17"
csv = "1.1"
colored = "2.0"
```rust use ethmerkletree::tree::MerkleTree;
let data = vec![ String::from("0x901Ab22EdCA65188686C9742F2C88c946698bc90, 100"), String::from("0x7b95d138cD923476b6e697391DD2aA01D15BAB27, 100"), ];
let tree = MerkleTree::new(data).expect("Tree creation error."); let root = tree.root.expect("Unable to access root"); println!("Root: {}", root.data);
``` or
```rust use ethmerkletree::tree::MerkleTree;
let data = vec![ String::from("0x901Ab22EdCA65188686C9742F2C88c946698bc90), String::from("0x7b95d138cD923476b6e697391DD2aA01D15BAB27), ];
let tree = MerkleTree::new(data).expect("Tree creation error."); let root = tree.root.expect("Unable to access root"); println!("Root: {}", root.data);
```
Can visualize the tree structure using the provided visualization tools:
```rust use ethmerkletree::graph::visualizer::graphviz;
graphviz(&tree).expect("Visualization Error!"); ```
The library also comes with a command-line interface for interacting with Merkle trees.
To visualize the tree, use the -v or --visualize flag:
bash
$ emtr -- ./example.txt -v
To generate a Merkle proof for a specific leaf:
bash
$ emtr -- ./example.txt --proof 0x901Ab22EdCA65188686C9742F2C88c946698bc90
Once the proof has been generated, it can be validated in Solidity using MerkleProof as in the following example:
```solidity pragma solidity >=0.8.0 <0.9.0;
import "@openzeppelin/contracts/utils/cryptography/MerkleProof.sol";
contract Verifier {
bytes32 private root;
constructor(bytes32 _root) { root = _root; }
function verify( bytes32[] memory proof, address addr, uint256 amount ) public view { bytes32 leaf = keccak256(abi.encode(addr, amount)); require(MerkleProof.verify(proof, root, leaf), "Invalid proof");
}
function verify( bytes32[] memory proof, address addr ) public view { bytes32 leaf = keccak256(abi.encodePacked(addr)); require(MerkleProof.verify(proof, root, leaf), "Invalid proof");
} } ```
This project is licensed under the MIT License. See the LICENSE file for details.