/* This file is part of TON Blockchain Library. TON Blockchain Library is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 2 of the License, or (at your option) any later version. TON Blockchain Library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with TON Blockchain Library. If not, see . Copyright 2017-2019 Telegram Systems LLP */ #pragma once #include "td/actor/actor.h" #include "crypto/vm/db/DynamicBagOfCellsDb.h" #include "crypto/vm/db/CellStorage.h" #include "td/db/KeyValue.h" #include "ton/ton-types.h" #include "interfaces/block-handle.h" #include "auto/tl/ton_api.h" namespace ton { namespace validator { class RootDb; class CellDb; class CellDbIn : public td::actor::Actor { public: using KeyHash = td::Bits256; void load_cell(RootHash hash, td::Promise> promise); void store_cell(BlockIdExt block_id, td::Ref cell, td::Promise> promise); CellDbIn(td::actor::ActorId root_db, td::actor::ActorId parent, std::string path); void start_up() override; void alarm() override; private: struct DbEntry { BlockIdExt block_id; KeyHash prev; KeyHash next; RootHash root_hash; DbEntry(tl_object_ptr entry); DbEntry() { } DbEntry(BlockIdExt block_id, KeyHash prev, KeyHash next, RootHash root_hash) : block_id(block_id), prev(prev), next(next), root_hash(root_hash) { } td::BufferSlice release(); bool is_empty() const { return !block_id.is_valid(); } }; td::Result get_block(KeyHash key); void set_block(KeyHash key, DbEntry e); static std::string get_key(KeyHash key); static KeyHash get_key_hash(BlockIdExt block_id); static BlockIdExt get_empty_key(); KeyHash get_empty_key_hash(); void gc(); void gc_cont(BlockHandle handle); void gc_cont2(BlockHandle handle); void skip_gc(); td::actor::ActorId root_db_; td::actor::ActorId parent_; std::string path_; std::unique_ptr boc_; std::shared_ptr cell_db_; KeyHash last_gc_; }; class CellDb : public td::actor::Actor { public: void load_cell(RootHash hash, td::Promise> promise); void store_cell(BlockIdExt block_id, td::Ref cell, td::Promise> promise); void update_snapshot(std::unique_ptr snapshot) { started_ = true; boc_->set_loader(std::make_unique(std::move(snapshot))).ensure(); } CellDb(td::actor::ActorId root_db, std::string path) : root_db_(root_db), path_(path) { } void start_up() override; private: td::actor::ActorId root_db_; std::string path_; td::actor::ActorOwn cell_db_; std::unique_ptr boc_; bool started_ = false; }; } // namespace validator } // namespace ton