tdlight/td/telegram/net/NetQueryDispatcher.h
levlam 2c4678a1e3 Send NetQuery to callback when closing.
GitOrigin-RevId: 6e564fd9401ae4352471d2938058d02e54c73f05
2018-04-19 20:21:26 +03:00

93 lines
2.6 KiB
C++

//
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
//
// 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/telegram/net/AuthDataShared.h"
#include "td/telegram/net/NetQuery.h"
#include "td/actor/actor.h"
#include "td/utils/common.h"
#include "td/utils/ScopeGuard.h"
#include "td/utils/Status.h"
#include <array>
#include <atomic>
#include <functional>
#include <memory>
#include <mutex>
namespace td {
class NetQueryDelayer;
class DataCenter;
class DcAuthManager;
class SessionMultiProxy;
class PublicRsaKeyShared;
class PublicRsaKeyWatchdog;
} // namespace td
namespace td {
// Not just dispatcher.
class NetQueryDispatcher {
public:
explicit NetQueryDispatcher(std::function<ActorShared<>()> create_reference);
NetQueryDispatcher();
NetQueryDispatcher(const NetQueryDispatcher &) = delete;
NetQueryDispatcher &operator=(const NetQueryDispatcher &) = delete;
NetQueryDispatcher(NetQueryDispatcher &&) = delete;
NetQueryDispatcher &operator=(NetQueryDispatcher &&) = delete;
~NetQueryDispatcher();
void dispatch(NetQueryPtr net_query);
void dispatch_with_callback(NetQueryPtr net_query, ActorShared<NetQueryCallback> callback);
void stop();
void update_session_count();
void update_use_pfs();
void update_valid_dc(DcId dc_id);
DcId main_dc_id() {
return DcId::internal(main_dc_id_.load());
}
private:
std::atomic<bool> stop_flag_{false};
ActorOwn<NetQueryDelayer> delayer_;
ActorOwn<DcAuthManager> dc_auth_manager_;
struct Dc {
std::atomic<bool> is_valid_{false};
std::atomic<bool> is_inited_{false}; // TODO: cache in scheduler local storage :D
ActorOwn<SessionMultiProxy> main_session_;
ActorOwn<SessionMultiProxy> download_session_;
ActorOwn<SessionMultiProxy> download_small_session_;
ActorOwn<SessionMultiProxy> upload_session_;
};
static constexpr size_t MAX_DC_COUNT = 1000;
std::array<Dc, MAX_DC_COUNT> dcs_;
#if TD_EMSCRIPTEN // FIXME
std::atomic<int32> main_dc_id_{2};
#else
std::atomic<int32> main_dc_id_{1};
#endif
std::shared_ptr<PublicRsaKeyShared> common_public_rsa_key_;
ActorOwn<PublicRsaKeyWatchdog> public_rsa_key_watchdog_;
std::mutex main_dc_id_mutex_;
std::shared_ptr<Guard> td_guard_;
Status wait_dc_init(DcId dc_id, bool force);
bool is_dc_inited(int32 raw_dc_id);
static int32 get_session_count();
static bool get_use_pfs();
static void complete_net_query(NetQueryPtr net_query);
void try_fix_migrate(NetQueryPtr &net_query);
};
} // namespace td