29#include <unordered_map>
62 const std::string& data_dir,
64 const std::unordered_map<MerkleTreeId, uint32_t>& tree_heights,
65 const std::unordered_map<MerkleTreeId, index_t>& tree_prefill,
66 uint32_t initial_header_generator_point);
69 const std::string& data_dir,
71 const std::unordered_map<MerkleTreeId, uint32_t>& tree_heights,
72 const std::unordered_map<MerkleTreeId, index_t>& tree_prefill,
73 uint32_t initial_header_generator_point);
76 const std::string& data_dir,
78 const std::unordered_map<MerkleTreeId, uint32_t>& tree_heights,
79 const std::unordered_map<MerkleTreeId, index_t>& tree_prefill,
81 uint32_t initial_header_generator_point);
84 const std::string& data_dir,
86 const std::unordered_map<MerkleTreeId, uint32_t>& tree_heights,
87 const std::unordered_map<MerkleTreeId, index_t>& tree_prefill,
89 uint32_t initial_header_generator_point);
97 void copy_stores(
const std::string& dstPath,
bool compact)
const;
137 const std::vector<index_t>& leafIndices,
149 template <
typename T>
163 template <
typename T>
177 const bb::fr& leaf_key)
const;
188 template <
typename T>
193 index_t start_index = 0)
const;
203 template <
typename T>
216 template <
typename T>
227 template <
typename T>
230 uint32_t subtree_depth,
241 template <
typename T>
262 const bb::fr& block_header_hash,
284 const bb::fr& block_header_hash,
303 std::unordered_map<uint64_t, Fork::SharedPtr>
_forks;
311 uint64_t maxReaders);
337 bool initial_state =
false);
346 template <
typename TreeType>
351 std::string& message,
354 template <
typename TreeType>
359 std::string& message,
363 template <
typename TreeType>
368 std::string& message,
373template <
typename TreeType>
378 std::string& message,
382 bool expected =
true;
383 if (!response.
success && success.compare_exchange_strong(expected,
false)) {
384 message = response.message;
392template <
typename TreeType>
397 std::string& message,
402 bool expected =
true;
403 if (!response.
success && success.compare_exchange_strong(expected,
false)) {
404 message = response.message;
412template <
typename TreeType>
417 std::string& message,
422 bool expected =
true;
423 if (!response.
success && success.compare_exchange_strong(expected,
false)) {
424 message = response.message;
459 throw std::runtime_error(
"Failed to find indexed leaf: " + local.
message);
462 return local.
inner.indexed_leaf;
465 throw std::runtime_error(
"Invalid tree type");
473 using namespace crypto::merkle_tree;
479 std::string error_msg;
484 if (!response.success || !response.inner.leaf.has_value()) {
486 error_msg = response.message;
488 leaf = response.inner.leaf;
505 if (!response.success || !response.inner.indexed_leaf.has_value()) {
507 error_msg = response.message;
509 leaf = response.inner.indexed_leaf.value().leaf;
533 using namespace crypto::merkle_tree;
546 wrapper.tree->find_leaf_indices_from(
549 wrapper.tree->find_leaf_indices_from(leaves, start_index, rev.
includeUncommitted, callback);
561 wrapper.tree->find_leaf_indices_from(leaves, start_index, rev.
includeUncommitted, callback);
567 if (!local.
success || local.
inner.leaf_indices.size() != leaves.size()) {
568 throw std::runtime_error(local.
message);
580 using namespace crypto::merkle_tree;
612 if (!local.
success || local.
inner.leaf_paths.size() != leaves.size()) {
613 throw std::runtime_error(local.
message);
621 using namespace crypto::merkle_tree;
628 std::string error_msg;
632 auto callback = [&](
const auto& resp) {
635 error_msg = resp.message;
639 wrapper.tree->add_values(leaves, callback);
644 typename Tree::AddCompletionCallback callback = [&](
const auto& resp) {
647 error_msg = resp.message;
651 wrapper.tree->add_or_update_values(leaves, 0, callback);
657 throw std::runtime_error(error_msg);
664 uint32_t subtree_depth,
667 using namespace crypto::merkle_tree;
677 std::string error_msg;
679 wrapper.tree->add_or_update_values(
681 if (response.success) {
687 error_msg = response.message;
696 throw std::runtime_error(error_msg);
707 using namespace crypto::merkle_tree;
717 std::string error_msg;
719 wrapper.tree->add_or_update_values_sequentially(
721 if (response.success) {
726 error_msg = response.message;
735 throw std::runtime_error(error_msg);
bb::bbapi::CommandResponse responses
void find_leaf_indices_from(const std::vector< typename Store::LeafType > &leaves, const index_t &start_index, bool includeUncommitted, const FindLeafCallback &on_completion) const
Returns the index of the provided leaf in the tree only if it exists after the index value provided.
void find_leaf_sibling_paths(const std::vector< typename Store::LeafType > &leaves, bool includeUncommitted, const FindSiblingPathCallback &on_completion) const
Returns the sibling paths for the provided leaves in the tree.
Serves as a key-value node store for merkle trees. Caches all changes in memory before persisting the...
Implements a parallelized batch insertion indexed tree Accepts template argument of the type of store...
Used in parallel insertions in the the IndexedTree. Workers signal to other following workes as they ...
void signal_level(uint32_t level=0)
Signals that the given level has been passed.
void signal_decrement(uint32_t delta=1)
void wait_for_level(uint32_t level=0)
Causes the thread to wait until the required level has been signalled.
Holds the Merkle trees responsible for storing the state of the Aztec protocol.
WorldStateStatusFull remove_historical_blocks(const block_number_t &toBlockNumber)
std::shared_ptr< bb::ThreadPool > _workers
void remove_forks_for_block(const block_number_t &blockNumber)
BatchInsertionResult< T > batch_insert_indexed_leaves(MerkleTreeId tree_id, const std::vector< T > &leaves, uint32_t subtree_depth, Fork::Id fork_id=CANONICAL_FORK_ID)
Batch inserts a set of leaves into an indexed Merkle Tree.
bool unwind_block(const block_number_t &blockNumber, WorldStateStatusFull &status)
static void get_status_summary_from_meta_responses(WorldStateStatusSummary &status, std::array< TreeMeta, NUM_TREES > &metaResponses)
void commit_tree(TreeDBStats &dbStats, Signal &signal, TreeType &tree, std::atomic_bool &success, std::string &message, TreeMeta &meta)
TreeStateReference get_tree_snapshot(MerkleTreeId id)
void append_leaves(MerkleTreeId tree_id, const std::vector< T > &leaves, Fork::Id fork_id=CANONICAL_FORK_ID)
Appends a set of leaves to an existing Merkle Tree.
StateReference get_initial_state_reference() const
Gets the initial state reference for all the trees in the world state.
void find_sibling_paths(const WorldStateRevision &revision, MerkleTreeId tree_id, const std::vector< T > &leaves, std::vector< std::optional< SiblingPathAndIndex > > &paths) const
Finds the sibling paths of leaves in a tree.
std::optional< crypto::merkle_tree::IndexedLeaf< T > > get_indexed_leaf(const WorldStateRevision &revision, MerkleTreeId tree_id, index_t leaf_index) const
Get the leaf preimage object.
void revert_checkpoint(const uint64_t &forkId)
WorldStateStatusFull attempt_tree_resync()
crypto::merkle_tree::TreeMetaResponse get_tree_info(const WorldStateRevision &revision, MerkleTreeId tree_id) const
Get tree metadata for a particular tree.
static void populate_status_summary(WorldStateStatusFull &status)
void unwind_tree(TreeDBStats &dbStats, Signal &signal, TreeType &tree, std::atomic_bool &success, std::string &message, TreeMeta &meta, const block_number_t &blockNumber)
std::unordered_map< uint64_t, Fork::SharedPtr > _forks
void create_canonical_fork(const std::string &dataDir, const std::unordered_map< MerkleTreeId, uint64_t > &dbSize, const std::vector< PublicDataLeafValue > &prefilled_public_data, uint64_t maxReaders)
std::pair< bool, std::string > commit(WorldStateStatusFull &status)
Commits the current state of the world state.
void remove_historic_block_for_tree(TreeDBStats &dbStats, Signal &signal, TreeType &tree, std::atomic_bool &success, std::string &message, TreeMeta &meta, const block_number_t &blockNumber)
SequentialInsertionResult< T > insert_indexed_leaves(MerkleTreeId tree_id, const std::vector< T > &leaves, Fork::Id fork_id=CANONICAL_FORK_ID)
Inserts a set of leaves sequentially into an indexed Merkle Tree.
void get_block_numbers_for_leaf_indices(const WorldStateRevision &revision, MerkleTreeId tree_id, const std::vector< index_t > &leafIndices, std::vector< std::optional< block_number_t > > &blockNumbers) const
StateReference get_state_reference(const WorldStateRevision &revision) const
Gets the state reference for all the trees in the world state.
WorldStateStatusFull unwind_blocks(const block_number_t &toBlockNumber)
uint32_t _initial_header_generator_point
bool is_archive_tip(const WorldStateRevision &revision, const bb::fr &block_header_hash) const
static bool determine_if_synched(std::array< TreeMeta, NUM_TREES > &metaResponses)
void update_public_data(const crypto::merkle_tree::PublicDataLeafValue &new_value, Fork::Id fork_id=CANONICAL_FORK_ID)
Updates a leaf in an existing Merkle Tree.
void commit_checkpoint(const uint64_t &forkId)
Fork::SharedPtr create_new_fork(const block_number_t &blockNumber)
void get_status_summary(WorldStateStatusSummary &status) const
void revert_all_checkpoints(const uint64_t &forkId)
void rollback()
Rolls back any uncommitted changes made to the world state.
void commit_all_checkpoints(const uint64_t &forkId)
WorldStateStatusFull sync_block(const StateReference &block_state_ref, const bb::fr &block_header_hash, const std::vector< bb::fr > ¬es, const std::vector< bb::fr > &l1_to_l2_messages, const std::vector< crypto::merkle_tree::NullifierLeafValue > &nullifiers, const std::vector< crypto::merkle_tree::PublicDataLeafValue > &public_writes)
WorldStateStatusSummary set_finalized_blocks(const block_number_t &toBlockNumber)
static bb::fr compute_initial_block_header_hash(const StateReference &initial_state_ref, uint32_t generator_point)
std::unordered_map< MerkleTreeId, index_t > _initial_tree_size
void delete_fork(const uint64_t &forkId)
bool remove_historical_block(const block_number_t &blockNumber, WorldStateStatusFull &status)
std::unordered_map< MerkleTreeId, uint32_t > _tree_heights
uint64_t create_fork(const std::optional< block_number_t > &blockNumber)
crypto::merkle_tree::fr_sibling_path get_sibling_path(const WorldStateRevision &revision, MerkleTreeId tree_id, index_t leaf_index) const
Get the sibling path object for a leaf in a tree.
void validate_trees_are_equally_synched()
void find_leaf_indices(const WorldStateRevision &revision, MerkleTreeId tree_id, const std::vector< T > &leaves, std::vector< std::optional< index_t > > &indices, index_t start_index=0) const
Finds the index of a leaf in a tree.
std::optional< T > get_leaf(const WorldStateRevision &revision, MerkleTreeId tree_id, index_t leaf_index) const
Gets the value of a leaf in a tree.
void checkpoint(const uint64_t &forkId)
static bool block_state_matches_world_state(const StateReference &block_state_ref, const StateReference &tree_state_ref)
bool is_same_state_reference(const WorldStateRevision &revision, const StateReference &state_ref) const
crypto::merkle_tree::GetLowIndexedLeafResponse find_low_leaf_index(const WorldStateRevision &revision, MerkleTreeId tree_id, const bb::fr &leaf_key) const
Finds the leaf that would have its nextIdx/nextValue fields modified if the target leaf were to be in...
void copy_stores(const std::string &dstPath, bool compact) const
Copies all underlying LMDB stores to the target directory while acquiring a write lock.
void update_archive(const StateReference &block_state_ref, const bb::fr &block_header_hash, Fork::Id fork_id=CANONICAL_FORK_ID)
Updates the archive tree with a new block.
bool set_finalized_block(const block_number_t &blockNumber)
WorldStateStores::Ptr _persistentStores
Fork::SharedPtr retrieve_fork(const uint64_t &forkId) const
void get_all_tree_info(const WorldStateRevision &revision, std::array< TreeMeta, NUM_TREES > &responses) const
std::vector< fr > fr_sibling_path
std::variant< TreeWithStore< FrTree >, TreeWithStore< NullifierTree >, TreeWithStore< PublicDataTree > > Tree
const uint64_t DEFAULT_MIN_NUMBER_OF_READERS
std::pair< bb::fr, bb::crypto::merkle_tree::index_t > TreeStateReference
const uint64_t CANONICAL_FORK_ID
std::unordered_map< MerkleTreeId, TreeStateReference > StateReference
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
std::vector< std::pair< LeafValueType, size_t > > sorted_leaves
std::vector< crypto::merkle_tree::LeafUpdateWitnessData< LeafValueType > > low_leaf_witness_data
MSGPACK_FIELDS(low_leaf_witness_data, sorted_leaves, subtree_path)
crypto::merkle_tree::fr_sibling_path subtree_path
std::shared_ptr< Fork > SharedPtr
MSGPACK_FIELDS(low_leaf_witness_data, insertion_witness_data)
std::vector< crypto::merkle_tree::LeafUpdateWitnessData< LeafValueType > > low_leaf_witness_data
std::vector< crypto::merkle_tree::LeafUpdateWitnessData< LeafValueType > > insertion_witness_data
block_number_t blockNumber
std::shared_ptr< WorldStateStores > Ptr