/*
    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-2020 Telegram Systems LLP
*/
#pragma once
#include 
#include 
#include "ton/ton-types.h"
#include "td/actor/actor.h"
#include "adnl/adnl.h"
#include "rldp/rldp.h"
#include "rldp2/rldp.h"
#include "dht/dht.h"
#include "overlay/overlays.h"
#include "validator/validator.h"
#include "adnl/adnl-ext-client.h"
namespace ton {
namespace validator {
namespace fullnode {
constexpr int VERBOSITY_NAME(FULL_NODE_WARNING) = verbosity_WARNING;
constexpr int VERBOSITY_NAME(FULL_NODE_NOTICE) = verbosity_INFO;
constexpr int VERBOSITY_NAME(FULL_NODE_INFO) = verbosity_DEBUG;
constexpr int VERBOSITY_NAME(FULL_NODE_DEBUG) = verbosity_DEBUG;
constexpr int VERBOSITY_NAME(FULL_NODE_EXTRA_DEBUG) = verbosity_DEBUG + 1;
struct FullNodeConfig {
  FullNodeConfig() = default;
  FullNodeConfig(const tl_object_ptr& obj);
  tl_object_ptr tl() const;
  bool operator==(const FullNodeConfig& rhs) const;
  bool operator!=(const FullNodeConfig& rhs) const;
  bool ext_messages_broadcast_disabled_ = false;
};
struct CustomOverlayParams {
  std::string name_;
  std::vector nodes_;
  std::map msg_senders_;
  std::set block_senders_;
  std::vector sender_shards_;
  bool send_shard(const ShardIdFull& shard) const;
  static CustomOverlayParams fetch(const ton_api::engine_validator_customOverlay& f);
};
class FullNode : public td::actor::Actor {
 public:
  virtual ~FullNode() = default;
  virtual void update_dht_node(td::actor::ActorId dht) = 0;
  virtual void add_permanent_key(PublicKeyHash key, td::Promise promise) = 0;
  virtual void del_permanent_key(PublicKeyHash key, td::Promise promise) = 0;
  virtual void sign_shard_overlay_certificate(ShardIdFull shard_id, PublicKeyHash signed_key,
                                              td::uint32 expiry_at, td::uint32 max_size,
                                              td::Promise promise) = 0;
  virtual void import_shard_overlay_certificate(ShardIdFull shard_id, PublicKeyHash signed_key,
                                                std::shared_ptr cert,
                                                td::Promise promise) = 0;
  virtual void update_adnl_id(adnl::AdnlNodeIdShort adnl_id, td::Promise promise) = 0;
  virtual void set_config(FullNodeConfig config) = 0;
  virtual void add_custom_overlay(CustomOverlayParams params, td::Promise promise) = 0;
  virtual void del_custom_overlay(std::string name, td::Promise promise) = 0;
  virtual void process_block_broadcast(BlockBroadcast broadcast) = 0;
  virtual void process_block_candidate_broadcast(BlockIdExt block_id, CatchainSeqno cc_seqno,
                                                 td::uint32 validator_set_hash, td::BufferSlice data) = 0;
  virtual void get_out_msg_queue_query_token(td::Promise> promise) = 0;
  virtual void set_validator_telemetry_filename(std::string value) = 0;
  static constexpr td::uint32 max_block_size() {
    return 4 << 20;
  }
  static constexpr td::uint32 max_proof_size() {
    return 4 << 20;
  }
  static constexpr td::uint64 max_state_size() {
    return 4ull << 30;
  }
  enum { broadcast_mode_public = 1, broadcast_mode_private_block = 2, broadcast_mode_custom = 4 };
  static td::actor::ActorOwn create(
      ton::PublicKeyHash local_id, adnl::AdnlNodeIdShort adnl_id, FileHash zero_state_file_hash, FullNodeConfig config,
      td::actor::ActorId keyring, td::actor::ActorId adnl,
      td::actor::ActorId rldp, td::actor::ActorId rldp2, td::actor::ActorId dht,
      td::actor::ActorId overlays, td::actor::ActorId validator_manager,
      td::actor::ActorId client, std::string db_root, td::Promise started_promise);
};
}  // namespace fullnode
}  // namespace validator
}  // namespace ton