/*
    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 .
*/
#pragma once
#include "ton/ton-types.h"
#include "td/actor/actor.h"
#include "interfaces/validator-manager.h"
namespace ton::validator {
class CandidatesBuffer : public td::actor::Actor {
 public:
  explicit CandidatesBuffer(td::actor::ActorId manager) : manager_(std::move(manager)) {
  }
  void start_up() override;
  void alarm() override;
  void add_new_candidate(BlockIdExt id, PublicKey source, FileHash collated_data_file_hash);
  void get_block_data(BlockIdExt id, td::Promise> promise);
  void get_block_state(BlockIdExt id, td::Promise> promise);
 private:
  td::actor::ActorId manager_;
  struct Candidate {
    PublicKey source_;
    FileHash collated_data_file_hash_;
    td::Timestamp ttl_;
    td::Ref data_;
    std::vector>> data_waiters_;
    bool data_requested_{false};
    td::Ref state_;
    std::vector>> state_waiters_;
    bool state_requested_{false};
  };
  std::map candidates_;
  void got_block_candidate(BlockIdExt id, td::Result R);
  void get_block_state_cont(BlockIdExt id, td::Ref data);
  void get_block_state_cont2(td::Ref block, std::vector prev,
                             std::vector> prev_states);
  void finish_get_block_data(BlockIdExt id, td::Result> res);
  void finish_get_block_state(BlockIdExt id, td::Result> res);
};
}  // namespace ton::validator