// // Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2022 // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) // #pragma once #include "td/actor/actor.h" #include "td/utils/common.h" #include "td/utils/FlatHashMap.h" #include "td/utils/Promise.h" #include "td/utils/Slice.h" #include "td/utils/Status.h" #include namespace td { // combines identical queries into one request class QueryCombiner final : public Actor { public: QueryCombiner(Slice name, double min_delay); void add_query(int64 query_id, Promise> &&send_query, Promise &&promise); private: struct QueryInfo { vector> promises; bool is_sent = false; Promise> send_query; }; int32 query_count_ = 0; double next_query_time_; double min_delay_; std::queue delayed_queries_; FlatHashMap queries_; void do_send_query(int64 query_id, QueryInfo &query); void on_get_query_result(int64 query_id, Result &&result); void loop() final; }; } // namespace td