#mpt #starknet #stark-net #key-value #trie #tree-root #merkle-patricia-trie

sn-merkle-trie

Minimal starknet merkle patricia trie implementation

1 unstable release

0.1.0 Sep 11, 2024

#909 in Algorithms

Download history 155/week @ 2024-09-08 44/week @ 2024-09-15 15/week @ 2024-09-22 41/week @ 2024-09-29 7/week @ 2024-10-06 13/week @ 2024-10-13 1/week @ 2024-10-20 39/week @ 2024-10-27 19/week @ 2024-11-03 14/week @ 2024-11-10 38/week @ 2024-11-17 19/week @ 2024-11-24 27/week @ 2024-12-01 14/week @ 2024-12-08 6/week @ 2024-12-15

67 downloads per month
Used in 2 crates (via sn-trie-proofs)

Custom license

45KB
844 lines

sn-merkle-trie

Crates.io Documentation License: MIT

Minimal implelementation of a StarkNet MPT.

Heavily rely on pathfinder's merkle tree implementation, but target to make it easy port as external dependency + sync primitives with type-rs.

Usage

  • tx trie

fn main() {
    // transaction tree either pedersen or poseidon
    let mut tree = TransactionMerkleTree::Pedersen(MerkleTree::default());
    let key1 = from_felt_to_bits(&Felt::from_hex_unchecked("0x0")); // 0b01
    let value_1 = Felt::from_hex_unchecked("0x2");
    // insert key and value
    tree.set(key1.clone(), value_1).unwrap();
    // commit tree to get root
    let (root, root_idx) = tree.commit().unwrap();
    // get proof of inclusion/non-inclusion
    let proof = tree.get_proof(root_idx, key1.clone()).unwrap().unwrap();
    // verify return membership proof
    let mem = tree.verify_proof(root, &key1, value_1, &proof);
}

Dependencies

~4.5MB
~86K SLoC