/* 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 */ #include "validator/fabric.h" #include "block.hpp" #include "external-message.hpp" #include "proof.hpp" #include "signature-set.hpp" #include "shard.hpp" #include "accept-block.hpp" #include "fake-accept-block.hpp" #include "check-proof.hpp" #include "collate-query.hpp" #include "validate-query.hpp" #include "top-shard-description.hpp" #include "validator/db/rootdb.hpp" #include "validator/block-handle.hpp" #include "validator/apply-block.hpp" #include "td/utils/Random.h" namespace ton { namespace validator { td::actor::ActorOwn create_db_actor(td::actor::ActorId manager, std::string db_root_) { return td::actor::create_actor("db", manager, db_root_); } td::Result> create_block(BlockIdExt block_id, td::BufferSlice data) { return td::Ref{true, block_id, std::move(data)}; } td::Result> create_block(ReceivedBlock data) { return td::Ref{true, data.id, std::move(data.data)}; } td::Result> create_proof(BlockIdExt masterchain_block_id, td::BufferSlice proof) { return td::Ref{true, masterchain_block_id, std::move(proof)}; } td::Result> create_proof_link(td::BufferSlice proof) { return td::Ref{true, std::move(proof)}; } td::Result> create_signature_set(td::BufferSlice sig_set) { return dummy0::BlockSignatureSetImpl::fetch(std::move(sig_set)); } td::Result> create_shard_state(BlockIdExt block_id, td::BufferSlice data) { return dummy0::ShardStateImpl::fetch(block_id, std::move(data)); } td::Result> create_shard_state(BlockIdExt block_id, td::Ref root_cell) { UNREACHABLE(); } td::Result create_block_handle(td::BufferSlice data) { return ton::validator::BlockHandleImpl::create(std::move(data)); } BlockHandle create_empty_block_handle(BlockIdExt id) { return ton::validator::BlockHandleImpl::create_empty(id); } //td::Ref create_mc_shard(ShardIdFull id, ZeroStateIdExt zero_top_block) { // return td::Ref{true, zero_top_block}; //} td::Ref create_signature_set(std::vector sig_set) { return td::Ref{true, std::move(sig_set)}; } td::Result> create_ext_message(td::BufferSlice data) { TRY_RESULT(B, fetch_tl_object(std::move(data), true)); return td::Ref{true, std::move(B)}; } void run_accept_block_query(BlockIdExt id, td::Ref data, std::vector prev, td::Ref validator_set, td::Ref signatures, bool send_broadcast, td::actor::ActorId manager, td::Promise promise) { td::actor::create_actor( "accept", id, std::move(data), prev, validator_set->get_catchain_seqno(), validator_set->get_validator_set_hash(), std::move(signatures), send_broadcast, manager, std::move(promise)) .release(); } void run_fake_accept_block_query(BlockIdExt id, td::Ref data, std::vector prev, td::Ref validator_set, td::actor::ActorId manager, td::Promise promise) { td::actor::create_actor("fakeaccept", id, std::move(data), std::move(prev), 0, 0, td::Ref{}, std::move(manager), std::move(promise)) .release(); } void run_apply_block_query(BlockIdExt id, td::Ref block, td::actor::ActorId manager, td::Timestamp timeout, td::Promise promise) { td::actor::create_actor("apply", id, std::move(block), manager, timeout, std::move(promise)).release(); } void run_check_proof_query(BlockIdExt id, td::Ref proof, td::actor::ActorId manager, td::Timestamp timeout, td::Promise promise) { td::actor::create_actor("checkproof", id, std::move(proof), manager, timeout, std::move(promise)) .release(); } void run_check_proof_link_query(BlockIdExt id, td::Ref proof, td::actor::ActorId manager, td::Timestamp timeout, td::Promise promise) { td::actor::create_actor("checkprooflink", id, std::move(proof), manager, timeout, std::move(promise)) .release(); } void run_validate_query(ShardIdFull shard, UnixTime min_ts, BlockIdExt min_masterchain_block_id, std::vector prev, BlockCandidate candidate, td::Ref validator_set, td::actor::ActorId manager, td::Timestamp timeout, td::Promise promise) { td::actor::create_actor( "validateblock", shard, min_ts, min_masterchain_block_id, std::move(prev), std::move(candidate), validator_set->get_catchain_seqno(), validator_set->get_validator_set_hash(), manager, timeout, std::move(promise)) .release(); } void run_collate_query(ShardIdFull shard, td::uint32 min_ts, const BlockIdExt& min_masterchain_block_id, std::vector prev, td::Ref validator_set, td::actor::ActorId manager, td::Timestamp timeout, td::Promise promise) { td::actor::create_actor("collator", shard, min_ts, min_masterchain_block_id, std::move(prev), std::move(validator_set), manager, timeout, std::move(promise)) .release(); } void run_liteserver_query(td::BufferSlice data, td::actor::ActorId manager, td::Promise promise) { LOG(ERROR) << "answering"; promise.set_value(serialize_tl_object(create_tl_object(td::Random::fast_uint32()), true)); } void run_validate_shard_block_description(td::BufferSlice data, BlockHandle masterchain_block, td::Ref masterchain_state, td::actor::ActorId manager, td::Timestamp timeout, td::Promise> promise, bool is_fake) { td::actor::create_actor( "topshardfetch", std::move(data), std::move(masterchain_block), std::move(masterchain_state), manager, timeout, std::move(promise)) .release(); } } // namespace validator } // namespace ton