8 releases
0.4.0 | Jul 13, 2023 |
---|---|
0.3.4 | Mar 1, 2023 |
0.3.3 | Feb 22, 2023 |
0.3.2 | Nov 10, 2022 |
0.1.0 | Jun 4, 2021 |
#28 in #dfinity
15,806 downloads per month
Used in 8 crates
(5 directly)
55KB
1.5K
SLoC
Certified Map
This package provides a map that can be used by Internet Computer canisters to implement certified queries.
Features
-
Incremental certification. The canister can store thousands of entries while keeping the cost of certification relatively low.
-
Proofs of absence. If the requested key is not present in the map, the returned tree structure allows the caller to verify that fact.
-
Relatively small merkle proofs. The size overhead of the certificate is O(log N), where N is the number of entries in the map.
Implementation Details
The canister uses an augmented Red-Black binary search tree to store the entries. Each node of the search tree is annotated with the root hash of the hash tree built from the subtree rooted at this node. Each time the tree is rotated or modified, the corresponding hashes are recomputed in O(1) time.
Dependencies
~0.7–1MB
~26K SLoC