A lot more minor improvements.

This commit is contained in:
levlam 2021-10-19 18:11:16 +03:00
parent 44a186c7c1
commit db7aa28bdf
114 changed files with 1025 additions and 967 deletions

View File

@ -105,7 +105,8 @@ BENCH(NewObj, "new struct, then delete") {
#if !TD_THREAD_UNSUPPORTED #if !TD_THREAD_UNSUPPORTED
BENCH(ThreadNew, "new struct, then delete in 2 threads") { BENCH(ThreadNew, "new struct, then delete in 2 threads") {
NewObjBench a, b; NewObjBench a;
NewObjBench b;
td::thread ta([&] { a.run(n / 2); }); td::thread ta([&] { a.run(n / 2); });
td::thread tb([&] { b.run(n - n / 2); }); td::thread tb([&] { b.run(n - n / 2); });
ta.join(); ta.join();

View File

@ -162,7 +162,7 @@ void AuthManager::check_bot_token(uint64 query_id, string bot_token) {
} }
on_new_query(query_id); on_new_query(query_id);
bot_token_ = bot_token; bot_token_ = std::move(bot_token);
was_check_bot_token_ = true; was_check_bot_token_ = true;
start_net_query(NetQueryType::BotAuthentication, start_net_query(NetQueryType::BotAuthentication,
G()->net_query_creator().create_unauth( G()->net_query_creator().create_unauth(
@ -258,8 +258,8 @@ void AuthManager::set_phone_number(uint64 query_id, string phone_number,
on_new_query(query_id); on_new_query(query_id);
start_net_query(NetQueryType::SendCode, G()->net_query_creator().create_unauth( start_net_query(NetQueryType::SendCode, G()->net_query_creator().create_unauth(send_code_helper_.send_code(
send_code_helper_.send_code(phone_number, settings, api_id_, api_hash_))); std::move(phone_number), settings, api_id_, api_hash_)));
} }
void AuthManager::resend_authentication_code(uint64 query_id) { void AuthManager::resend_authentication_code(uint64 query_id) {
@ -425,8 +425,8 @@ void AuthManager::on_query_error(Status status) {
on_query_error(id, std::move(status)); on_query_error(id, std::move(status));
} }
void AuthManager::on_query_error(uint64 id, Status status) { void AuthManager::on_query_error(uint64 query_id, Status status) {
send_closure(G()->td(), &Td::send_error, id, std::move(status)); send_closure(G()->td(), &Td::send_error, query_id, std::move(status));
} }
void AuthManager::on_query_ok() { void AuthManager::on_query_ok() {

View File

@ -126,15 +126,16 @@ class AuthManager final : public NetActor {
TermsOfService terms_of_service_; TermsOfService terms_of_service_;
DbState() = default; DbState() = default;
static DbState wait_code(int32 api_id, string api_hash, SendCodeHelper send_code_helper) { static DbState wait_code(int32 api_id, string api_hash, SendCodeHelper send_code_helper) {
DbState state(State::WaitCode, api_id, api_hash); DbState state(State::WaitCode, api_id, std::move(api_hash));
state.send_code_helper_ = std::move(send_code_helper); state.send_code_helper_ = std::move(send_code_helper);
return state; return state;
} }
static DbState wait_qr_code_confirmation(int32 api_id, string api_hash, vector<UserId> other_user_ids, static DbState wait_qr_code_confirmation(int32 api_id, string api_hash, vector<UserId> other_user_ids,
string login_token, double login_token_expires_at) { string login_token, double login_token_expires_at) {
DbState state(State::WaitQrCodeConfirmation, api_id, api_hash); DbState state(State::WaitQrCodeConfirmation, api_id, std::move(api_hash));
state.other_user_ids_ = std::move(other_user_ids); state.other_user_ids_ = std::move(other_user_ids);
state.login_token_ = std::move(login_token); state.login_token_ = std::move(login_token);
state.login_token_expires_at_ = login_token_expires_at; state.login_token_expires_at_ = login_token_expires_at;
@ -142,14 +143,14 @@ class AuthManager final : public NetActor {
} }
static DbState wait_password(int32 api_id, string api_hash, WaitPasswordState wait_password_state) { static DbState wait_password(int32 api_id, string api_hash, WaitPasswordState wait_password_state) {
DbState state(State::WaitPassword, api_id, api_hash); DbState state(State::WaitPassword, api_id, std::move(api_hash));
state.wait_password_state_ = std::move(wait_password_state); state.wait_password_state_ = std::move(wait_password_state);
return state; return state;
} }
static DbState wait_registration(int32 api_id, string api_hash, SendCodeHelper send_code_helper, static DbState wait_registration(int32 api_id, string api_hash, SendCodeHelper send_code_helper,
TermsOfService terms_of_service) { TermsOfService terms_of_service) {
DbState state(State::WaitRegistration, api_id, api_hash); DbState state(State::WaitRegistration, api_id, std::move(api_hash));
state.send_code_helper_ = std::move(send_code_helper); state.send_code_helper_ = std::move(send_code_helper);
state.terms_of_service_ = std::move(terms_of_service); state.terms_of_service_ = std::move(terms_of_service);
return state; return state;
@ -161,8 +162,8 @@ class AuthManager final : public NetActor {
void parse(ParserT &parser); void parse(ParserT &parser);
private: private:
DbState(State state, int32 api_id, string api_hash) DbState(State state, int32 api_id, string &&api_hash)
: state_(state), api_id_(api_id), api_hash_(api_hash), state_timestamp_(Timestamp::now()) { : state_(state), api_id_(api_id), api_hash_(std::move(api_hash)), state_timestamp_(Timestamp::now()) {
} }
}; };
@ -216,7 +217,6 @@ class AuthManager final : public NetActor {
void on_new_query(uint64 query_id); void on_new_query(uint64 query_id);
void on_query_error(Status status); void on_query_error(Status status);
void on_query_error(uint64 id, Status status);
void on_query_ok(); void on_query_ok();
void start_net_query(NetQueryType net_query_type, NetQueryPtr net_query); void start_net_query(NetQueryType net_query_type, NetQueryPtr net_query);
@ -232,7 +232,7 @@ class AuthManager final : public NetActor {
void on_get_password_result(NetQueryPtr &result); void on_get_password_result(NetQueryPtr &result);
void on_request_password_recovery_result(NetQueryPtr &result); void on_request_password_recovery_result(NetQueryPtr &result);
void on_check_password_recovery_code_result(NetQueryPtr &result); void on_check_password_recovery_code_result(NetQueryPtr &result);
void on_authentication_result(NetQueryPtr &result, bool expected_flag); void on_authentication_result(NetQueryPtr &result, bool is_from_current_query);
void on_log_out_result(NetQueryPtr &result); void on_log_out_result(NetQueryPtr &result);
void on_delete_account_result(NetQueryPtr &result); void on_delete_account_result(NetQueryPtr &result);
void on_get_login_token(tl_object_ptr<telegram_api::auth_LoginToken> login_token); void on_get_login_token(tl_object_ptr<telegram_api::auth_LoginToken> login_token);
@ -242,7 +242,9 @@ class AuthManager final : public NetActor {
void update_state(State new_state, bool force = false, bool should_save_state = true); void update_state(State new_state, bool force = false, bool should_save_state = true);
tl_object_ptr<td_api::AuthorizationState> get_authorization_state_object(State authorization_state) const; tl_object_ptr<td_api::AuthorizationState> get_authorization_state_object(State authorization_state) const;
void send_ok(uint64 query_id);
static void send_ok(uint64 query_id);
static void on_query_error(uint64 query_id, Status status);
void start_up() final; void start_up() final;
void tear_down() final; void tear_down() final;

View File

@ -453,7 +453,7 @@ void BackgroundManager::get_backgrounds(bool for_dark_theme,
} }
Result<string> BackgroundManager::get_background_url(const string &name, Result<string> BackgroundManager::get_background_url(const string &name,
td_api::object_ptr<td_api::BackgroundType> background_type) const { td_api::object_ptr<td_api::BackgroundType> background_type) {
TRY_RESULT(type, BackgroundType::get_background_type(background_type.get())); TRY_RESULT(type, BackgroundType::get_background_type(background_type.get()));
auto url = PSTRING() << G()->shared_config().get_option_string("t_me_url", "https://t.me/") << "bg/"; auto url = PSTRING() << G()->shared_config().get_option_string("t_me_url", "https://t.me/") << "bg/";
auto link = type.get_link(); auto link = type.get_link();
@ -526,7 +526,7 @@ std::pair<BackgroundId, BackgroundType> BackgroundManager::search_background(con
if (queries.size() == 1) { if (queries.size() == 1) {
LOG(INFO) << "Trying to load background " << slug << " from database"; LOG(INFO) << "Trying to load background " << slug << " from database";
G()->td_db()->get_sqlite_pmc()->get( G()->td_db()->get_sqlite_pmc()->get(
get_background_name_database_key(slug), PromiseCreator::lambda([slug](string value) { get_background_name_database_key(slug), PromiseCreator::lambda([slug](string value) mutable {
send_closure(G()->background_manager(), &BackgroundManager::on_load_background_from_database, send_closure(G()->background_manager(), &BackgroundManager::on_load_background_from_database,
std::move(slug), std::move(value)); std::move(slug), std::move(value));
})); }));
@ -563,7 +563,7 @@ void BackgroundManager::on_load_background_from_database(string name, string val
} else { } else {
if (background.name != name) { if (background.name != name) {
LOG(ERROR) << "Expected background " << name << ", but received " << background.name; LOG(ERROR) << "Expected background " << name << ", but received " << background.name;
name_to_background_id_.emplace(name, background.id); name_to_background_id_.emplace(std::move(name), background.id);
} }
add_background(background, false); add_background(background, false);
} }

View File

@ -36,8 +36,8 @@ class BackgroundManager final : public Actor {
void get_backgrounds(bool for_dark_theme, Promise<td_api::object_ptr<td_api::backgrounds>> &&promise); void get_backgrounds(bool for_dark_theme, Promise<td_api::object_ptr<td_api::backgrounds>> &&promise);
Result<string> get_background_url(const string &name, static Result<string> get_background_url(const string &name,
td_api::object_ptr<td_api::BackgroundType> background_type) const; td_api::object_ptr<td_api::BackgroundType> background_type);
void reload_background(BackgroundId background_id, int64 access_hash, Promise<Unit> &&promise); void reload_background(BackgroundId background_id, int64 access_hash, Promise<Unit> &&promise);

View File

@ -222,7 +222,7 @@ bool BackgroundFill::is_dark() const {
(fourth_color_ == -1 || (fourth_color_ & 0x808080) == 0); (fourth_color_ == -1 || (fourth_color_ & 0x808080) == 0);
default: default:
UNREACHABLE(); UNREACHABLE();
return 0; return false;
} }
} }

View File

@ -484,7 +484,7 @@ Status CallActor::do_update_call(telegram_api::phoneCall &call) {
get_emojis_fingerprint(call_state_.key, is_outgoing_ ? dh_handshake_.get_g_b() : dh_handshake_.get_g_a()); get_emojis_fingerprint(call_state_.key, is_outgoing_ ? dh_handshake_.get_g_b() : dh_handshake_.get_g_a());
for (auto &connection : call.connections_) { for (auto &connection : call.connections_) {
call_state_.connections.push_back(CallConnection(*connection)); call_state_.connections.emplace_back(*connection);
} }
call_state_.protocol = CallProtocol(*call.protocol_); call_state_.protocol = CallProtocol(*call.protocol_);
call_state_.allow_p2p = (call.flags_ & telegram_api::phoneCall::P2P_ALLOWED_MASK) != 0; call_state_.allow_p2p = (call.flags_ & telegram_api::phoneCall::P2P_ALLOWED_MASK) != 0;

View File

@ -70,7 +70,7 @@ struct CallState {
enum class Type : int32 { Empty, Pending, ExchangingKey, Ready, HangingUp, Discarded, Error } type{Type::Empty}; enum class Type : int32 { Empty, Pending, ExchangingKey, Ready, HangingUp, Discarded, Error } type{Type::Empty};
CallProtocol protocol; CallProtocol protocol;
std::vector<CallConnection> connections; vector<CallConnection> connections;
CallDiscardReason discard_reason{CallDiscardReason::Empty}; CallDiscardReason discard_reason{CallDiscardReason::Empty};
bool is_created{false}; bool is_created{false};
bool is_received{false}; bool is_received{false};

View File

@ -79,7 +79,9 @@ class GetBotCallbackAnswerQuery final : public Td::ResultHandler {
return on_error(id, result_ptr.move_as_error()); return on_error(id, result_ptr.move_as_error());
} }
td->callback_queries_manager_->on_get_callback_query_answer(result_ptr.move_as_ok(), std::move(promise_)); auto answer = result_ptr.move_as_ok();
bool show_alert = (answer->flags_ & telegram_api::messages_botCallbackAnswer::ALERT_MASK) != 0;
promise_.set_value(td_api::make_object<td_api::callbackQueryAnswer>(answer->message_, show_alert, answer->url_));
} }
void on_error(uint64 id, Status status) final { void on_error(uint64 id, Status status) final {
@ -288,12 +290,4 @@ void CallbackQueriesManager::send_get_callback_answer_query(
->send(dialog_id, full_message_id.get_message_id(), payload, std::move(password)); ->send(dialog_id, full_message_id.get_message_id(), payload, std::move(password));
} }
void CallbackQueriesManager::on_get_callback_query_answer(
tl_object_ptr<telegram_api::messages_botCallbackAnswer> &&answer,
Promise<td_api::object_ptr<td_api::callbackQueryAnswer>> &&promise) {
CHECK(answer != nullptr);
bool show_alert = (answer->flags_ & BOT_CALLBACK_ANSWER_FLAG_NEED_SHOW_ALERT) != 0;
promise.set_value(td_api::make_object<td_api::callbackQueryAnswer>(answer->message_, show_alert, answer->url_));
}
} // namespace td } // namespace td

View File

@ -42,15 +42,12 @@ class CallbackQueriesManager {
void send_callback_query(FullMessageId full_message_id, tl_object_ptr<td_api::CallbackQueryPayload> &&payload, void send_callback_query(FullMessageId full_message_id, tl_object_ptr<td_api::CallbackQueryPayload> &&payload,
Promise<td_api::object_ptr<td_api::callbackQueryAnswer>> &&promise); Promise<td_api::object_ptr<td_api::callbackQueryAnswer>> &&promise);
void on_get_callback_query_answer(tl_object_ptr<telegram_api::messages_botCallbackAnswer> &&answer,
Promise<td_api::object_ptr<td_api::callbackQueryAnswer>> &&promise);
private: private:
static constexpr int32 BOT_CALLBACK_ANSWER_FLAG_HAS_MESSAGE = 1 << 0; static constexpr int32 BOT_CALLBACK_ANSWER_FLAG_HAS_MESSAGE = 1 << 0;
static constexpr int32 BOT_CALLBACK_ANSWER_FLAG_NEED_SHOW_ALERT = 1 << 1; static constexpr int32 BOT_CALLBACK_ANSWER_FLAG_NEED_SHOW_ALERT = 1 << 1;
static constexpr int32 BOT_CALLBACK_ANSWER_FLAG_HAS_URL = 1 << 2; static constexpr int32 BOT_CALLBACK_ANSWER_FLAG_HAS_URL = 1 << 2;
tl_object_ptr<td_api::CallbackQueryPayload> get_query_payload(int32 flags, BufferSlice &&data, static tl_object_ptr<td_api::CallbackQueryPayload> get_query_payload(int32 flags, BufferSlice &&data,
string &&game_short_name); string &&game_short_name);
void send_get_callback_answer_query(FullMessageId full_message_id, void send_get_callback_answer_query(FullMessageId full_message_id,

View File

@ -64,7 +64,7 @@ class ClientActor final : public Actor {
/** /**
* Destroys the ClientActor and the TDLib instance. * Destroys the ClientActor and the TDLib instance.
*/ */
~ClientActor(); ~ClientActor() final;
/** /**
* Move constructor. * Move constructor.

View File

@ -379,7 +379,8 @@ ActorOwn<> get_simple_config_firebase_firestore(Promise<SimpleConfigResult> prom
prefer_ipv6, std::move(get_config)); prefer_ipv6, std::move(get_config));
} }
ActorOwn<> get_full_config(DcOption option, Promise<FullConfig> promise, ActorShared<> parent) { static ActorOwn<> get_full_config(DcOption option, Promise<tl_object_ptr<telegram_api::config>> promise,
ActorShared<> parent) {
class SessionCallback final : public Session::Callback { class SessionCallback final : public Session::Callback {
public: public:
SessionCallback(ActorShared<> parent, DcOption option) : parent_(std::move(parent)), option_(std::move(option)) { SessionCallback(ActorShared<> parent, DcOption option) : parent_(std::move(parent)), option_(std::move(option)) {
@ -496,7 +497,7 @@ ActorOwn<> get_full_config(DcOption option, Promise<FullConfig> promise, ActorSh
class GetConfigActor final : public NetQueryCallback { class GetConfigActor final : public NetQueryCallback {
public: public:
GetConfigActor(DcOption option, Promise<FullConfig> promise, ActorShared<> parent) GetConfigActor(DcOption option, Promise<tl_object_ptr<telegram_api::config>> promise, ActorShared<> parent)
: option_(std::move(option)), promise_(std::move(promise)), parent_(std::move(parent)) { : option_(std::move(option)), promise_(std::move(promise)), parent_(std::move(parent)) {
} }
@ -542,11 +543,12 @@ ActorOwn<> get_full_config(DcOption option, Promise<FullConfig> promise, ActorSh
DcOption option_; DcOption option_;
ActorOwn<Session> session_; ActorOwn<Session> session_;
Promise<FullConfig> promise_; Promise<tl_object_ptr<telegram_api::config>> promise_;
ActorShared<> parent_; ActorShared<> parent_;
}; };
return ActorOwn<>(create_actor<GetConfigActor>("GetConfigActor", option, std::move(promise), std::move(parent))); return ActorOwn<>(
create_actor<GetConfigActor>("GetConfigActor", std::move(option), std::move(promise), std::move(parent)));
} }
class ConfigRecoverer final : public Actor { class ConfigRecoverer final : public Actor {
@ -556,7 +558,7 @@ class ConfigRecoverer final : public Actor {
} }
void on_dc_options_update(DcOptions dc_options) { void on_dc_options_update(DcOptions dc_options) {
dc_options_update_ = dc_options; dc_options_update_ = std::move(dc_options);
update_dc_options(); update_dc_options();
loop(); loop();
} }
@ -676,22 +678,22 @@ class ConfigRecoverer final : public Actor {
} }
} }
void on_full_config(Result<FullConfig> r_full_config, bool dummy) { void on_full_config(Result<tl_object_ptr<telegram_api::config>> r_full_config, bool dummy) {
full_config_query_.reset(); full_config_query_.reset();
if (r_full_config.is_ok()) { if (r_full_config.is_ok()) {
full_config_ = r_full_config.move_as_ok(); full_config_ = r_full_config.move_as_ok();
VLOG(config_recoverer) << "Got FullConfig " << to_string(full_config_); VLOG(config_recoverer) << "Receive " << to_string(full_config_);
full_config_expires_at_ = get_config_expire_time(); full_config_expires_at_ = get_config_expire_time();
send_closure(G()->connection_creator(), &ConnectionCreator::on_dc_options, DcOptions(full_config_->dc_options_)); send_closure(G()->connection_creator(), &ConnectionCreator::on_dc_options, DcOptions(full_config_->dc_options_));
} else { } else {
VLOG(config_recoverer) << "Get FullConfig error " << r_full_config.error(); VLOG(config_recoverer) << "Failed to get config: " << r_full_config.error();
full_config_ = FullConfig(); full_config_ = nullptr;
full_config_expires_at_ = get_failed_config_expire_time(); full_config_expires_at_ = get_failed_config_expire_time();
} }
loop(); loop();
} }
bool expect_blocking() const { static bool expect_blocking() {
return G()->shared_config().get_option_boolean("expect_blocking", true); return G()->shared_config().get_option_boolean("expect_blocking", true);
} }
@ -729,7 +731,7 @@ class ConfigRecoverer final : public Actor {
size_t date_option_i_{0}; size_t date_option_i_{0};
FullConfig full_config_; tl_object_ptr<telegram_api::config> full_config_;
double full_config_expires_at_{0}; double full_config_expires_at_{0};
ActorOwn<> full_config_query_; ActorOwn<> full_config_query_;
@ -760,6 +762,7 @@ class ConfigRecoverer final : public Actor {
double max_connecting_delay() const { double max_connecting_delay() const {
return expect_blocking() ? 5 : 20; return expect_blocking() ? 5 : 20;
} }
void loop() final { void loop() final {
if (close_flag_) { if (close_flag_) {
return; return;
@ -829,9 +832,10 @@ class ConfigRecoverer final : public Actor {
if (need_full_config) { if (need_full_config) {
ref_cnt_++; ref_cnt_++;
VLOG(config_recoverer) << "Ask full config with dc_options_i_ = " << dc_options_i_; VLOG(config_recoverer) << "Ask full config with dc_options_i_ = " << dc_options_i_;
full_config_query_ = full_config_query_ = get_full_config(
get_full_config(dc_options_.dc_options[dc_options_i_], dc_options_.dc_options[dc_options_i_],
PromiseCreator::lambda([actor_id = actor_id(this)](Result<FullConfig> r_full_config) { PromiseCreator::lambda(
[actor_id = actor_id(this)](Result<tl_object_ptr<telegram_api::config>> r_full_config) {
send_closure(actor_id, &ConfigRecoverer::on_full_config, std::move(r_full_config), false); send_closure(actor_id, &ConfigRecoverer::on_full_config, std::move(r_full_config), false);
}), }),
actor_shared(this)); actor_shared(this));
@ -1282,7 +1286,7 @@ void ConfigManager::on_result(NetQueryPtr res) {
} }
} }
void ConfigManager::save_dc_options_update(DcOptions dc_options) { void ConfigManager::save_dc_options_update(const DcOptions &dc_options) {
if (dc_options.dc_options.empty()) { if (dc_options.dc_options.empty()) {
G()->td_db()->get_binlog_pmc()->erase("dc_options_update"); G()->td_db()->get_binlog_pmc()->erase("dc_options_update");
return; return;

View File

@ -78,10 +78,6 @@ class HttpDate {
static Result<int32> parse_http_date(std::string slice); static Result<int32> parse_http_date(std::string slice);
}; };
using FullConfig = tl_object_ptr<telegram_api::config>;
ActorOwn<> get_full_config(DcId dc_id, IPAddress ip_address, Promise<FullConfig> promise);
class ConfigRecoverer; class ConfigRecoverer;
class ConfigManager final : public NetQueryCallback { class ConfigManager final : public NetQueryCallback {
public: public:
@ -155,7 +151,7 @@ class ConfigManager final : public NetQueryCallback {
static Timestamp load_config_expire_time(); static Timestamp load_config_expire_time();
static void save_config_expire(Timestamp timestamp); static void save_config_expire(Timestamp timestamp);
static void save_dc_options_update(DcOptions dc_options); static void save_dc_options_update(const DcOptions &dc_options);
static DcOptions load_dc_options_update(); static DcOptions load_dc_options_update();
ActorShared<> create_reference(); ActorShared<> create_reference();

View File

@ -23,7 +23,7 @@ void ConfigShared::set_callback(unique_ptr<Callback> callback) {
return; return;
} }
for (auto key_value : config_pmc_->get_all()) { for (const auto &key_value : config_pmc_->get_all()) {
on_option_updated(key_value.first); on_option_updated(key_value.first);
} }
} }

View File

@ -580,7 +580,7 @@ class ImportContactsQuery final : public Td::ResultHandler {
return promise_.set_error(Status::Error(429, "Too Many Requests: retry after 3600")); return promise_.set_error(Status::Error(429, "Too Many Requests: retry after 3600"));
} }
int64 total_size = static_cast<int64>(input_contacts_.size()); auto total_size = static_cast<int64>(input_contacts_.size());
vector<tl_object_ptr<telegram_api::inputPhoneContact>> contacts; vector<tl_object_ptr<telegram_api::inputPhoneContact>> contacts;
contacts.reserve(ptr->retry_contacts_.size()); contacts.reserve(ptr->retry_contacts_.size());
for (auto &client_id : ptr->retry_contacts_) { for (auto &client_id : ptr->retry_contacts_) {
@ -588,7 +588,7 @@ class ImportContactsQuery final : public Td::ResultHandler {
LOG(ERROR) << "Wrong client_id " << client_id << " returned"; LOG(ERROR) << "Wrong client_id " << client_id << " returned";
continue; continue;
} }
size_t i = static_cast<size_t>(client_id); auto i = static_cast<size_t>(client_id);
contacts.push_back(input_contacts_[i].get_input_phone_contact(client_id)); contacts.push_back(input_contacts_[i].get_input_phone_contact(client_id));
} }
@ -2271,7 +2271,8 @@ class EditChannelAdminQuery final : public Td::ResultHandler {
explicit EditChannelAdminQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) { explicit EditChannelAdminQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
} }
void send(ChannelId channel_id, tl_object_ptr<telegram_api::InputUser> &&input_user, DialogParticipantStatus status) { void send(ChannelId channel_id, tl_object_ptr<telegram_api::InputUser> &&input_user,
const DialogParticipantStatus &status) {
channel_id_ = channel_id; channel_id_ = channel_id;
auto input_channel = td->contacts_manager_->get_input_channel(channel_id); auto input_channel = td->contacts_manager_->get_input_channel(channel_id);
CHECK(input_channel != nullptr); CHECK(input_channel != nullptr);
@ -2306,7 +2307,8 @@ class EditChannelBannedQuery final : public Td::ResultHandler {
explicit EditChannelBannedQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) { explicit EditChannelBannedQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
} }
void send(ChannelId channel_id, tl_object_ptr<telegram_api::InputPeer> &&input_peer, DialogParticipantStatus status) { void send(ChannelId channel_id, tl_object_ptr<telegram_api::InputPeer> &&input_peer,
const DialogParticipantStatus &status) {
channel_id_ = channel_id; channel_id_ = channel_id;
auto input_channel = td->contacts_manager_->get_input_channel(channel_id); auto input_channel = td->contacts_manager_->get_input_channel(channel_id);
CHECK(input_channel != nullptr); CHECK(input_channel != nullptr);
@ -2685,7 +2687,7 @@ class GetUserPhotosQuery final : public Td::ResultHandler {
auto photos = move_tl_object_as<telegram_api::photos_photos>(ptr); auto photos = move_tl_object_as<telegram_api::photos_photos>(ptr);
td->contacts_manager_->on_get_users(std::move(photos->users_), "GetUserPhotosQuery"); td->contacts_manager_->on_get_users(std::move(photos->users_), "GetUserPhotosQuery");
int32 photos_size = narrow_cast<int32>(photos->photos_.size()); auto photos_size = narrow_cast<int32>(photos->photos_.size());
td->contacts_manager_->on_get_user_photos(user_id_, offset_, limit_, photos_size, std::move(photos->photos_)); td->contacts_manager_->on_get_user_photos(user_id_, offset_, limit_, photos_size, std::move(photos->photos_));
} else { } else {
CHECK(constructor_id == telegram_api::photos_photosSlice::ID); CHECK(constructor_id == telegram_api::photos_photosSlice::ID);
@ -2924,7 +2926,7 @@ class GetChannelParticipantsQuery final : public Td::ResultHandler {
: promise_(std::move(promise)) { : promise_(std::move(promise)) {
} }
void send(ChannelId channel_id, ChannelParticipantsFilter filter, int32 offset, int32 limit) { void send(ChannelId channel_id, const ChannelParticipantsFilter &filter, int32 offset, int32 limit) {
auto input_channel = td->contacts_manager_->get_input_channel(channel_id); auto input_channel = td->contacts_manager_->get_input_channel(channel_id);
if (input_channel == nullptr) { if (input_channel == nullptr) {
return promise_.set_error(Status::Error(400, "Supergroup not found")); return promise_.set_error(Status::Error(400, "Supergroup not found"));
@ -5181,7 +5183,7 @@ td_api::object_ptr<td_api::session> ContactsManager::convert_authorization_objec
authorization->country_, authorization->region_); authorization->country_, authorization->region_);
} }
void ContactsManager::confirm_qr_code_authentication(string link, void ContactsManager::confirm_qr_code_authentication(const string &link,
Promise<td_api::object_ptr<td_api::session>> &&promise) { Promise<td_api::object_ptr<td_api::session>> &&promise) {
Slice prefix("tg://login?token="); Slice prefix("tg://login?token=");
if (!begins_with(to_lower(link), prefix)) { if (!begins_with(to_lower(link), prefix)) {
@ -5372,7 +5374,7 @@ std::pair<vector<UserId>, vector<int32>> ContactsManager::import_contacts(const
return {}; return {};
} }
void ContactsManager::remove_contacts(vector<UserId> user_ids, Promise<Unit> &&promise) { void ContactsManager::remove_contacts(const vector<UserId> &user_ids, Promise<Unit> &&promise) {
LOG(INFO) << "Delete contacts: " << format::as_array(user_ids); LOG(INFO) << "Delete contacts: " << format::as_array(user_ids);
if (!are_contacts_loaded_) { if (!are_contacts_loaded_) {
load_contacts(std::move(promise)); load_contacts(std::move(promise));
@ -5586,7 +5588,7 @@ std::pair<vector<UserId>, vector<int32>> ContactsManager::change_imported_contac
std::pair<vector<size_t>, vector<Contact>> to_add; std::pair<vector<size_t>, vector<Contact>> to_add;
for (auto &new_contact : different_new_contacts) { for (auto &new_contact : different_new_contacts) {
to_add.first.push_back(new_contact.second); to_add.first.push_back(new_contact.second);
to_add.second.push_back(std::move(new_contact.first)); to_add.second.push_back(new_contact.first);
} }
if (to_add.first.empty() && to_delete.empty()) { if (to_add.first.empty() && to_delete.empty()) {
@ -6670,10 +6672,10 @@ void ContactsManager::send_get_channel_message_stats_query(
->send(dialog_id.get_channel_id(), full_message_id.get_message_id(), is_dark, dc_id); ->send(dialog_id.get_channel_id(), full_message_id.get_message_id(), is_dark, dc_id);
} }
void ContactsManager::load_statistics_graph(DialogId dialog_id, const string &token, int64 x, void ContactsManager::load_statistics_graph(DialogId dialog_id, string token, int64 x,
Promise<td_api::object_ptr<td_api::StatisticalGraph>> &&promise) { Promise<td_api::object_ptr<td_api::StatisticalGraph>> &&promise) {
auto dc_id_promise = PromiseCreator::lambda( auto dc_id_promise = PromiseCreator::lambda([actor_id = actor_id(this), token = std::move(token), x,
[actor_id = actor_id(this), token, x, promise = std::move(promise)](Result<DcId> r_dc_id) mutable { promise = std::move(promise)](Result<DcId> r_dc_id) mutable {
if (r_dc_id.is_error()) { if (r_dc_id.is_error()) {
return promise.set_error(r_dc_id.move_as_error()); return promise.set_error(r_dc_id.move_as_error());
} }
@ -6810,8 +6812,8 @@ void ContactsManager::add_chat_participant(ChatId chat_id, UserId user_id, int32
td_->create_handler<AddChatUserQuery>(std::move(promise))->send(chat_id, std::move(input_user), forward_limit); td_->create_handler<AddChatUserQuery>(std::move(promise))->send(chat_id, std::move(input_user), forward_limit);
} }
void ContactsManager::add_channel_participant(ChannelId channel_id, UserId user_id, Promise<Unit> &&promise, void ContactsManager::add_channel_participant(ChannelId channel_id, UserId user_id,
DialogParticipantStatus old_status) { const DialogParticipantStatus &old_status, Promise<Unit> &&promise) {
if (td_->auth_manager_->is_bot()) { if (td_->auth_manager_->is_bot()) {
return promise.set_error(Status::Error(400, "Bots can't add new chat members")); return promise.set_error(Status::Error(400, "Bots can't add new chat members"));
} }
@ -6985,8 +6987,8 @@ void ContactsManager::set_channel_participant_status_impl(ChannelId channel_id,
if (participant_dialog_id.get_type() != DialogType::User) { if (participant_dialog_id.get_type() != DialogType::User) {
return promise.set_error(Status::Error(400, "Can't promote chats to chat administrators")); return promise.set_error(Status::Error(400, "Can't promote chats to chat administrators"));
} }
return promote_channel_participant(channel_id, participant_dialog_id.get_user_id(), std::move(status), return promote_channel_participant(channel_id, participant_dialog_id.get_user_id(), status, old_status,
std::move(old_status), std::move(promise)); std::move(promise));
} else if (need_restrict) { } else if (need_restrict) {
return restrict_channel_participant(channel_id, participant_dialog_id, std::move(status), std::move(old_status), return restrict_channel_participant(channel_id, participant_dialog_id, std::move(status), std::move(old_status),
std::move(promise)); std::move(promise));
@ -6995,13 +6997,13 @@ void ContactsManager::set_channel_participant_status_impl(ChannelId channel_id,
if (participant_dialog_id.get_type() != DialogType::User) { if (participant_dialog_id.get_type() != DialogType::User) {
return promise.set_error(Status::Error(400, "Can't add chats as chat members")); return promise.set_error(Status::Error(400, "Can't add chats as chat members"));
} }
return add_channel_participant(channel_id, participant_dialog_id.get_user_id(), std::move(promise), return add_channel_participant(channel_id, participant_dialog_id.get_user_id(), old_status, std::move(promise));
std::move(old_status));
} }
} }
void ContactsManager::promote_channel_participant(ChannelId channel_id, UserId user_id, DialogParticipantStatus status, void ContactsManager::promote_channel_participant(ChannelId channel_id, UserId user_id,
DialogParticipantStatus old_status, Promise<Unit> &&promise) { const DialogParticipantStatus &status,
const DialogParticipantStatus &old_status, Promise<Unit> &&promise) {
LOG(INFO) << "Promote " << user_id << " in " << channel_id << " from " << old_status << " to " << status; LOG(INFO) << "Promote " << user_id << " in " << channel_id << " from " << old_status << " to " << status;
const Channel *c = get_channel(channel_id); const Channel *c = get_channel(channel_id);
CHECK(c != nullptr); CHECK(c != nullptr);
@ -7458,8 +7460,8 @@ void ContactsManager::delete_chat_participant(ChatId chat_id, UserId user_id, bo
} }
void ContactsManager::restrict_channel_participant(ChannelId channel_id, DialogId participant_dialog_id, void ContactsManager::restrict_channel_participant(ChannelId channel_id, DialogId participant_dialog_id,
DialogParticipantStatus status, DialogParticipantStatus old_status, DialogParticipantStatus &&status,
Promise<Unit> &&promise) { DialogParticipantStatus &&old_status, Promise<Unit> &&promise) {
TRY_STATUS_PROMISE(promise, G()->close_status()); TRY_STATUS_PROMISE(promise, G()->close_status());
LOG(INFO) << "Restrict " << participant_dialog_id << " in " << channel_id << " from " << old_status << " to " LOG(INFO) << "Restrict " << participant_dialog_id << " in " << channel_id << " from " << old_status << " to "
@ -7520,21 +7522,22 @@ void ContactsManager::restrict_channel_participant(ChannelId channel_id, DialogI
if (old_status.is_member() && !status.is_member() && !status.is_banned()) { if (old_status.is_member() && !status.is_member() && !status.is_banned()) {
// we can't make participant Left without kicking it first // we can't make participant Left without kicking it first
auto on_result_promise = PromiseCreator::lambda([actor_id = actor_id(this), channel_id, participant_dialog_id, auto on_result_promise = PromiseCreator::lambda([actor_id = actor_id(this), channel_id, participant_dialog_id,
status, promise = std::move(promise)](Result<> result) mutable { status = std::move(status),
if (result.is_error()) {
return promise.set_error(result.move_as_error());
}
create_actor<SleepActor>("RestrictChannelParticipantSleepActor", 1.0,
PromiseCreator::lambda([actor_id, channel_id, participant_dialog_id, status,
promise = std::move(promise)](Result<> result) mutable { promise = std::move(promise)](Result<> result) mutable {
if (result.is_error()) { if (result.is_error()) {
return promise.set_error(result.move_as_error()); return promise.set_error(result.move_as_error());
} }
send_closure(actor_id, &ContactsManager::restrict_channel_participant, channel_id, create_actor<SleepActor>(
participant_dialog_id, status, DialogParticipantStatus::Banned(0), "RestrictChannelParticipantSleepActor", 1.0,
std::move(promise)); PromiseCreator::lambda([actor_id, channel_id, participant_dialog_id, status = std::move(status),
promise = std::move(promise)](Result<> result) mutable {
if (result.is_error()) {
return promise.set_error(result.move_as_error());
}
send_closure(actor_id, &ContactsManager::restrict_channel_participant, channel_id, participant_dialog_id,
std::move(status), DialogParticipantStatus::Banned(0), std::move(promise));
})) }))
.release(); .release();
}); });
@ -7605,7 +7608,7 @@ vector<DialogId> ContactsManager::get_dialog_ids(vector<tl_object_ptr<telegram_a
} }
vector<DialogId> ContactsManager::get_created_public_dialogs(PublicDialogType type, Promise<Unit> &&promise) { vector<DialogId> ContactsManager::get_created_public_dialogs(PublicDialogType type, Promise<Unit> &&promise) {
int32 index = static_cast<int32>(type); auto index = static_cast<int32>(type);
if (created_public_channels_inited_[index]) { if (created_public_channels_inited_[index]) {
promise.set_value(Unit()); promise.set_value(Unit());
return transform(created_public_channels_[index], [&](ChannelId channel_id) { return transform(created_public_channels_[index], [&](ChannelId channel_id) {
@ -7621,7 +7624,7 @@ vector<DialogId> ContactsManager::get_created_public_dialogs(PublicDialogType ty
void ContactsManager::on_get_created_public_channels(PublicDialogType type, void ContactsManager::on_get_created_public_channels(PublicDialogType type,
vector<tl_object_ptr<telegram_api::Chat>> &&chats) { vector<tl_object_ptr<telegram_api::Chat>> &&chats) {
int32 index = static_cast<int32>(type); auto index = static_cast<int32>(type);
created_public_channels_[index] = get_channel_ids(std::move(chats), "on_get_created_public_channels"); created_public_channels_[index] = get_channel_ids(std::move(chats), "on_get_created_public_channels");
created_public_channels_inited_[index] = true; created_public_channels_inited_[index] = true;
} }
@ -9626,7 +9629,7 @@ ContactsManager::ChannelFull *ContactsManager::get_channel_full_force(ChannelId
return get_channel_full(channel_id, only_local, source); return get_channel_full(channel_id, only_local, source);
} }
void ContactsManager::for_each_secret_chat_with_user(UserId user_id, std::function<void(SecretChatId)> f) { void ContactsManager::for_each_secret_chat_with_user(UserId user_id, const std::function<void(SecretChatId)> &f) {
auto it = secret_chats_with_user_.find(user_id); auto it = secret_chats_with_user_.find(user_id);
if (it != secret_chats_with_user_.end()) { if (it != secret_chats_with_user_.end()) {
for (auto secret_chat_id : it->second) { for (auto secret_chat_id : it->second) {
@ -10208,7 +10211,7 @@ void ContactsManager::on_get_user_full(tl_object_ptr<telegram_api::userFull> &&u
void ContactsManager::on_get_user_photos(UserId user_id, int32 offset, int32 limit, int32 total_count, void ContactsManager::on_get_user_photos(UserId user_id, int32 offset, int32 limit, int32 total_count,
vector<tl_object_ptr<telegram_api::Photo>> photos) { vector<tl_object_ptr<telegram_api::Photo>> photos) {
int32 photo_count = narrow_cast<int32>(photos.size()); auto photo_count = narrow_cast<int32>(photos.size());
int32 min_total_count = (offset >= 0 && photo_count > 0 ? offset : 0) + photo_count; int32 min_total_count = (offset >= 0 && photo_count > 0 ? offset : 0) + photo_count;
if (total_count < min_total_count) { if (total_count < min_total_count) {
LOG(ERROR) << "Wrong photos total_count " << total_count << ". Receive " << photo_count << " photos with offset " LOG(ERROR) << "Wrong photos total_count " << total_count << ". Receive " << photo_count << " photos with offset "
@ -10737,7 +10740,7 @@ void ContactsManager::on_get_chat_full_failed(ChatId chat_id) {
return; return;
} }
LOG(INFO) << "Failed to get " << chat_id; LOG(INFO) << "Failed to get full " << chat_id;
} }
void ContactsManager::on_get_channel_full_failed(ChannelId channel_id) { void ContactsManager::on_get_channel_full_failed(ChannelId channel_id) {
@ -10745,7 +10748,7 @@ void ContactsManager::on_get_channel_full_failed(ChannelId channel_id) {
return; return;
} }
LOG(INFO) << "Failed to get " << channel_id; LOG(INFO) << "Failed to get full " << channel_id;
auto channel_full = get_channel_full(channel_id, true, "on_get_channel_full"); auto channel_full = get_channel_full(channel_id, true, "on_get_channel_full");
if (channel_full != nullptr) { if (channel_full != nullptr) {
channel_full->repair_request_version = 0; channel_full->repair_request_version = 0;
@ -10869,8 +10872,8 @@ void ContactsManager::do_update_user_photo(User *u, UserId user_id,
do_update_user_photo(u, user_id, std::move(new_photo), true, source); do_update_user_photo(u, user_id, std::move(new_photo), true, source);
} }
void ContactsManager::do_update_user_photo(User *u, UserId user_id, ProfilePhoto new_photo, bool invalidate_photo_cache, void ContactsManager::do_update_user_photo(User *u, UserId user_id, ProfilePhoto &&new_photo,
const char *source) { bool invalidate_photo_cache, const char *source) {
u->is_photo_inited = true; u->is_photo_inited = true;
if (new_photo != u->photo) { if (new_photo != u->photo) {
LOG_IF(ERROR, u->access_hash == -1 && new_photo.small_file_id.is_valid()) LOG_IF(ERROR, u->access_hash == -1 && new_photo.small_file_id.is_valid())
@ -11148,7 +11151,7 @@ void ContactsManager::on_update_user_need_phone_number_privacy_exception(UserId
} }
void ContactsManager::on_update_user_full_need_phone_number_privacy_exception( void ContactsManager::on_update_user_full_need_phone_number_privacy_exception(
UserFull *user_full, UserId user_id, bool need_phone_number_privacy_exception) { UserFull *user_full, UserId user_id, bool need_phone_number_privacy_exception) const {
CHECK(user_full != nullptr); CHECK(user_full != nullptr);
if (need_phone_number_privacy_exception) { if (need_phone_number_privacy_exception) {
const User *u = get_user(user_id); const User *u = get_user(user_id);
@ -11993,8 +11996,8 @@ void ContactsManager::speculative_add_channel_participant_count(ChannelId channe
} }
void ContactsManager::speculative_add_channel_user(ChannelId channel_id, UserId user_id, void ContactsManager::speculative_add_channel_user(ChannelId channel_id, UserId user_id,
DialogParticipantStatus new_status, const DialogParticipantStatus &new_status,
DialogParticipantStatus old_status) { const DialogParticipantStatus &old_status) {
auto c = get_channel_force(channel_id); auto c = get_channel_force(channel_id);
// channel full must be loaded before c->participant_count is updated, because on_load_channel_full_from_database // channel full must be loaded before c->participant_count is updated, because on_load_channel_full_from_database
// must copy the initial c->participant_count before it is speculatibely updated // must copy the initial c->participant_count before it is speculatibely updated
@ -12799,7 +12802,7 @@ void ContactsManager::on_update_chat_status(Chat *c, ChatId chat_id, DialogParti
bool need_reload_group_call = c->status.can_manage_calls() != status.can_manage_calls(); bool need_reload_group_call = c->status.can_manage_calls() != status.can_manage_calls();
bool need_drop_invite_link = c->status.can_manage_invite_links() && !status.can_manage_invite_links(); bool need_drop_invite_link = c->status.can_manage_invite_links() && !status.can_manage_invite_links();
c->status = status; c->status = std::move(status);
if (c->status.is_left()) { if (c->status.is_left()) {
c->participant_count = 0; c->participant_count = 0;
@ -13376,7 +13379,7 @@ void ContactsManager::on_update_channel_default_permissions(ChannelId channel_id
} }
void ContactsManager::send_update_chat_member(DialogId dialog_id, UserId agent_user_id, int32 date, void ContactsManager::send_update_chat_member(DialogId dialog_id, UserId agent_user_id, int32 date,
DialogInviteLink invite_link, const DialogInviteLink &invite_link,
const DialogParticipant &old_dialog_participant, const DialogParticipant &old_dialog_participant,
const DialogParticipant &new_dialog_participant) { const DialogParticipant &new_dialog_participant) {
CHECK(td_->auth_manager_->is_bot()); CHECK(td_->auth_manager_->is_bot());
@ -14621,8 +14624,8 @@ void ContactsManager::add_dialog_participant(DialogId dialog_id, UserId user_id,
case DialogType::Chat: case DialogType::Chat:
return add_chat_participant(dialog_id.get_chat_id(), user_id, forward_limit, std::move(promise)); return add_chat_participant(dialog_id.get_chat_id(), user_id, forward_limit, std::move(promise));
case DialogType::Channel: case DialogType::Channel:
return add_channel_participant(dialog_id.get_channel_id(), user_id, std::move(promise), return add_channel_participant(dialog_id.get_channel_id(), user_id, DialogParticipantStatus::Left(),
DialogParticipantStatus::Left()); std::move(promise));
case DialogType::SecretChat: case DialogType::SecretChat:
return promise.set_error(Status::Error(400, "Can't add members to a secret chat")); return promise.set_error(Status::Error(400, "Can't add members to a secret chat"));
case DialogType::None: case DialogType::None:
@ -15091,7 +15094,7 @@ void ContactsManager::get_channel_participants(ChannelId channel_id,
} }
}); });
td_->create_handler<GetChannelParticipantsQuery>(std::move(get_channel_participants_promise)) td_->create_handler<GetChannelParticipantsQuery>(std::move(get_channel_participants_promise))
->send(channel_id, std::move(participants_filter), offset, limit); ->send(channel_id, participants_filter, offset, limit);
} }
vector<DialogAdministrator> ContactsManager::get_dialog_administrators(DialogId dialog_id, int left_tries, vector<DialogAdministrator> ContactsManager::get_dialog_administrators(DialogId dialog_id, int left_tries,
@ -15150,10 +15153,11 @@ string ContactsManager::get_dialog_administrators_database_key(DialogId dialog_i
void ContactsManager::load_dialog_administrators(DialogId dialog_id, Promise<Unit> &&promise) { void ContactsManager::load_dialog_administrators(DialogId dialog_id, Promise<Unit> &&promise) {
if (G()->parameters().use_chat_info_db) { if (G()->parameters().use_chat_info_db) {
LOG(INFO) << "Load administrators of " << dialog_id << " from database"; LOG(INFO) << "Load administrators of " << dialog_id << " from database";
G()->td_db()->get_sqlite_pmc()->get( G()->td_db()->get_sqlite_pmc()->get(get_dialog_administrators_database_key(dialog_id),
get_dialog_administrators_database_key(dialog_id), PromiseCreator::lambda([actor_id = actor_id(this), dialog_id,
PromiseCreator::lambda([dialog_id, promise = std::move(promise)](string value) mutable { promise = std::move(promise)](string value) mutable {
send_closure(G()->contacts_manager(), &ContactsManager::on_load_dialog_administrators_from_database, send_closure(actor_id,
&ContactsManager::on_load_dialog_administrators_from_database,
dialog_id, std::move(value), std::move(promise)); dialog_id, std::move(value), std::move(promise));
})); }));
} else { } else {
@ -15650,7 +15654,7 @@ void ContactsManager::on_chat_update(telegram_api::channelForbidden &channel, co
on_update_channel_status(c, channel_id, DialogParticipantStatus::Banned(unban_date)); on_update_channel_status(c, channel_id, DialogParticipantStatus::Banned(unban_date));
// on_update_channel_username(c, channel_id, ""); // don't know if channel username is empty, so don't update it // on_update_channel_username(c, channel_id, ""); // don't know if channel username is empty, so don't update it
tl_object_ptr<telegram_api::chatBannedRights> banned_rights; // == nullptr tl_object_ptr<telegram_api::chatBannedRights> banned_rights; // == nullptr
on_update_channel_default_permissions(c, channel_id, get_restricted_rights(banned_rights)); on_update_channel_default_permissions(c, channel_id, get_restricted_rights(std::move(banned_rights)));
td_->messages_manager_->on_update_dialog_group_call(DialogId(channel_id), false, false, "receive channelForbidden"); td_->messages_manager_->on_update_dialog_group_call(DialogId(channel_id), false, false, "receive channelForbidden");
bool sign_messages = false; bool sign_messages = false;
@ -15943,7 +15947,7 @@ tl_object_ptr<td_api::supergroup> ContactsManager::get_supergroup_object(Channel
return get_supergroup_object(channel_id, get_channel(channel_id)); return get_supergroup_object(channel_id, get_channel(channel_id));
} }
tl_object_ptr<td_api::supergroup> ContactsManager::get_supergroup_object(ChannelId channel_id, const Channel *c) const { tl_object_ptr<td_api::supergroup> ContactsManager::get_supergroup_object(ChannelId channel_id, const Channel *c) {
if (c == nullptr) { if (c == nullptr) {
return nullptr; return nullptr;
} }

View File

@ -111,7 +111,7 @@ class ContactsManager final : public Actor {
bool is_update_about_username_change_received(UserId user_id) const; bool is_update_about_username_change_received(UserId user_id) const;
void for_each_secret_chat_with_user(UserId user_id, std::function<void(SecretChatId)> f); void for_each_secret_chat_with_user(UserId user_id, const std::function<void(SecretChatId)> &f);
string get_user_username(UserId user_id) const; string get_user_username(UserId user_id) const;
string get_channel_username(ChannelId channel_id) const; string get_channel_username(ChannelId channel_id) const;
@ -278,14 +278,14 @@ class ContactsManager final : public Actor {
static td_api::object_ptr<td_api::session> convert_authorization_object( static td_api::object_ptr<td_api::session> convert_authorization_object(
tl_object_ptr<telegram_api::authorization> &&authorization); tl_object_ptr<telegram_api::authorization> &&authorization);
void confirm_qr_code_authentication(string link, Promise<td_api::object_ptr<td_api::session>> &&promise); void confirm_qr_code_authentication(const string &link, Promise<td_api::object_ptr<td_api::session>> &&promise);
void get_active_sessions(Promise<tl_object_ptr<td_api::sessions>> &&promise) const; void get_active_sessions(Promise<tl_object_ptr<td_api::sessions>> &&promise) const;
void terminate_session(int64 session_id, Promise<Unit> &&promise) const; void terminate_session(int64 session_id, Promise<Unit> &&promise) const;
void terminate_all_other_sessions(Promise<Unit> &&promise) const; void terminate_all_other_sessions(Promise<Unit> &&promise) const;
void get_connected_websites(Promise<tl_object_ptr<td_api::connectedWebsites>> &&promise) const; void get_connected_websites(Promise<tl_object_ptr<td_api::connectedWebsites>> &&promise) const;
void disconnect_website(int64 authorizations_id, Promise<Unit> &&promise) const; void disconnect_website(int64 website_id, Promise<Unit> &&promise) const;
void disconnect_all_websites(Promise<Unit> &&promise) const; void disconnect_all_websites(Promise<Unit> &&promise) const;
void add_contact(Contact contact, bool share_phone_number, Promise<Unit> &&promise); void add_contact(Contact contact, bool share_phone_number, Promise<Unit> &&promise);
@ -295,7 +295,7 @@ class ContactsManager final : public Actor {
std::pair<int32, vector<UserId>> search_contacts(const string &query, int32 limit, Promise<Unit> &&promise); std::pair<int32, vector<UserId>> search_contacts(const string &query, int32 limit, Promise<Unit> &&promise);
void remove_contacts(vector<UserId> user_ids, Promise<Unit> &&promise); void remove_contacts(const vector<UserId> &user_ids, Promise<Unit> &&promise);
void remove_contacts_by_phone_number(vector<string> user_phone_numbers, vector<UserId> user_ids, void remove_contacts_by_phone_number(vector<string> user_phone_numbers, vector<UserId> user_ids,
Promise<Unit> &&promise); Promise<Unit> &&promise);
@ -367,7 +367,7 @@ class ContactsManager final : public Actor {
void get_channel_message_statistics(FullMessageId full_message_id, bool is_dark, void get_channel_message_statistics(FullMessageId full_message_id, bool is_dark,
Promise<td_api::object_ptr<td_api::messageStatistics>> &&promise); Promise<td_api::object_ptr<td_api::messageStatistics>> &&promise);
void load_statistics_graph(DialogId dialog_id, const string &token, int64 x, void load_statistics_graph(DialogId dialog_id, string token, int64 x,
Promise<td_api::object_ptr<td_api::StatisticalGraph>> &&promise); Promise<td_api::object_ptr<td_api::StatisticalGraph>> &&promise);
struct CanTransferOwnershipResult { struct CanTransferOwnershipResult {
@ -476,7 +476,7 @@ class ContactsManager final : public Actor {
FileSourceId get_chat_full_file_source_id(ChatId chat_id); FileSourceId get_chat_full_file_source_id(ChatId chat_id);
void reload_chat_full(ChatId chat_id, Promise<Unit> &&promise); void reload_chat_full(ChatId chat_id, Promise<Unit> &&promise);
int32 get_chat_participant_count(ChatId channel_id) const; int32 get_chat_participant_count(ChatId chat_id) const;
bool get_chat_is_active(ChatId chat_id) const; bool get_chat_is_active(ChatId chat_id) const;
ChannelId get_chat_migrated_to_channel_id(ChatId chat_id) const; ChannelId get_chat_migrated_to_channel_id(ChatId chat_id) const;
DialogParticipantStatus get_chat_status(ChatId chat_id) const; DialogParticipantStatus get_chat_status(ChatId chat_id) const;
@ -487,7 +487,7 @@ class ContactsManager final : public Actor {
bool have_min_channel(ChannelId channel_id) const; bool have_min_channel(ChannelId channel_id) const;
bool have_channel_force(ChannelId channel_id); bool have_channel_force(ChannelId channel_id);
bool get_channel(ChannelId channel_id, int left_tries, Promise<Unit> &&promise); bool get_channel(ChannelId channel_id, int left_tries, Promise<Unit> &&promise);
void reload_channel(ChannelId chnanel_id, Promise<Unit> &&promise); void reload_channel(ChannelId channel_id, Promise<Unit> &&promise);
void load_channel_full(ChannelId channel_id, bool force, Promise<Unit> &&promise, const char *source); void load_channel_full(ChannelId channel_id, bool force, Promise<Unit> &&promise, const char *source);
FileSourceId get_channel_full_file_source_id(ChannelId channel_id); FileSourceId get_channel_full_file_source_id(ChannelId channel_id);
void reload_channel_full(ChannelId channel_id, Promise<Unit> &&promise, const char *source); void reload_channel_full(ChannelId channel_id, Promise<Unit> &&promise, const char *source);
@ -581,7 +581,7 @@ class ContactsManager final : public Actor {
static tl_object_ptr<td_api::StatisticalGraph> convert_stats_graph(tl_object_ptr<telegram_api::StatsGraph> obj); static tl_object_ptr<td_api::StatisticalGraph> convert_stats_graph(tl_object_ptr<telegram_api::StatsGraph> obj);
static double get_percentage_value(double new_value, double old_value); static double get_percentage_value(double part, double total);
static tl_object_ptr<td_api::statisticalValue> convert_stats_absolute_value( static tl_object_ptr<td_api::statisticalValue> convert_stats_absolute_value(
const tl_object_ptr<telegram_api::statsAbsValueAndPrev> &obj); const tl_object_ptr<telegram_api::statsAbsValueAndPrev> &obj);
@ -1162,7 +1162,7 @@ class ContactsManager final : public Actor {
static bool is_valid_username(const string &username); static bool is_valid_username(const string &username);
void on_update_user_name(User *u, UserId user_id, string &&first_name, string &&last_name, string &&username); void on_update_user_name(User *u, UserId user_id, string &&first_name, string &&last_name, string &&username);
void on_update_user_phone_number(User *u, UserId user_id, string &&phone_number); static void on_update_user_phone_number(User *u, UserId user_id, string &&phone_number);
void on_update_user_photo(User *u, UserId user_id, tl_object_ptr<telegram_api::UserProfilePhoto> &&photo, void on_update_user_photo(User *u, UserId user_id, tl_object_ptr<telegram_api::UserProfilePhoto> &&photo,
const char *source); const char *source);
void on_update_user_is_contact(User *u, UserId user_id, bool is_contact, bool is_mutual_contact); void on_update_user_is_contact(User *u, UserId user_id, bool is_contact, bool is_mutual_contact);
@ -1171,7 +1171,7 @@ class ContactsManager final : public Actor {
void do_update_user_photo(User *u, UserId user_id, tl_object_ptr<telegram_api::UserProfilePhoto> &&photo, void do_update_user_photo(User *u, UserId user_id, tl_object_ptr<telegram_api::UserProfilePhoto> &&photo,
const char *source); const char *source);
void do_update_user_photo(User *u, UserId user_id, ProfilePhoto new_photo, bool invalidate_photo_cache, void do_update_user_photo(User *u, UserId user_id, ProfilePhoto &&new_photo, bool invalidate_photo_cache,
const char *source); const char *source);
void upload_profile_photo(FileId file_id, bool is_animation, double main_frame_timestamp, Promise<Unit> &&promise, void upload_profile_photo(FileId file_id, bool is_animation, double main_frame_timestamp, Promise<Unit> &&promise,
@ -1182,12 +1182,12 @@ class ContactsManager final : public Actor {
void register_user_photo(User *u, UserId user_id, const Photo &photo); void register_user_photo(User *u, UserId user_id, const Photo &photo);
void on_update_user_full_is_blocked(UserFull *user_full, UserId user_id, bool is_blocked); static void on_update_user_full_is_blocked(UserFull *user_full, UserId user_id, bool is_blocked);
void on_update_user_full_common_chat_count(UserFull *user_full, UserId user_id, int32 common_chat_count); static void on_update_user_full_common_chat_count(UserFull *user_full, UserId user_id, int32 common_chat_count);
void on_update_user_full_commands(UserFull *user_full, UserId user_id, static void on_update_user_full_commands(UserFull *user_full, UserId user_id,
vector<tl_object_ptr<telegram_api::botCommand>> &&bot_commands); vector<tl_object_ptr<telegram_api::botCommand>> &&bot_commands);
void on_update_user_full_need_phone_number_privacy_exception(UserFull *user_full, UserId user_id, void on_update_user_full_need_phone_number_privacy_exception(UserFull *user_full, UserId user_id,
bool need_phone_number_privacy_exception); bool need_phone_number_privacy_exception) const;
void add_profile_photo_to_cache(UserId user_id, Photo &&photo); void add_profile_photo_to_cache(UserId user_id, Photo &&photo);
bool delete_profile_photo_from_cache(UserId user_id, int64 profile_photo_id, bool send_updates); bool delete_profile_photo_from_cache(UserId user_id, int64 profile_photo_id, bool send_updates);
@ -1195,13 +1195,14 @@ class ContactsManager final : public Actor {
void drop_user_full(UserId user_id); void drop_user_full(UserId user_id);
void on_update_chat_status(Chat *c, ChatId chat_id, DialogParticipantStatus status); void on_update_chat_status(Chat *c, ChatId chat_id, DialogParticipantStatus status);
void on_update_chat_default_permissions(Chat *c, ChatId chat_id, RestrictedRights default_permissions, int32 version); static void on_update_chat_default_permissions(Chat *c, ChatId chat_id, RestrictedRights default_permissions,
int32 version);
void on_update_chat_participant_count(Chat *c, ChatId chat_id, int32 participant_count, int32 version, void on_update_chat_participant_count(Chat *c, ChatId chat_id, int32 participant_count, int32 version,
const string &debug_str); const string &debug_str);
void on_update_chat_photo(Chat *c, ChatId chat_id, tl_object_ptr<telegram_api::ChatPhoto> &&chat_photo_ptr); void on_update_chat_photo(Chat *c, ChatId chat_id, tl_object_ptr<telegram_api::ChatPhoto> &&chat_photo_ptr);
void on_update_chat_title(Chat *c, ChatId chat_id, string &&title); static void on_update_chat_title(Chat *c, ChatId chat_id, string &&title);
void on_update_chat_active(Chat *c, ChatId chat_id, bool is_active); static void on_update_chat_active(Chat *c, ChatId chat_id, bool is_active);
void on_update_chat_migrated_to_channel_id(Chat *c, ChatId chat_id, ChannelId migrated_to_channel_id); static void on_update_chat_migrated_to_channel_id(Chat *c, ChatId chat_id, ChannelId migrated_to_channel_id);
void on_update_chat_full_photo(ChatFull *chat_full, ChatId chat_id, Photo photo); void on_update_chat_full_photo(ChatFull *chat_full, ChatId chat_id, Photo photo);
bool on_update_chat_full_participants_short(ChatFull *chat_full, ChatId chat_id, int32 version); bool on_update_chat_full_participants_short(ChatFull *chat_full, ChatId chat_id, int32 version);
@ -1212,10 +1213,11 @@ class ContactsManager final : public Actor {
void on_update_channel_photo(Channel *c, ChannelId channel_id, void on_update_channel_photo(Channel *c, ChannelId channel_id,
tl_object_ptr<telegram_api::ChatPhoto> &&chat_photo_ptr); tl_object_ptr<telegram_api::ChatPhoto> &&chat_photo_ptr);
void on_update_channel_title(Channel *c, ChannelId channel_id, string &&title); static void on_update_channel_title(Channel *c, ChannelId channel_id, string &&title);
void on_update_channel_username(Channel *c, ChannelId channel_id, string &&username); void on_update_channel_username(Channel *c, ChannelId channel_id, string &&username);
void on_update_channel_status(Channel *c, ChannelId channel_id, DialogParticipantStatus &&status); void on_update_channel_status(Channel *c, ChannelId channel_id, DialogParticipantStatus &&status);
void on_update_channel_default_permissions(Channel *c, ChannelId channel_id, RestrictedRights default_permissions); static void on_update_channel_default_permissions(Channel *c, ChannelId channel_id,
RestrictedRights default_permissions);
void on_update_channel_bot_user_ids(ChannelId channel_id, vector<UserId> &&bot_user_ids); void on_update_channel_bot_user_ids(ChannelId channel_id, vector<UserId> &&bot_user_ids);
@ -1227,8 +1229,9 @@ class ContactsManager final : public Actor {
void on_update_channel_full_location(ChannelFull *channel_full, ChannelId channel_id, const DialogLocation &location); void on_update_channel_full_location(ChannelFull *channel_full, ChannelId channel_id, const DialogLocation &location);
void on_update_channel_full_slow_mode_delay(ChannelFull *channel_full, ChannelId channel_id, int32 slow_mode_delay, void on_update_channel_full_slow_mode_delay(ChannelFull *channel_full, ChannelId channel_id, int32 slow_mode_delay,
int32 slow_mode_next_send_date); int32 slow_mode_next_send_date);
void on_update_channel_full_slow_mode_next_send_date(ChannelFull *channel_full, int32 slow_mode_next_send_date); static void on_update_channel_full_slow_mode_next_send_date(ChannelFull *channel_full,
void on_update_channel_full_bot_user_ids(ChannelFull *channel_full, ChannelId channel_id, int32 slow_mode_next_send_date);
static void on_update_channel_full_bot_user_ids(ChannelFull *channel_full, ChannelId channel_id,
vector<UserId> &&bot_user_ids); vector<UserId> &&bot_user_ids);
void on_channel_status_changed(const Channel *c, ChannelId channel_id, const DialogParticipantStatus &old_status, void on_channel_status_changed(const Channel *c, ChannelId channel_id, const DialogParticipantStatus &old_status,
@ -1243,15 +1246,15 @@ class ContactsManager final : public Actor {
void speculative_add_channel_participant_count(ChannelId channel_id, int32 delta_participant_count, bool by_me); void speculative_add_channel_participant_count(ChannelId channel_id, int32 delta_participant_count, bool by_me);
void speculative_add_channel_user(ChannelId channel_id, UserId user_id, DialogParticipantStatus new_status, void speculative_add_channel_user(ChannelId channel_id, UserId user_id, const DialogParticipantStatus &new_status,
DialogParticipantStatus old_status); const DialogParticipantStatus &old_status);
void drop_chat_photos(ChatId chat_id, bool is_empty, bool drop_chat_full_photo, const char *source); void drop_chat_photos(ChatId chat_id, bool is_empty, bool drop_chat_full_photo, const char *source);
void drop_chat_full(ChatId chat_id); void drop_chat_full(ChatId chat_id);
void drop_channel_photos(ChannelId channel_id, bool is_empty, bool drop_channel_full_photo, const char *source); void drop_channel_photos(ChannelId channel_id, bool is_empty, bool drop_channel_full_photo, const char *source);
void do_invalidate_channel_full(ChannelFull *channel_full, bool need_drop_slow_mode_delay); static void do_invalidate_channel_full(ChannelFull *channel_full, bool need_drop_slow_mode_delay);
void update_user_online_member_count(User *u); void update_user_online_member_count(User *u);
void update_chat_online_member_count(const ChatFull *chat_full, ChatId chat_id, bool is_from_server); void update_chat_online_member_count(const ChatFull *chat_full, ChatId chat_id, bool is_from_server);
@ -1331,7 +1334,7 @@ class ContactsManager final : public Actor {
void update_channel_full(ChannelFull *channel_full, ChannelId channel_id, const char *source, void update_channel_full(ChannelFull *channel_full, ChannelId channel_id, const char *source,
bool from_database = false); bool from_database = false);
bool is_chat_full_outdated(const ChatFull *chat_full, const Chat *c, ChatId chat_id); static bool is_chat_full_outdated(const ChatFull *chat_full, const Chat *c, ChatId chat_id);
bool is_user_contact(const User *u, UserId user_id, bool is_mutual) const; bool is_user_contact(const User *u, UserId user_id, bool is_mutual) const;
@ -1360,8 +1363,8 @@ class ContactsManager final : public Actor {
void on_clear_imported_contacts(vector<Contact> &&contacts, vector<size_t> contacts_unique_id, void on_clear_imported_contacts(vector<Contact> &&contacts, vector<size_t> contacts_unique_id,
std::pair<vector<size_t>, vector<Contact>> &&to_add, Promise<Unit> &&promise); std::pair<vector<size_t>, vector<Contact>> &&to_add, Promise<Unit> &&promise);
void send_update_chat_member(DialogId dialog_id, UserId agent_user_id, int32 date, DialogInviteLink invite_link, void send_update_chat_member(DialogId dialog_id, UserId agent_user_id, int32 date,
const DialogParticipant &old_dialog_participant, const DialogInviteLink &invite_link, const DialogParticipant &old_dialog_participant,
const DialogParticipant &new_dialog_participant); const DialogParticipant &new_dialog_participant);
static vector<td_api::object_ptr<td_api::chatNearby>> get_chats_nearby_object( static vector<td_api::object_ptr<td_api::chatNearby>> get_chats_nearby_object(
@ -1395,8 +1398,8 @@ class ContactsManager final : public Actor {
void add_chat_participant(ChatId chat_id, UserId user_id, int32 forward_limit, Promise<Unit> &&promise); void add_chat_participant(ChatId chat_id, UserId user_id, int32 forward_limit, Promise<Unit> &&promise);
void add_channel_participant(ChannelId channel_id, UserId user_id, Promise<Unit> &&promise, void add_channel_participant(ChannelId channel_id, UserId user_id, const DialogParticipantStatus &old_status,
DialogParticipantStatus old_status); Promise<Unit> &&promise);
void add_channel_participants(ChannelId channel_id, const vector<UserId> &user_ids, Promise<Unit> &&promise); void add_channel_participants(ChannelId channel_id, const vector<UserId> &user_ids, Promise<Unit> &&promise);
@ -1461,7 +1464,7 @@ class ContactsManager final : public Actor {
static td_api::object_ptr<td_api::updateSupergroup> get_update_unknown_supergroup_object(ChannelId channel_id); static td_api::object_ptr<td_api::updateSupergroup> get_update_unknown_supergroup_object(ChannelId channel_id);
tl_object_ptr<td_api::supergroup> get_supergroup_object(ChannelId channel_id, const Channel *c) const; static tl_object_ptr<td_api::supergroup> get_supergroup_object(ChannelId channel_id, const Channel *c);
tl_object_ptr<td_api::supergroupFullInfo> get_supergroup_full_info_object(const ChannelFull *channel_full, tl_object_ptr<td_api::supergroupFullInfo> get_supergroup_full_info_object(const ChannelFull *channel_full,
ChannelId channel_id) const; ChannelId channel_id) const;
@ -1514,11 +1517,11 @@ class ContactsManager final : public Actor {
DialogParticipantStatus status, DialogParticipantStatus old_status, DialogParticipantStatus status, DialogParticipantStatus old_status,
Promise<Unit> &&promise); Promise<Unit> &&promise);
void promote_channel_participant(ChannelId channel_id, UserId user_id, DialogParticipantStatus status, void promote_channel_participant(ChannelId channel_id, UserId user_id, const DialogParticipantStatus &status,
DialogParticipantStatus old_status, Promise<Unit> &&promise); const DialogParticipantStatus &old_status, Promise<Unit> &&promise);
void restrict_channel_participant(ChannelId channel_id, DialogId participant_dialog_id, void restrict_channel_participant(ChannelId channel_id, DialogId participant_dialog_id,
DialogParticipantStatus status, DialogParticipantStatus old_status, DialogParticipantStatus &&status, DialogParticipantStatus &&old_status,
Promise<Unit> &&promise); Promise<Unit> &&promise);
void transfer_channel_ownership(ChannelId channel_id, UserId user_id, void transfer_channel_ownership(ChannelId channel_id, UserId user_id,

View File

@ -214,9 +214,9 @@ void CountryInfoManager::do_get_phone_number_info(string phone_number_prefix, st
})); }));
} }
td_api::object_ptr<td_api::phoneNumberInfo> CountryInfoManager::get_phone_number_info_sync(string language_code, td_api::object_ptr<td_api::phoneNumberInfo> CountryInfoManager::get_phone_number_info_sync(const string &language_code,
string phone_number_prefix) { string phone_number_prefix) {
td::remove_if(phone_number_prefix, [](char c) { return c < '0' || c > '9'; }); td::remove_if(phone_number_prefix, [](char c) { return !is_digit(c); });
if (phone_number_prefix.empty()) { if (phone_number_prefix.empty()) {
return td_api::make_object<td_api::phoneNumberInfo>(nullptr, string(), string()); return td_api::make_object<td_api::phoneNumberInfo>(nullptr, string(), string());
} }
@ -401,7 +401,7 @@ void CountryInfoManager::on_get_country_list_impl(const string &language_code,
info.country_code = std::move(c->iso2_); info.country_code = std::move(c->iso2_);
info.default_name = std::move(c->default_name_); info.default_name = std::move(c->default_name_);
info.name = std::move(c->name_); info.name = std::move(c->name_);
info.is_hidden = std::move(c->hidden_); info.is_hidden = c->hidden_;
for (auto &code : c->country_codes_) { for (auto &code : c->country_codes_) {
auto r_calling_code = to_integer_safe<int32>(code->country_code_); auto r_calling_code = to_integer_safe<int32>(code->country_code_);
if (r_calling_code.is_error() || r_calling_code.ok() <= 0) { if (r_calling_code.is_error() || r_calling_code.ok() <= 0) {

View File

@ -34,7 +34,7 @@ class CountryInfoManager final : public Actor {
void get_phone_number_info(string phone_number_prefix, void get_phone_number_info(string phone_number_prefix,
Promise<td_api::object_ptr<td_api::phoneNumberInfo>> &&promise); Promise<td_api::object_ptr<td_api::phoneNumberInfo>> &&promise);
static td_api::object_ptr<td_api::phoneNumberInfo> get_phone_number_info_sync(string language_code, static td_api::object_ptr<td_api::phoneNumberInfo> get_phone_number_info_sync(const string &language_code,
string phone_number_prefix); string phone_number_prefix);
CountryInfoManager(const CountryInfoManager &) = delete; CountryInfoManager(const CountryInfoManager &) = delete;

View File

@ -129,7 +129,7 @@ StringBuilder &operator<<(StringBuilder &string_builder, const DeviceTokenManage
} }
void DeviceTokenManager::register_device(tl_object_ptr<td_api::DeviceToken> device_token_ptr, void DeviceTokenManager::register_device(tl_object_ptr<td_api::DeviceToken> device_token_ptr,
vector<UserId> other_user_ids, const vector<UserId> &other_user_ids,
Promise<td_api::object_ptr<td_api::pushReceiverId>> promise) { Promise<td_api::object_ptr<td_api::pushReceiverId>> promise) {
CHECK(device_token_ptr != nullptr); CHECK(device_token_ptr != nullptr);
TokenType token_type; TokenType token_type;
@ -259,7 +259,7 @@ void DeviceTokenManager::register_device(tl_object_ptr<td_api::DeviceToken> devi
if (encrypt != info.encrypt) { if (encrypt != info.encrypt) {
if (encrypt) { if (encrypt) {
constexpr size_t ENCRYPTION_KEY_LENGTH = 256; constexpr size_t ENCRYPTION_KEY_LENGTH = 256;
constexpr int64 MIN_ENCRYPTION_KEY_ID = static_cast<int64>(10000000000000ll); constexpr auto MIN_ENCRYPTION_KEY_ID = static_cast<int64>(10000000000000ll);
info.encryption_key.resize(ENCRYPTION_KEY_LENGTH); info.encryption_key.resize(ENCRYPTION_KEY_LENGTH);
while (true) { while (true) {
Random::secure_bytes(info.encryption_key); Random::secure_bytes(info.encryption_key);

View File

@ -26,7 +26,7 @@ class DeviceTokenManager final : public NetQueryCallback {
public: public:
explicit DeviceTokenManager(ActorShared<> parent) : parent_(std::move(parent)) { explicit DeviceTokenManager(ActorShared<> parent) : parent_(std::move(parent)) {
} }
void register_device(tl_object_ptr<td_api::DeviceToken> device_token_ptr, vector<UserId> other_user_ids, void register_device(tl_object_ptr<td_api::DeviceToken> device_token_ptr, const vector<UserId> &other_user_ids,
Promise<td_api::object_ptr<td_api::pushReceiverId>> promise); Promise<td_api::object_ptr<td_api::pushReceiverId>> promise);
void reregister_device(); void reregister_device();

View File

@ -27,7 +27,7 @@ int DhCache::is_good_prime(Slice prime_str) const {
if (value == "bad") { if (value == "bad") {
return 0; return 0;
} }
CHECK(value == ""); CHECK(value.empty());
return -1; return -1;
} }

View File

@ -46,7 +46,7 @@ void DialogAction::init(Type type, string emoji) {
} }
} }
void DialogAction::init(Type type, int32 message_id, string emoji, string data) { void DialogAction::init(Type type, int32 message_id, string emoji, const string &data) {
if (ServerMessageId(message_id).is_valid() && is_valid_emoji(emoji) && check_utf8(data)) { if (ServerMessageId(message_id).is_valid() && is_valid_emoji(emoji) && check_utf8(data)) {
type_ = type; type_ = type;
progress_ = message_id; progress_ = message_id;
@ -199,7 +199,7 @@ DialogAction::DialogAction(telegram_api::object_ptr<telegram_api::SendMessageAct
case telegram_api::sendMessageEmojiInteraction::ID: { case telegram_api::sendMessageEmojiInteraction::ID: {
auto emoji_interaction_action = move_tl_object_as<telegram_api::sendMessageEmojiInteraction>(action); auto emoji_interaction_action = move_tl_object_as<telegram_api::sendMessageEmojiInteraction>(action);
init(Type::ClickingAnimatedEmoji, emoji_interaction_action->msg_id_, init(Type::ClickingAnimatedEmoji, emoji_interaction_action->msg_id_,
std::move(emoji_interaction_action->emoticon_), std::move(emoji_interaction_action->interaction_->data_)); std::move(emoji_interaction_action->emoticon_), emoji_interaction_action->interaction_->data_);
break; break;
} }
default: default:

View File

@ -49,7 +49,7 @@ class DialogAction {
void init(Type type, string emoji); void init(Type type, string emoji);
void init(Type type, int32 message_id, string emoji, string data); void init(Type type, int32 message_id, string emoji, const string &data);
static bool is_valid_emoji(string &emoji); static bool is_valid_emoji(string &emoji);

View File

@ -458,7 +458,7 @@ DialogParticipantStatus get_dialog_participant_status(const tl_object_ptr<td_api
} }
DialogParticipantStatus get_dialog_participant_status(bool can_be_edited, DialogParticipantStatus get_dialog_participant_status(bool can_be_edited,
const tl_object_ptr<telegram_api::chatAdminRights> &admin_rights, tl_object_ptr<telegram_api::chatAdminRights> &&admin_rights,
string rank) { string rank) {
bool can_change_info = (admin_rights->flags_ & telegram_api::chatAdminRights::CHANGE_INFO_MASK) != 0; bool can_change_info = (admin_rights->flags_ & telegram_api::chatAdminRights::CHANGE_INFO_MASK) != 0;
bool can_post_messages = (admin_rights->flags_ & telegram_api::chatAdminRights::POST_MESSAGES_MASK) != 0; bool can_post_messages = (admin_rights->flags_ & telegram_api::chatAdminRights::POST_MESSAGES_MASK) != 0;
@ -480,8 +480,8 @@ DialogParticipantStatus get_dialog_participant_status(bool can_be_edited,
can_pin_messages, can_promote_members, can_manage_calls); can_pin_messages, can_promote_members, can_manage_calls);
} }
DialogParticipantStatus get_dialog_participant_status( DialogParticipantStatus get_dialog_participant_status(bool is_member,
bool is_member, const tl_object_ptr<telegram_api::chatBannedRights> &banned_rights) { tl_object_ptr<telegram_api::chatBannedRights> &&banned_rights) {
bool can_view_messages = (banned_rights->flags_ & telegram_api::chatBannedRights::VIEW_MESSAGES_MASK) == 0; bool can_view_messages = (banned_rights->flags_ & telegram_api::chatBannedRights::VIEW_MESSAGES_MASK) == 0;
if (!can_view_messages) { if (!can_view_messages) {
return DialogParticipantStatus::Banned(banned_rights->until_date_); return DialogParticipantStatus::Banned(banned_rights->until_date_);
@ -616,7 +616,7 @@ StringBuilder &operator<<(StringBuilder &string_builder, const RestrictedRights
return string_builder; return string_builder;
} }
RestrictedRights get_restricted_rights(const tl_object_ptr<telegram_api::chatBannedRights> &banned_rights) { RestrictedRights get_restricted_rights(tl_object_ptr<telegram_api::chatBannedRights> &&banned_rights) {
if (banned_rights == nullptr) { if (banned_rights == nullptr) {
return RestrictedRights(false, false, false, false, false, false, false, false, false, false, false); return RestrictedRights(false, false, false, false, false, false, false, false, false, false, false);
} }
@ -657,14 +657,14 @@ RestrictedRights get_restricted_rights(const td_api::object_ptr<td_api::chatPerm
DialogParticipant::DialogParticipant(DialogId dialog_id, UserId inviter_user_id, int32 joined_date, DialogParticipant::DialogParticipant(DialogId dialog_id, UserId inviter_user_id, int32 joined_date,
DialogParticipantStatus status) DialogParticipantStatus status)
: dialog_id(dialog_id), inviter_user_id(inviter_user_id), joined_date(joined_date), status(status) { : dialog_id(dialog_id), inviter_user_id(inviter_user_id), joined_date(joined_date), status(std::move(status)) {
if (!inviter_user_id.is_valid() && inviter_user_id != UserId()) { if (!inviter_user_id.is_valid() && inviter_user_id != UserId()) {
LOG(ERROR) << "Receive inviter " << inviter_user_id; LOG(ERROR) << "Receive inviter " << inviter_user_id;
inviter_user_id = UserId(); this->inviter_user_id = UserId();
} }
if (joined_date < 0) { if (joined_date < 0) {
LOG(ERROR) << "Receive date " << joined_date; LOG(ERROR) << "Receive date " << joined_date;
joined_date = 0; this->joined_date = 0;
} }
} }

View File

@ -397,7 +397,7 @@ struct DialogParticipant {
DialogParticipant() = default; DialogParticipant() = default;
DialogParticipant(DialogId user_id, UserId inviter_user_id, int32 joined_date, DialogParticipantStatus status); DialogParticipant(DialogId dialog_id, UserId inviter_user_id, int32 joined_date, DialogParticipantStatus status);
DialogParticipant(tl_object_ptr<telegram_api::ChatParticipant> &&participant_ptr, int32 chat_creation_date, DialogParticipant(tl_object_ptr<telegram_api::ChatParticipant> &&participant_ptr, int32 chat_creation_date,
bool is_creator); bool is_creator);
@ -508,13 +508,13 @@ DialogParticipantsFilter get_dialog_participants_filter(const tl_object_ptr<td_a
DialogParticipantStatus get_dialog_participant_status(const tl_object_ptr<td_api::ChatMemberStatus> &status); DialogParticipantStatus get_dialog_participant_status(const tl_object_ptr<td_api::ChatMemberStatus> &status);
DialogParticipantStatus get_dialog_participant_status(bool can_be_edited, DialogParticipantStatus get_dialog_participant_status(bool can_be_edited,
const tl_object_ptr<telegram_api::chatAdminRights> &admin_rights, tl_object_ptr<telegram_api::chatAdminRights> &&admin_rights,
string rank); string rank);
DialogParticipantStatus get_dialog_participant_status( DialogParticipantStatus get_dialog_participant_status(bool is_member,
bool is_member, const tl_object_ptr<telegram_api::chatBannedRights> &banned_rights); tl_object_ptr<telegram_api::chatBannedRights> &&banned_rights);
RestrictedRights get_restricted_rights(const tl_object_ptr<telegram_api::chatBannedRights> &banned_rights); RestrictedRights get_restricted_rights(tl_object_ptr<telegram_api::chatBannedRights> &&banned_rights);
RestrictedRights get_restricted_rights(const td_api::object_ptr<td_api::chatPermissions> &permissions); RestrictedRights get_restricted_rights(const td_api::object_ptr<td_api::chatPermissions> &permissions);

View File

@ -573,7 +573,7 @@ SecretInputMedia DocumentsManager::get_secret_input_media(FileId document_file_i
return SecretInputMedia{}; return SecretInputMedia{};
} }
vector<tl_object_ptr<secret_api::DocumentAttribute>> attributes; vector<tl_object_ptr<secret_api::DocumentAttribute>> attributes;
if (document->file_name.size()) { if (!document->file_name.empty()) {
attributes.push_back(make_tl_object<secret_api::documentAttributeFilename>(document->file_name)); attributes.push_back(make_tl_object<secret_api::documentAttributeFilename>(document->file_name));
} }
return SecretInputMedia{ return SecretInputMedia{
@ -604,7 +604,7 @@ tl_object_ptr<telegram_api::InputMedia> DocumentsManager::get_input_media(
CHECK(document != nullptr); CHECK(document != nullptr);
vector<tl_object_ptr<telegram_api::DocumentAttribute>> attributes; vector<tl_object_ptr<telegram_api::DocumentAttribute>> attributes;
if (document->file_name.size()) { if (!document->file_name.empty()) {
attributes.push_back(make_tl_object<telegram_api::documentAttributeFilename>(document->file_name)); attributes.push_back(make_tl_object<telegram_api::documentAttributeFilename>(document->file_name));
} }
int32 flags = 0; int32 flags = 0;

View File

@ -54,7 +54,8 @@ class FileReferenceManager final : public Actor {
using NodeId = FileId; using NodeId = FileId;
void repair_file_reference(NodeId node_id, Promise<> promise); void repair_file_reference(NodeId node_id, Promise<> promise);
void reload_photo(PhotoSizeSource source, Promise<Unit> promise);
static void reload_photo(PhotoSizeSource source, Promise<Unit> promise);
bool add_file_source(NodeId node_id, FileSourceId file_source_id); bool add_file_source(NodeId node_id, FileSourceId file_source_id);

View File

@ -369,7 +369,7 @@ class Global final : public ActorContext {
void set_dh_config(std::shared_ptr<DhConfig> new_dh_config) { void set_dh_config(std::shared_ptr<DhConfig> new_dh_config) {
#if !TD_HAVE_ATOMIC_SHARED_PTR #if !TD_HAVE_ATOMIC_SHARED_PTR
std::lock_guard<std::mutex> guard(dh_config_mutex_); std::lock_guard<std::mutex> guard(dh_config_mutex_);
dh_config_ = new_dh_config; dh_config_ = std::move(new_dh_config);
#else #else
atomic_store(&dh_config_, std::move(new_dh_config)); atomic_store(&dh_config_, std::move(new_dh_config));
#endif #endif

View File

@ -1749,6 +1749,7 @@ void GroupCallManager::on_update_group_call_participants(
}); });
td_->create_handler<GetGroupCallParticipantQuery>(std::move(query_promise)) td_->create_handler<GetGroupCallParticipantQuery>(std::move(query_promise))
->send(input_group_call_id, std::move(input_peers), {}); ->send(input_group_call_id, std::move(input_peers), {});
return;
} }
} }
@ -1961,8 +1962,9 @@ void GroupCallManager::on_sync_group_call_participants(InputGroupCallId input_gr
} }
} }
GroupCallParticipantOrder GroupCallManager::get_real_participant_order( GroupCallParticipantOrder GroupCallManager::get_real_participant_order(bool can_self_unmute,
bool can_self_unmute, const GroupCallParticipant &participant, const GroupCallParticipants *participants) const { const GroupCallParticipant &participant,
const GroupCallParticipants *participants) {
auto real_order = participant.get_real_order(can_self_unmute, participants->joined_date_asc, false); auto real_order = participant.get_real_order(can_self_unmute, participants->joined_date_asc, false);
if (real_order >= participants->min_order) { if (real_order >= participants->min_order) {
return real_order; return real_order;
@ -4091,7 +4093,7 @@ InputGroupCallId GroupCallManager::update_group_call(const tl_object_ptr<telegra
auto group_call = static_cast<const telegram_api::groupCall *>(group_call_ptr.get()); auto group_call = static_cast<const telegram_api::groupCall *>(group_call_ptr.get());
input_group_call_id = InputGroupCallId(group_call->id_, group_call->access_hash_); input_group_call_id = InputGroupCallId(group_call->id_, group_call->access_hash_);
call.is_active = true; call.is_active = true;
call.title = std::move(group_call->title_); call.title = group_call->title_;
call.start_subscribed = group_call->schedule_start_subscribed_; call.start_subscribed = group_call->schedule_start_subscribed_;
call.mute_new_participants = group_call->join_muted_; call.mute_new_participants = group_call->join_muted_;
call.joined_date_asc = group_call->join_date_asc_; call.joined_date_asc = group_call->join_date_asc_;
@ -4465,8 +4467,10 @@ void GroupCallManager::remove_recent_group_call_speaker(InputGroupCallId input_g
void GroupCallManager::on_group_call_recent_speakers_updated(const GroupCall *group_call, void GroupCallManager::on_group_call_recent_speakers_updated(const GroupCall *group_call,
GroupCallRecentSpeakers *recent_speakers) { GroupCallRecentSpeakers *recent_speakers) {
if (group_call == nullptr || !group_call->is_inited || recent_speakers->is_changed) { if (group_call == nullptr || !group_call->is_inited || recent_speakers->is_changed) {
if (group_call != nullptr) {
LOG(INFO) << "Don't need to send update of recent speakers in " << group_call->group_call_id << " from " LOG(INFO) << "Don't need to send update of recent speakers in " << group_call->group_call_id << " from "
<< group_call->dialog_id; << group_call->dialog_id;
}
return; return;
} }
@ -4662,12 +4666,12 @@ vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> GroupCallManager::get
} }
tl_object_ptr<td_api::groupCall> GroupCallManager::get_group_call_object( tl_object_ptr<td_api::groupCall> GroupCallManager::get_group_call_object(
const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers) const { const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers) {
CHECK(group_call != nullptr); CHECK(group_call != nullptr);
CHECK(group_call->is_inited); CHECK(group_call->is_inited);
int32 scheduled_start_date = group_call->scheduled_start_date; int32 scheduled_start_date = group_call->scheduled_start_date;
bool is_active = scheduled_start_date == 0 ? group_call->is_active : 0; bool is_active = scheduled_start_date == 0 ? group_call->is_active : false;
bool is_joined = group_call->is_joined && !group_call->is_being_left; bool is_joined = group_call->is_joined && !group_call->is_being_left;
bool start_subscribed = get_group_call_start_subscribed(group_call); bool start_subscribed = get_group_call_start_subscribed(group_call);
bool is_my_video_enabled = get_group_call_is_my_video_enabled(group_call); bool is_my_video_enabled = get_group_call_is_my_video_enabled(group_call);
@ -4688,7 +4692,7 @@ tl_object_ptr<td_api::groupCall> GroupCallManager::get_group_call_object(
} }
tl_object_ptr<td_api::updateGroupCall> GroupCallManager::get_update_group_call_object( tl_object_ptr<td_api::updateGroupCall> GroupCallManager::get_update_group_call_object(
const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers) const { const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers) {
return td_api::make_object<td_api::updateGroupCall>(get_group_call_object(group_call, std::move(recent_speakers))); return td_api::make_object<td_api::updateGroupCall>(get_group_call_object(group_call, std::move(recent_speakers)));
} }

View File

@ -233,8 +233,9 @@ class GroupCallManager final : public Actor {
void on_sync_group_call_participants(InputGroupCallId input_group_call_id, void on_sync_group_call_participants(InputGroupCallId input_group_call_id,
Result<tl_object_ptr<telegram_api::phone_groupCall>> &&result); Result<tl_object_ptr<telegram_api::phone_groupCall>> &&result);
GroupCallParticipantOrder get_real_participant_order(bool can_self_unmute, const GroupCallParticipant &participant, static GroupCallParticipantOrder get_real_participant_order(bool can_self_unmute,
const GroupCallParticipants *participants) const; const GroupCallParticipant &participant,
const GroupCallParticipants *participants);
void process_my_group_call_participant(InputGroupCallId input_group_call_id, GroupCallParticipant &&participant); void process_my_group_call_participant(InputGroupCallId input_group_call_id, GroupCallParticipant &&participant);
@ -242,7 +243,7 @@ class GroupCallManager final : public Actor {
vector<tl_object_ptr<telegram_api::groupCallParticipant>> &&participants, vector<tl_object_ptr<telegram_api::groupCallParticipant>> &&participants,
int32 version, const string &offset, bool is_load, bool is_sync); int32 version, const string &offset, bool is_load, bool is_sync);
bool update_group_call_participant_can_be_muted(bool can_manage, const GroupCallParticipants *participants, static bool update_group_call_participant_can_be_muted(bool can_manage, const GroupCallParticipants *participants,
GroupCallParticipant &participant); GroupCallParticipant &participant);
void update_group_call_participants_can_be_muted(InputGroupCallId input_group_call_id, bool can_manage, void update_group_call_participants_can_be_muted(InputGroupCallId input_group_call_id, bool can_manage,
@ -358,11 +359,11 @@ class GroupCallManager final : public Actor {
vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> get_recent_speakers(const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> get_recent_speakers(const GroupCall *group_call,
bool for_update); bool for_update);
tl_object_ptr<td_api::updateGroupCall> get_update_group_call_object( static tl_object_ptr<td_api::updateGroupCall> get_update_group_call_object(
const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers) const; const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers);
tl_object_ptr<td_api::groupCall> get_group_call_object( static tl_object_ptr<td_api::groupCall> get_group_call_object(
const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers) const; const GroupCall *group_call, vector<td_api::object_ptr<td_api::groupCallRecentSpeaker>> recent_speakers);
tl_object_ptr<td_api::updateGroupCallParticipant> get_update_group_call_participant_object( tl_object_ptr<td_api::updateGroupCallParticipant> get_update_group_call_participant_object(
GroupCallId group_call_id, const GroupCallParticipant &participant); GroupCallId group_call_id, const GroupCallParticipant &participant);

View File

@ -20,7 +20,7 @@ GroupCallParticipant::GroupCallParticipant(const tl_object_ptr<telegram_api::gro
int32 call_version) { int32 call_version) {
CHECK(participant != nullptr); CHECK(participant != nullptr);
dialog_id = DialogId(participant->peer_); dialog_id = DialogId(participant->peer_);
about = std::move(participant->about_); about = participant->about_;
audio_source = participant->source_; audio_source = participant->source_;
server_is_muted_by_themselves = participant->can_self_unmute_; server_is_muted_by_themselves = participant->can_self_unmute_;
server_is_muted_by_admin = participant->muted_ && !participant->can_self_unmute_; server_is_muted_by_admin = participant->muted_ && !participant->can_self_unmute_;

View File

@ -487,7 +487,11 @@ void InlineQueriesManager::answer_inline_query(int64 inline_query_id, bool is_pe
if (first_name.empty()) { if (first_name.empty()) {
return promise.set_error(Status::Error(400, "Field \"first_name\" must be non-empty")); return promise.set_error(Status::Error(400, "Field \"first_name\" must be non-empty"));
} }
title = last_name.empty() ? first_name : first_name + " " + last_name; if (last_name.empty()) {
title = std::move(first_name);
} else {
title = PSTRING() << first_name << ' ' << last_name;
}
description = std::move(phone_number); description = std::move(phone_number);
thumbnail_url = std::move(contact->thumbnail_url_); thumbnail_url = std::move(contact->thumbnail_url_);
if (!thumbnail_url.empty()) { if (!thumbnail_url.empty()) {
@ -1459,7 +1463,7 @@ void InlineQueriesManager::on_get_inline_query_results(DialogId dialog_id, UserI
if (result->type_ == "article") { if (result->type_ == "article") {
auto article = make_tl_object<td_api::inlineQueryResultArticle>(); auto article = make_tl_object<td_api::inlineQueryResultArticle>();
article->id_ = std::move(result->id_); article->id_ = std::move(result->id_);
article->url_ = get_web_document_url(std::move(result->content_)); article->url_ = get_web_document_url(result->content_);
if (result->url_.empty()) { if (result->url_.empty()) {
article->hide_url_ = true; article->hide_url_ = true;
} else { } else {

View File

@ -220,7 +220,7 @@ int32 get_json_value_int(telegram_api::object_ptr<telegram_api::JSONValue> &&jso
string get_json_value_string(telegram_api::object_ptr<telegram_api::JSONValue> &&json_value, Slice name) { string get_json_value_string(telegram_api::object_ptr<telegram_api::JSONValue> &&json_value, Slice name) {
CHECK(json_value != nullptr); CHECK(json_value != nullptr);
if (json_value->get_id() == telegram_api::jsonString::ID) { if (json_value->get_id() == telegram_api::jsonString::ID) {
return std::move(static_cast<const telegram_api::jsonString *>(json_value.get())->value_); return std::move(static_cast<telegram_api::jsonString *>(json_value.get())->value_);
} }
LOG(ERROR) << "Expected String as " << name << ", but found " << to_string(json_value); LOG(ERROR) << "Expected String as " << name << ", but found " << to_string(json_value);
return string(); return string();

View File

@ -170,7 +170,7 @@ static string load_database_language_base_language_code(SqliteKeyValue *kv) {
return kv->get("!base_language_code"); return kv->get("!base_language_code");
} }
LanguagePackManager::LanguageDatabase *LanguagePackManager::add_language_database(const string &path) { LanguagePackManager::LanguageDatabase *LanguagePackManager::add_language_database(string path) {
auto it = language_databases_.find(path); auto it = language_databases_.find(path);
if (it != language_databases_.end()) { if (it != language_databases_.end()) {
return it->second.get(); return it->second.get();
@ -395,11 +395,11 @@ void LanguagePackManager::on_language_pack_version_changed(bool is_base, int32 n
LOG(INFO) << (is_base ? "Base" : "Main") << " language pack " << language_code << " vesrion has changed to " LOG(INFO) << (is_base ? "Base" : "Main") << " language pack " << language_code << " vesrion has changed to "
<< new_version; << new_version;
send_language_get_difference_query(language, language_code, version, Auto()); send_language_get_difference_query(language, std::move(language_code), version, Auto());
} }
void LanguagePackManager::send_language_get_difference_query(Language *language, const string &language_code, void LanguagePackManager::send_language_get_difference_query(Language *language, string language_code, int32 version,
int32 version, Promise<Unit> &&promise) { Promise<Unit> &&promise) {
std::lock_guard<std::mutex> lock(language->mutex_); std::lock_guard<std::mutex> lock(language->mutex_);
language->get_difference_queries_.push_back(std::move(promise)); language->get_difference_queries_.push_back(std::move(promise));
if (language->has_get_difference_query_) { if (language->has_get_difference_query_) {
@ -1179,7 +1179,7 @@ void LanguagePackManager::synchronize_language_pack(string language_code, Promis
if (version == -1) { if (version == -1) {
version = 0; version = 0;
} }
send_language_get_difference_query(language, language_code, version, std::move(promise)); send_language_get_difference_query(language, std::move(language_code), version, std::move(promise));
} }
static td_api::object_ptr<td_api::LanguagePackStringValue> copy_language_pack_string_value( static td_api::object_ptr<td_api::LanguagePackStringValue> copy_language_pack_string_value(
@ -1294,7 +1294,7 @@ bool LanguagePackManager::is_valid_key(Slice key) {
} }
void LanguagePackManager::save_strings_to_database(SqliteKeyValue *kv, int32 new_version, bool new_is_full, void LanguagePackManager::save_strings_to_database(SqliteKeyValue *kv, int32 new_version, bool new_is_full,
int32 new_key_count, vector<std::pair<string, string>> strings) { int32 new_key_count, vector<std::pair<string, string>> &&strings) {
LOG(DEBUG) << "Save to database a language pack with new version " << new_version << " and " << strings.size() LOG(DEBUG) << "Save to database a language pack with new version " << new_version << " and " << strings.size()
<< " new strings"; << " new strings";
if (new_version == -1 && strings.empty()) { if (new_version == -1 && strings.empty()) {
@ -1314,7 +1314,7 @@ void LanguagePackManager::save_strings_to_database(SqliteKeyValue *kv, int32 new
} }
kv->begin_write_transaction().ensure(); kv->begin_write_transaction().ensure();
for (auto str : strings) { for (const auto &str : strings) {
if (!is_valid_key(str.first)) { if (!is_valid_key(str.first)) {
LOG(ERROR) << "Have invalid key \"" << str.first << '"'; LOG(ERROR) << "Have invalid key \"" << str.first << '"';
continue; continue;
@ -1339,7 +1339,7 @@ void LanguagePackManager::save_strings_to_database(SqliteKeyValue *kv, int32 new
} }
void LanguagePackManager::on_get_language_pack_strings( void LanguagePackManager::on_get_language_pack_strings(
string language_pack, string language_code, int32 version, bool is_diff, vector<string> keys, string language_pack, string language_code, int32 version, bool is_diff, vector<string> &&keys,
vector<tl_object_ptr<telegram_api::LangPackString>> results, vector<tl_object_ptr<telegram_api::LangPackString>> results,
Promise<td_api::object_ptr<td_api::languagePackStrings>> promise) { Promise<td_api::object_ptr<td_api::languagePackStrings>> promise) {
Language *language = get_language(database_, language_pack, language_code); Language *language = get_language(database_, language_pack, language_code);
@ -1370,7 +1370,7 @@ void LanguagePackManager::on_get_language_pack_strings(
CHECK(result != nullptr); CHECK(result != nullptr);
switch (result->get_id()) { switch (result->get_id()) {
case telegram_api::langPackString::ID: { case telegram_api::langPackString::ID: {
auto str = static_cast<telegram_api::langPackString *>(result.get()); auto str = telegram_api::move_object_as<telegram_api::langPackString>(result);
auto it = language->ordinary_strings_.find(str->key_); auto it = language->ordinary_strings_.find(str->key_);
if (it == language->ordinary_strings_.end()) { if (it == language->ordinary_strings_.end()) {
key_count_delta++; key_count_delta++;
@ -1383,11 +1383,11 @@ void LanguagePackManager::on_get_language_pack_strings(
if (is_diff) { if (is_diff) {
strings.push_back(get_language_pack_string_object(*it)); strings.push_back(get_language_pack_string_object(*it));
} }
database_strings.emplace_back(str->key_, PSTRING() << '1' << it->second); database_strings.emplace_back(std::move(str->key_), PSTRING() << '1' << it->second);
break; break;
} }
case telegram_api::langPackStringPluralized::ID: { case telegram_api::langPackStringPluralized::ID: {
auto str = static_cast<const telegram_api::langPackStringPluralized *>(result.get()); auto str = telegram_api::move_object_as<telegram_api::langPackStringPluralized>(result);
PluralizedString value{std::move(str->zero_value_), std::move(str->one_value_), PluralizedString value{std::move(str->zero_value_), std::move(str->one_value_),
std::move(str->two_value_), std::move(str->few_value_), std::move(str->two_value_), std::move(str->few_value_),
std::move(str->many_value_), std::move(str->other_value_)}; std::move(str->many_value_), std::move(str->other_value_)};
@ -1404,20 +1404,21 @@ void LanguagePackManager::on_get_language_pack_strings(
strings.push_back(get_language_pack_string_object(*it)); strings.push_back(get_language_pack_string_object(*it));
} }
database_strings.emplace_back( database_strings.emplace_back(
str->key_, PSTRING() << '2' << it->second.zero_value_ << '\x00' << it->second.one_value_ << '\x00' std::move(str->key_), PSTRING()
<< '2' << it->second.zero_value_ << '\x00' << it->second.one_value_ << '\x00'
<< it->second.two_value_ << '\x00' << it->second.few_value_ << '\x00' << it->second.two_value_ << '\x00' << it->second.few_value_ << '\x00'
<< it->second.many_value_ << '\x00' << it->second.other_value_); << it->second.many_value_ << '\x00' << it->second.other_value_);
break; break;
} }
case telegram_api::langPackStringDeleted::ID: { case telegram_api::langPackStringDeleted::ID: {
auto str = static_cast<const telegram_api::langPackStringDeleted *>(result.get()); auto str = telegram_api::move_object_as<telegram_api::langPackStringDeleted>(result);
key_count_delta -= static_cast<int32>(language->ordinary_strings_.erase(str->key_)); key_count_delta -= static_cast<int32>(language->ordinary_strings_.erase(str->key_));
key_count_delta -= static_cast<int32>(language->pluralized_strings_.erase(str->key_)); key_count_delta -= static_cast<int32>(language->pluralized_strings_.erase(str->key_));
language->deleted_strings_.insert(std::move(str->key_)); language->deleted_strings_.insert(str->key_);
if (is_diff) { if (is_diff) {
strings.push_back(get_language_pack_string_object(str->key_)); strings.push_back(get_language_pack_string_object(str->key_));
} }
database_strings.emplace_back(str->key_, "3"); database_strings.emplace_back(std::move(str->key_), "3");
break; break;
} }
default: default:
@ -1426,7 +1427,7 @@ void LanguagePackManager::on_get_language_pack_strings(
} }
} }
if (!language->is_full_) { if (!language->is_full_) {
for (auto &key : keys) { for (const auto &key : keys) {
if (!language_has_string_unsafe(language, key)) { if (!language_has_string_unsafe(language, key)) {
LOG(ERROR) << "Doesn't receive key " << key << " from server"; LOG(ERROR) << "Doesn't receive key " << key << " from server";
language->deleted_strings_.insert(key); language->deleted_strings_.insert(key);
@ -1822,7 +1823,7 @@ void LanguagePackManager::delete_language(string language_code, Promise<Unit> &&
} }
} }
Status LanguagePackManager::do_delete_language(string language_code) { Status LanguagePackManager::do_delete_language(const string &language_code) {
add_language(database_, language_pack_, language_code); add_language(database_, language_pack_, language_code);
std::lock_guard<std::mutex> packs_lock(database_->mutex_); std::lock_guard<std::mutex> packs_lock(database_->mutex_);

View File

@ -108,7 +108,7 @@ class LanguagePackManager final : public NetQueryCallback {
static std::mutex language_database_mutex_; static std::mutex language_database_mutex_;
static std::unordered_map<string, unique_ptr<LanguageDatabase>> language_databases_; static std::unordered_map<string, unique_ptr<LanguageDatabase>> language_databases_;
static LanguageDatabase *add_language_database(const string &path); static LanguageDatabase *add_language_database(string path);
static Language *get_language(LanguageDatabase *database, const string &language_pack, const string &language_code); static Language *get_language(LanguageDatabase *database, const string &language_pack, const string &language_code);
static Language *get_language(LanguagePack *language_pack, const string &language_code); static Language *get_language(LanguagePack *language_pack, const string &language_code);
@ -160,25 +160,25 @@ class LanguagePackManager final : public NetQueryCallback {
static bool is_valid_key(Slice key); static bool is_valid_key(Slice key);
void save_strings_to_database(SqliteKeyValue *kv, int32 new_version, bool new_is_full, int32 new_key_count, void save_strings_to_database(SqliteKeyValue *kv, int32 new_version, bool new_is_full, int32 new_key_count,
vector<std::pair<string, string>> strings); vector<std::pair<string, string>> &&strings);
void load_empty_language_pack(const string &language_code); void load_empty_language_pack(const string &language_code);
void on_get_language_pack_strings(string language_pack, string language_code, int32 version, bool is_diff, void on_get_language_pack_strings(string language_pack, string language_code, int32 version, bool is_diff,
vector<string> keys, vector<tl_object_ptr<telegram_api::LangPackString>> results, vector<string> &&keys, vector<tl_object_ptr<telegram_api::LangPackString>> results,
Promise<td_api::object_ptr<td_api::languagePackStrings>> promise); Promise<td_api::object_ptr<td_api::languagePackStrings>> promise);
void on_get_all_language_pack_strings(string language_pack, string language_code, void on_get_all_language_pack_strings(string language_pack, string language_code,
Result<td_api::object_ptr<td_api::languagePackStrings>> r_strings); Result<td_api::object_ptr<td_api::languagePackStrings>> r_strings);
void send_language_get_difference_query(Language *language, const string &language_code, int32 version, void send_language_get_difference_query(Language *language, string language_code, int32 version,
Promise<Unit> &&promise); Promise<Unit> &&promise);
void on_failed_get_difference(string language_pack, string language_code, Status error); void on_failed_get_difference(string language_pack, string language_code, Status error);
void on_get_language_info(const string &language_pack, td_api::languagePackInfo *language_pack_info); void on_get_language_info(const string &language_pack, td_api::languagePackInfo *language_pack_info);
void save_server_language_pack_infos(LanguagePack *pack); static void save_server_language_pack_infos(LanguagePack *pack);
void on_get_languages(vector<tl_object_ptr<telegram_api::langPackLanguage>> languages, string language_pack, void on_get_languages(vector<tl_object_ptr<telegram_api::langPackLanguage>> languages, string language_pack,
bool only_local, Promise<td_api::object_ptr<td_api::localizationTargetInfo>> promise); bool only_local, Promise<td_api::object_ptr<td_api::localizationTargetInfo>> promise);
@ -186,7 +186,7 @@ class LanguagePackManager final : public NetQueryCallback {
void on_get_language(tl_object_ptr<telegram_api::langPackLanguage> lang_pack_language, string language_pack, void on_get_language(tl_object_ptr<telegram_api::langPackLanguage> lang_pack_language, string language_pack,
string language_code, Promise<td_api::object_ptr<td_api::languagePackInfo>> promise); string language_code, Promise<td_api::object_ptr<td_api::languagePackInfo>> promise);
Status do_delete_language(string language_code); Status do_delete_language(const string &language_code);
void on_result(NetQueryPtr query) final; void on_result(NetQueryPtr query) final;

View File

@ -77,7 +77,7 @@ static string get_url_query_hash(bool is_tg, const HttpUrlQuery &url_query) {
// /joinchat/<link> // /joinchat/<link>
return path[1]; return path[1];
} }
if (path.size() >= 1 && path[0].size() >= 2 && (path[0][0] == ' ' || path[0][0] == '+')) { if (!path.empty() && path[0].size() >= 2 && (path[0][0] == ' ' || path[0][0] == '+')) {
// /+<link> // /+<link>
return path[0].substr(1); return path[0].substr(1);
} }
@ -811,7 +811,7 @@ unique_ptr<LinkManager::InternalLink> LinkManager::parse_tg_link_query(Slice que
} else if (path.size() == 1 && path[0] == "passport") { } else if (path.size() == 1 && path[0] == "passport") {
// passport?bot_id=<bot_user_id>&scope=<scope>&public_key=<public_key>&nonce=<nonce> // passport?bot_id=<bot_user_id>&scope=<scope>&public_key=<public_key>&nonce=<nonce>
return get_internal_link_passport(query, url_query.args_); return get_internal_link_passport(query, url_query.args_);
} else if (path.size() >= 1 && path[0] == "settings") { } else if (!path.empty() && path[0] == "settings") {
if (path.size() == 2 && path[1] == "change_number") { if (path.size() == 2 && path[1] == "change_number") {
// settings/change_number // settings/change_number
return td::make_unique<InternalLinkChangePhoneNumber>(); return td::make_unique<InternalLinkChangePhoneNumber>();

View File

@ -34,7 +34,7 @@ class Location {
void init(double latitude, double longitude, double horizontal_accuracy, int64 access_hash); void init(double latitude, double longitude, double horizontal_accuracy, int64 access_hash);
double fix_accuracy(double accuracy); static double fix_accuracy(double accuracy);
public: public:
Location() = default; Location() = default;

File diff suppressed because it is too large Load Diff

View File

@ -1595,7 +1595,7 @@ static void fix_entity_offsets(Slice text, vector<MessageEntity> &entities) {
auto entity_begin = entity.offset; auto entity_begin = entity.offset;
auto entity_end = entity.offset + entity.length; auto entity_end = entity.offset + entity.length;
int32 pos = static_cast<int32>(ptr - begin); auto pos = static_cast<int32>(ptr - begin);
if (entity_begin == pos) { if (entity_begin == pos) {
cnt--; cnt--;
entity.offset = utf16_pos; entity.offset = utf16_pos;
@ -3631,7 +3631,7 @@ static Result<string> clean_input_string_with_entities(const string &text, vecto
utf16_offset += 1 + (c >= 0xf0); // >= 4 bytes in symbol => surrogate pair utf16_offset += 1 + (c >= 0xf0); // >= 4 bytes in symbol => surrogate pair
} }
if (c == 0xe2 && pos + 2 < text_size) { if (c == 0xe2 && pos + 2 < text_size) {
unsigned char next = static_cast<unsigned char>(text[pos + 1]); auto next = static_cast<unsigned char>(text[pos + 1]);
if (next == 0x80) { if (next == 0x80) {
next = static_cast<unsigned char>(text[pos + 2]); next = static_cast<unsigned char>(text[pos + 2]);
if (0xa8 <= next && next <= 0xae) { if (0xa8 <= next && next <= 0xae) {
@ -3642,7 +3642,7 @@ static Result<string> clean_input_string_with_entities(const string &text, vecto
} }
} }
if (c == 0xcc && pos + 1 < text_size) { if (c == 0xcc && pos + 1 < text_size) {
unsigned char next = static_cast<unsigned char>(text[pos + 1]); auto next = static_cast<unsigned char>(text[pos + 1]);
// remove vertical lines // remove vertical lines
if (next == 0xb3 || next == 0xbf || next == 0x8a) { if (next == 0xb3 || next == 0xbf || next == 0x8a) {
pos++; pos++;
@ -4010,7 +4010,7 @@ Status fix_formatted_text(string &text, vector<MessageEntity> &entities, bool al
first_non_whitespaces_pos++; first_non_whitespaces_pos++;
} }
if (first_non_whitespaces_pos > 0) { if (first_non_whitespaces_pos > 0) {
int32 offset = narrow_cast<int32>(first_non_whitespaces_pos); auto offset = narrow_cast<int32>(first_non_whitespaces_pos);
text = result.substr(first_non_whitespaces_pos); text = result.substr(first_non_whitespaces_pos);
for (auto &entity : entities) { for (auto &entity : entities) {
entity.offset -= offset; entity.offset -= offset;

View File

@ -902,7 +902,7 @@ class MessagesDbImpl final : public MessagesDbSyncInterface {
return std::move(right); return std::move(right);
} }
Result<vector<MessagesDbDialogMessage>> get_messages_inner(SqliteStatement &stmt, DialogId dialog_id, static Result<vector<MessagesDbDialogMessage>> get_messages_inner(SqliteStatement &stmt, DialogId dialog_id,
int64 from_message_id, int32 limit) { int64 from_message_id, int32 limit) {
SCOPE_EXIT { SCOPE_EXIT {
stmt.reset(); stmt.reset();

View File

@ -150,7 +150,7 @@ class UpdateDialogFiltersOrderQuery final : public Td::ResultHandler {
explicit UpdateDialogFiltersOrderQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) { explicit UpdateDialogFiltersOrderQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
} }
void send(vector<DialogFilterId> dialog_filter_ids) { void send(const vector<DialogFilterId> &dialog_filter_ids) {
send_query(G()->net_query_creator().create(telegram_api::messages_updateDialogFiltersOrder( send_query(G()->net_query_creator().create(telegram_api::messages_updateDialogFiltersOrder(
transform(dialog_filter_ids, [](auto dialog_filter_id) { return dialog_filter_id.get(); })))); transform(dialog_filter_ids, [](auto dialog_filter_id) { return dialog_filter_id.get(); }))));
} }
@ -495,7 +495,7 @@ class GetChannelMessagesQuery final : public Td::ResultHandler {
} }
} }
} }
td->messages_manager_->on_get_empty_messages(DialogId(channel_id_), std::move(empty_message_ids)); td->messages_manager_->on_get_empty_messages(DialogId(channel_id_), empty_message_ids);
} }
td->messages_manager_->get_channel_difference_if_needed( td->messages_manager_->get_channel_difference_if_needed(
DialogId(channel_id_), std::move(info), DialogId(channel_id_), std::move(info),
@ -1528,7 +1528,7 @@ class SaveDraftMessageQuery final : public Td::ResultHandler {
if (draft_message->input_message_text.disable_web_page_preview) { if (draft_message->input_message_text.disable_web_page_preview) {
flags |= MessagesManager::SEND_MESSAGE_FLAG_DISABLE_WEB_PAGE_PREVIEW; flags |= MessagesManager::SEND_MESSAGE_FLAG_DISABLE_WEB_PAGE_PREVIEW;
} }
if (draft_message->input_message_text.text.entities.size()) { if (!draft_message->input_message_text.text.entities.empty()) {
flags |= MessagesManager::SEND_MESSAGE_FLAG_HAS_ENTITIES; flags |= MessagesManager::SEND_MESSAGE_FLAG_HAS_ENTITIES;
} }
} }
@ -9119,9 +9119,9 @@ void MessagesManager::after_get_difference() {
} }
} }
void MessagesManager::on_get_empty_messages(DialogId dialog_id, vector<MessageId> empty_message_ids) { void MessagesManager::on_get_empty_messages(DialogId dialog_id, const vector<MessageId> &empty_message_ids) {
if (!empty_message_ids.empty()) { if (!empty_message_ids.empty()) {
delete_dialog_messages(dialog_id, std::move(empty_message_ids), true, true, "on_get_empty_messages"); delete_dialog_messages(dialog_id, empty_message_ids, true, true, "on_get_empty_messages");
} }
} }
@ -10139,7 +10139,7 @@ bool MessagesManager::can_get_message_statistics(DialogId dialog_id, const Messa
return td_->contacts_manager_->can_get_channel_message_statistics(dialog_id); return td_->contacts_manager_->can_get_channel_message_statistics(dialog_id);
} }
bool MessagesManager::can_delete_channel_message(DialogParticipantStatus status, const Message *m, bool is_bot) { bool MessagesManager::can_delete_channel_message(const DialogParticipantStatus &status, const Message *m, bool is_bot) {
if (m == nullptr) { if (m == nullptr) {
return true; return true;
} }
@ -16035,7 +16035,7 @@ void MessagesManager::reload_pinned_dialogs(DialogListId dialog_list_id, Promise
} }
} }
double MessagesManager::get_dialog_filters_cache_time() const { double MessagesManager::get_dialog_filters_cache_time() {
return DIALOG_FILTERS_CACHE_TIME * 0.0001 * Random::fast(9000, 11000); return DIALOG_FILTERS_CACHE_TIME * 0.0001 * Random::fast(9000, 11000);
} }
@ -16618,7 +16618,7 @@ void MessagesManager::on_get_common_dialogs(UserId user_id, int64 offset_chat_id
td_->contacts_manager_->on_update_user_common_chat_count(user_id, total_count); td_->contacts_manager_->on_update_user_common_chat_count(user_id, total_count);
} }
result.push_back(DialogId()); result.emplace_back();
} }
common_dialogs.total_count = total_count; common_dialogs.total_count = total_count;
} }
@ -17279,15 +17279,15 @@ void MessagesManager::on_get_message_viewers(DialogId dialog_id, vector<UserId>
void MessagesManager::get_dialog_info_full(DialogId dialog_id, Promise<Unit> &&promise, const char *source) { void MessagesManager::get_dialog_info_full(DialogId dialog_id, Promise<Unit> &&promise, const char *source) {
switch (dialog_id.get_type()) { switch (dialog_id.get_type()) {
case DialogType::User: case DialogType::User:
send_closure_later(G()->contacts_manager(), &ContactsManager::load_user_full, dialog_id.get_user_id(), false, send_closure_later(td_->contacts_manager_actor_, &ContactsManager::load_user_full, dialog_id.get_user_id(), false,
std::move(promise), source); std::move(promise), source);
return; return;
case DialogType::Chat: case DialogType::Chat:
send_closure_later(G()->contacts_manager(), &ContactsManager::load_chat_full, dialog_id.get_chat_id(), false, send_closure_later(td_->contacts_manager_actor_, &ContactsManager::load_chat_full, dialog_id.get_chat_id(), false,
std::move(promise), source); std::move(promise), source);
return; return;
case DialogType::Channel: case DialogType::Channel:
send_closure_later(G()->contacts_manager(), &ContactsManager::load_channel_full, dialog_id.get_channel_id(), send_closure_later(td_->contacts_manager_actor_, &ContactsManager::load_channel_full, dialog_id.get_channel_id(),
false, std::move(promise), source); false, std::move(promise), source);
return; return;
case DialogType::SecretChat: case DialogType::SecretChat:
@ -17306,15 +17306,15 @@ void MessagesManager::reload_dialog_info_full(DialogId dialog_id) {
switch (dialog_id.get_type()) { switch (dialog_id.get_type()) {
case DialogType::User: case DialogType::User:
send_closure_later(G()->contacts_manager(), &ContactsManager::reload_user_full, dialog_id.get_user_id()); send_closure_later(td_->contacts_manager_actor_, &ContactsManager::reload_user_full, dialog_id.get_user_id());
return; return;
case DialogType::Chat: case DialogType::Chat:
send_closure_later(G()->contacts_manager(), &ContactsManager::reload_chat_full, dialog_id.get_chat_id(), send_closure_later(td_->contacts_manager_actor_, &ContactsManager::reload_chat_full, dialog_id.get_chat_id(),
Promise<Unit>()); Promise<Unit>());
return; return;
case DialogType::Channel: case DialogType::Channel:
send_closure_later(G()->contacts_manager(), &ContactsManager::reload_channel_full, dialog_id.get_channel_id(), send_closure_later(td_->contacts_manager_actor_, &ContactsManager::reload_channel_full,
Promise<Unit>(), "reload_dialog_info_full"); dialog_id.get_channel_id(), Promise<Unit>(), "reload_dialog_info_full");
return; return;
case DialogType::SecretChat: case DialogType::SecretChat:
return; return;
@ -18159,7 +18159,7 @@ void MessagesManager::reorder_dialog_filters_on_server(vector<DialogFilterId> di
send_closure(actor_id, &MessagesManager::on_reorder_dialog_filters, std::move(dialog_filter_ids), send_closure(actor_id, &MessagesManager::on_reorder_dialog_filters, std::move(dialog_filter_ids),
result.is_error() ? result.move_as_error() : Status::OK()); result.is_error() ? result.move_as_error() : Status::OK());
}); });
td_->create_handler<UpdateDialogFiltersOrderQuery>(std::move(promise))->send(std::move(dialog_filter_ids)); td_->create_handler<UpdateDialogFiltersOrderQuery>(std::move(promise))->send(dialog_filter_ids);
} }
void MessagesManager::on_reorder_dialog_filters(vector<DialogFilterId> dialog_filter_ids, Status result) { void MessagesManager::on_reorder_dialog_filters(vector<DialogFilterId> dialog_filter_ids, Status result) {
@ -19878,7 +19878,7 @@ void MessagesManager::open_dialog(Dialog *d) {
d->is_has_scheduled_database_messages_checked = true; d->is_has_scheduled_database_messages_checked = true;
G()->td_db()->get_messages_db_async()->get_scheduled_messages( G()->td_db()->get_messages_db_async()->get_scheduled_messages(
dialog_id, 1, dialog_id, 1,
PromiseCreator::lambda([dialog_id, actor_id = actor_id(this)](vector<MessagesDbDialogMessage> messages) { PromiseCreator::lambda([actor_id = actor_id(this), dialog_id](vector<MessagesDbDialogMessage> messages) {
if (messages.empty()) { if (messages.empty()) {
send_closure(actor_id, &MessagesManager::set_dialog_has_scheduled_database_messages, dialog_id, false); send_closure(actor_id, &MessagesManager::set_dialog_has_scheduled_database_messages, dialog_id, false);
} }
@ -20612,7 +20612,7 @@ tl_object_ptr<td_api::messages> MessagesManager::get_dialog_history(DialogId dia
} }
} }
if (messages.size()) { if (!messages.empty()) {
// maybe need some messages // maybe need some messages
CHECK(offset == 0); CHECK(offset == 0);
preload_newer_messages(d, MessageId(messages[0]->id_)); preload_newer_messages(d, MessageId(messages[0]->id_));
@ -21799,7 +21799,7 @@ void MessagesManager::on_search_dialog_messages_db_result(int64 random_id, Dialo
} }
auto &message_count = d->message_count_by_index[message_search_filter_index(filter)]; auto &message_count = d->message_count_by_index[message_search_filter_index(filter)];
int32 result_size = narrow_cast<int32>(res.size()); auto result_size = narrow_cast<int32>(res.size());
bool from_the_end = bool from_the_end =
from_message_id == MessageId::max() || (offset < 0 && (result_size == 0 || res[0] < from_message_id)); from_message_id == MessageId::max() || (offset < 0 && (result_size == 0 || res[0] < from_message_id));
if ((message_count != -1 && message_count < result_size) || if ((message_count != -1 && message_count < result_size) ||
@ -21843,7 +21843,7 @@ td_api::object_ptr<td_api::foundMessages> MessagesManager::get_found_messages_ob
} }
MessagesManager::FoundMessages MessagesManager::offline_search_messages(DialogId dialog_id, const string &query, MessagesManager::FoundMessages MessagesManager::offline_search_messages(DialogId dialog_id, const string &query,
const string &offset, int32 limit, string offset, int32 limit,
MessageSearchFilter filter, int64 &random_id, MessageSearchFilter filter, int64 &random_id,
Promise<> &&promise) { Promise<> &&promise) {
if (!G()->parameters().use_message_db) { if (!G()->parameters().use_message_db) {
@ -21897,8 +21897,9 @@ MessagesManager::FoundMessages MessagesManager::offline_search_messages(DialogId
found_fts_messages_[random_id]; // reserve place for result found_fts_messages_[random_id]; // reserve place for result
G()->td_db()->get_messages_db_async()->get_messages_fts( G()->td_db()->get_messages_db_async()->get_messages_fts(
std::move(fts_query), PromiseCreator::lambda([random_id, offset, limit, promise = std::move(promise)]( std::move(fts_query),
Result<MessagesDbFtsResult> fts_result) mutable { PromiseCreator::lambda([random_id, offset = std::move(offset), limit,
promise = std::move(promise)](Result<MessagesDbFtsResult> fts_result) mutable {
send_closure(G()->messages_manager(), &MessagesManager::on_messages_db_fts_result, std::move(fts_result), send_closure(G()->messages_manager(), &MessagesManager::on_messages_db_fts_result, std::move(fts_result),
std::move(offset), limit, random_id, std::move(promise)); std::move(offset), limit, random_id, std::move(promise));
})); }));
@ -21925,7 +21926,7 @@ void MessagesManager::on_messages_db_fts_result(Result<MessagesDbFtsResult> resu
for (auto &message : fts_result.messages) { for (auto &message : fts_result.messages) {
auto m = on_get_message_from_database(message, false, "on_messages_db_fts_result"); auto m = on_get_message_from_database(message, false, "on_messages_db_fts_result");
if (m != nullptr) { if (m != nullptr) {
res.push_back(FullMessageId(message.dialog_id, m->message_id)); res.emplace_back(message.dialog_id, m->message_id);
} }
} }
@ -21959,7 +21960,7 @@ void MessagesManager::on_messages_db_calls_result(Result<MessagesDbCallsResult>
auto m = on_get_message_from_database(message, false, "on_messages_db_calls_result"); auto m = on_get_message_from_database(message, false, "on_messages_db_calls_result");
if (m != nullptr && first_db_message_id <= m->message_id) { if (m != nullptr && first_db_message_id <= m->message_id) {
res.push_back(FullMessageId(message.dialog_id, m->message_id)); res.emplace_back(message.dialog_id, m->message_id);
} }
} }
it->second.first = calls_db_state_.message_count_by_index[call_message_search_filter_index(filter)]; it->second.first = calls_db_state_.message_count_by_index[call_message_search_filter_index(filter)];
@ -23327,7 +23328,7 @@ Status MessagesManager::can_send_message(DialogId dialog_id) const {
return Status::OK(); return Status::OK();
} }
MessageId MessagesManager::get_persistent_message_id(const Dialog *d, MessageId message_id) const { MessageId MessagesManager::get_persistent_message_id(const Dialog *d, MessageId message_id) {
if (!message_id.is_valid() && !message_id.is_valid_scheduled()) { if (!message_id.is_valid() && !message_id.is_valid_scheduled()) {
return MessageId(); return MessageId();
} }
@ -25692,18 +25693,14 @@ void MessagesManager::update_message_max_reply_media_timestamp(const Dialog *d,
return; return;
} }
auto new_max_reply_media_timestamp = m->max_reply_media_timestamp; auto new_max_reply_media_timestamp = -1;
if (!m->reply_to_message_id.is_valid()) { if (m->reply_to_message_id.is_valid()) {
new_max_reply_media_timestamp = -1;
} else {
auto replied_m = get_message(d, m->reply_to_message_id); auto replied_m = get_message(d, m->reply_to_message_id);
if (replied_m != nullptr) { if (replied_m != nullptr) {
new_max_reply_media_timestamp = get_message_own_max_media_timestamp(replied_m); new_max_reply_media_timestamp = get_message_own_max_media_timestamp(replied_m);
} else if (d->deleted_message_ids.count(m->reply_to_message_id) || } else if (!d->deleted_message_ids.count(m->reply_to_message_id) &&
m->reply_to_message_id <= d->last_clear_history_message_id || m->reply_to_message_id > d->last_clear_history_message_id &&
m->reply_to_message_id <= d->max_unavailable_message_id) { m->reply_to_message_id > d->max_unavailable_message_id) {
new_max_reply_media_timestamp = -1;
} else {
// replied message isn't deleted and isn't loaded yet // replied message isn't deleted and isn't loaded yet
return; return;
} }
@ -28885,7 +28882,7 @@ void MessagesManager::send_update_chat_has_scheduled_messages(Dialog *d, bool fr
} }
void MessagesManager::send_update_user_chat_action(DialogId dialog_id, MessageId top_thread_message_id, UserId user_id, void MessagesManager::send_update_user_chat_action(DialogId dialog_id, MessageId top_thread_message_id, UserId user_id,
DialogAction action) { const DialogAction &action) {
if (td_->auth_manager_->is_bot()) { if (td_->auth_manager_->is_bot()) {
return; return;
} }
@ -31934,7 +31931,7 @@ tl_object_ptr<td_api::ChatEventAction> MessagesManager::get_chat_event_action_ob
} }
case telegram_api::channelAdminLogEventActionParticipantMute::ID: { case telegram_api::channelAdminLogEventActionParticipantMute::ID: {
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantMute>(action_ptr); auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantMute>(action_ptr);
GroupCallParticipant participant(std::move(action->participant_), 0); GroupCallParticipant participant(action->participant_, 0);
if (!participant.is_valid()) { if (!participant.is_valid()) {
return nullptr; return nullptr;
} }
@ -31943,7 +31940,7 @@ tl_object_ptr<td_api::ChatEventAction> MessagesManager::get_chat_event_action_ob
} }
case telegram_api::channelAdminLogEventActionParticipantUnmute::ID: { case telegram_api::channelAdminLogEventActionParticipantUnmute::ID: {
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantUnmute>(action_ptr); auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantUnmute>(action_ptr);
GroupCallParticipant participant(std::move(action->participant_), 0); GroupCallParticipant participant(action->participant_, 0);
if (!participant.is_valid()) { if (!participant.is_valid()) {
return nullptr; return nullptr;
} }
@ -31952,7 +31949,7 @@ tl_object_ptr<td_api::ChatEventAction> MessagesManager::get_chat_event_action_ob
} }
case telegram_api::channelAdminLogEventActionParticipantVolume::ID: { case telegram_api::channelAdminLogEventActionParticipantVolume::ID: {
auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantVolume>(action_ptr); auto action = move_tl_object_as<telegram_api::channelAdminLogEventActionParticipantVolume>(action_ptr);
GroupCallParticipant participant(std::move(action->participant_), 0); GroupCallParticipant participant(action->participant_, 0);
if (!participant.is_valid()) { if (!participant.is_valid()) {
return nullptr; return nullptr;
} }
@ -35456,7 +35453,7 @@ unique_ptr<MessagesManager::Dialog> MessagesManager::parse_dialog(DialogId dialo
return d; return d;
} }
MessagesManager::Dialog *MessagesManager::on_load_dialog_from_database(DialogId dialog_id, const BufferSlice &value, MessagesManager::Dialog *MessagesManager::on_load_dialog_from_database(DialogId dialog_id, BufferSlice &&value,
const char *source) { const char *source) {
CHECK(G()->parameters().use_message_db); CHECK(G()->parameters().use_message_db);
@ -35555,17 +35552,17 @@ bool MessagesManager::has_dialogs_from_folder(const DialogList &list, const Dial
return false; return false;
} }
bool MessagesManager::is_dialog_in_list(const Dialog *d, DialogListId dialog_list_id) const { bool MessagesManager::is_dialog_in_list(const Dialog *d, DialogListId dialog_list_id) {
return td::contains(d->dialog_list_ids, dialog_list_id); return td::contains(d->dialog_list_ids, dialog_list_id);
} }
void MessagesManager::add_dialog_to_list(Dialog *d, DialogListId dialog_list_id) const { void MessagesManager::add_dialog_to_list(Dialog *d, DialogListId dialog_list_id) {
LOG(INFO) << "Add " << d->dialog_id << " to " << dialog_list_id; LOG(INFO) << "Add " << d->dialog_id << " to " << dialog_list_id;
CHECK(!is_dialog_in_list(d, dialog_list_id)); CHECK(!is_dialog_in_list(d, dialog_list_id));
d->dialog_list_ids.push_back(dialog_list_id); d->dialog_list_ids.push_back(dialog_list_id);
} }
void MessagesManager::remove_dialog_from_list(Dialog *d, DialogListId dialog_list_id) const { void MessagesManager::remove_dialog_from_list(Dialog *d, DialogListId dialog_list_id) {
LOG(INFO) << "Remove " << d->dialog_id << " from " << dialog_list_id; LOG(INFO) << "Remove " << d->dialog_id << " from " << dialog_list_id;
bool is_removed = td::remove(d->dialog_list_ids, dialog_list_id); bool is_removed = td::remove(d->dialog_list_ids, dialog_list_id);
CHECK(is_removed); CHECK(is_removed);
@ -35702,7 +35699,7 @@ MessagesManager::get_dialog_positions(const Dialog *d) const {
return positions; return positions;
} }
vector<DialogListId> MessagesManager::get_dialog_list_ids(const Dialog *d) const { vector<DialogListId> MessagesManager::get_dialog_list_ids(const Dialog *d) {
return d->dialog_list_ids; return d->dialog_list_ids;
} }

View File

@ -180,7 +180,7 @@ class MessagesManager final : public Actor {
bool have_input_peer(DialogId dialog_id, AccessRights access_rights) const; bool have_input_peer(DialogId dialog_id, AccessRights access_rights) const;
void on_get_empty_messages(DialogId dialog_id, vector<MessageId> empty_message_ids); void on_get_empty_messages(DialogId dialog_id, const vector<MessageId> &empty_message_ids);
struct MessagesInfo { struct MessagesInfo {
vector<tl_object_ptr<telegram_api::Message>> messages; vector<tl_object_ptr<telegram_api::Message>> messages;
@ -520,7 +520,7 @@ class MessagesManager final : public Actor {
void load_dialogs(vector<DialogId> dialog_ids, Promise<vector<DialogId>> &&promise); void load_dialogs(vector<DialogId> dialog_ids, Promise<vector<DialogId>> &&promise);
void load_dialog_filter(DialogFilterId dialog_id, bool force, Promise<Unit> &&promise); void load_dialog_filter(DialogFilterId dialog_filter_id, bool force, Promise<Unit> &&promise);
void get_recommended_dialog_filters(Promise<td_api::object_ptr<td_api::recommendedChatFilters>> &&promise); void get_recommended_dialog_filters(Promise<td_api::object_ptr<td_api::recommendedChatFilters>> &&promise);
@ -705,7 +705,7 @@ class MessagesManager final : public Actor {
td_api::object_ptr<td_api::foundMessages> get_found_messages_object(const FoundMessages &found_messages, td_api::object_ptr<td_api::foundMessages> get_found_messages_object(const FoundMessages &found_messages,
const char *source); const char *source);
FoundMessages offline_search_messages(DialogId dialog_id, const string &query, const string &offset, int32 limit, FoundMessages offline_search_messages(DialogId dialog_id, const string &query, string offset, int32 limit,
MessageSearchFilter filter, int64 &random_id, Promise<> &&promise); MessageSearchFilter filter, int64 &random_id, Promise<> &&promise);
std::pair<int32, vector<FullMessageId>> search_messages(FolderId folder_id, bool ignore_folder_id, std::pair<int32, vector<FullMessageId>> search_messages(FolderId folder_id, bool ignore_folder_id,
@ -984,7 +984,7 @@ class MessagesManager final : public Actor {
, sender_name(std::move(sender_name)) , sender_name(std::move(sender_name))
, from_dialog_id(from_dialog_id) , from_dialog_id(from_dialog_id)
, from_message_id(from_message_id) , from_message_id(from_message_id)
, psa_type(psa_type) , psa_type(std::move(psa_type))
, is_imported(is_imported) { , is_imported(is_imported) {
} }
@ -1160,8 +1160,8 @@ class MessagesManager final : public Actor {
int32 server_unread_count = 0; int32 server_unread_count = 0;
int32 local_unread_count = 0; int32 local_unread_count = 0;
int32 unread_mention_count = 0; int32 unread_mention_count = 0;
MessageId last_read_inbox_message_id;
int32 last_read_inbox_message_date = 0; // secret chats only int32 last_read_inbox_message_date = 0; // secret chats only
MessageId last_read_inbox_message_id;
MessageId last_read_outbox_message_id; MessageId last_read_outbox_message_id;
MessageId last_pinned_message_id; MessageId last_pinned_message_id;
MessageId reply_markup_message_id; MessageId reply_markup_message_id;
@ -1186,11 +1186,13 @@ class MessagesManager final : public Actor {
MessageId MessageId
max_unavailable_message_id; // maximum unavailable message identifier for dialogs with cleared/unavailable history max_unavailable_message_id; // maximum unavailable message identifier for dialogs with cleared/unavailable history
int32 distance = -1; // distance to the peer
int32 last_clear_history_date = 0; int32 last_clear_history_date = 0;
MessageId last_clear_history_message_id; MessageId last_clear_history_message_id;
int64 order = DEFAULT_ORDER; int64 order = DEFAULT_ORDER;
int32 delete_last_message_date = 0;
MessageId deleted_last_message_id; MessageId deleted_last_message_id;
int32 delete_last_message_date = 0;
int32 pending_last_message_date = 0; int32 pending_last_message_date = 0;
MessageId pending_last_message_id; MessageId pending_last_message_id;
MessageId max_notification_message_id; MessageId max_notification_message_id;
@ -1209,8 +1211,6 @@ class MessagesManager final : public Actor {
NotificationId new_secret_chat_notification_id; // secret chats only NotificationId new_secret_chat_notification_id; // secret chats only
MessageId pinned_message_notification_message_id; MessageId pinned_message_notification_message_id;
int32 distance = -1; // distance to the peer
bool has_contact_registered_message = false; bool has_contact_registered_message = false;
bool is_last_message_deleted_locally = false; bool is_last_message_deleted_locally = false;
@ -1264,10 +1264,13 @@ class MessagesManager final : public Actor {
bool has_unload_timeout = false; bool has_unload_timeout = false;
bool is_channel_difference_finished = false; bool is_channel_difference_finished = false;
bool suffix_load_done_ = false;
bool suffix_load_has_query_ = false;
int32 pts = 0; // for channels only int32 pts = 0; // for channels only
int32 pending_read_channel_inbox_pts = 0; // for channels only int32 pending_read_channel_inbox_pts = 0; // for channels only
MessageId pending_read_channel_inbox_max_message_id; // for channels only
int32 pending_read_channel_inbox_server_unread_count = 0; // for channels only int32 pending_read_channel_inbox_server_unread_count = 0; // for channels only
MessageId pending_read_channel_inbox_max_message_id; // for channels only
std::unordered_map<int64, MessageId> random_id_to_message_id; // for secret chats only std::unordered_map<int64, MessageId> random_id_to_message_id; // for secret chats only
MessageId last_assigned_message_id; // identifier of the last local or yet unsent message, assigned after MessageId last_assigned_message_id; // identifier of the last local or yet unsent message, assigned after
@ -1298,8 +1301,6 @@ class MessagesManager final : public Actor {
// [suffix_load_first_message_id_, last_message_id] are loaded // [suffix_load_first_message_id_, last_message_id] are loaded
MessageId suffix_load_query_message_id_; MessageId suffix_load_query_message_id_;
std::vector<std::pair<Promise<>, std::function<bool(const Message *)>>> suffix_load_queries_; std::vector<std::pair<Promise<>, std::function<bool(const Message *)>>> suffix_load_queries_;
bool suffix_load_done_ = false;
bool suffix_load_has_query_ = false;
std::unordered_map<MessageId, int64, MessageIdHash> pending_viewed_live_locations; // message_id -> task_id std::unordered_map<MessageId, int64, MessageIdHash> pending_viewed_live_locations; // message_id -> task_id
std::unordered_set<MessageId, MessageIdHash> pending_viewed_message_ids; std::unordered_set<MessageId, MessageIdHash> pending_viewed_message_ids;
@ -1815,7 +1816,7 @@ class MessagesManager final : public Actor {
bool was_uploaded, bool was_thumbnail_uploaded, string file_reference, bool was_uploaded, bool was_thumbnail_uploaded, string file_reference,
int32 scheduled_date, uint64 generation, Result<int32> &&result); int32 scheduled_date, uint64 generation, Result<int32> &&result);
MessageId get_persistent_message_id(const Dialog *d, MessageId message_id) const; static MessageId get_persistent_message_id(const Dialog *d, MessageId message_id);
static FullMessageId get_replied_message_id(DialogId dialog_id, const Message *m); static FullMessageId get_replied_message_id(DialogId dialog_id, const Message *m);
@ -1914,18 +1915,18 @@ class MessagesManager final : public Actor {
void on_yet_unsent_media_queue_updated(DialogId dialog_id); void on_yet_unsent_media_queue_updated(DialogId dialog_id);
void save_send_bot_start_message_log_event(UserId bot_user_id, DialogId dialog_id, const string &parameter, static void save_send_bot_start_message_log_event(UserId bot_user_id, DialogId dialog_id, const string &parameter,
const Message *m); const Message *m);
void do_send_bot_start_message(UserId bot_user_id, DialogId dialog_id, const string &parameter, const Message *m); void do_send_bot_start_message(UserId bot_user_id, DialogId dialog_id, const string &parameter, const Message *m);
void save_send_inline_query_result_message_log_event(DialogId dialog_id, const Message *m, int64 query_id, static void save_send_inline_query_result_message_log_event(DialogId dialog_id, const Message *m, int64 query_id,
const string &result_id); const string &result_id);
void do_send_inline_query_result_message(DialogId dialog_id, const Message *m, int64 query_id, void do_send_inline_query_result_message(DialogId dialog_id, const Message *m, int64 query_id,
const string &result_id); const string &result_id);
uint64 save_send_screenshot_taken_notification_message_log_event(DialogId dialog_id, const Message *m); static uint64 save_send_screenshot_taken_notification_message_log_event(DialogId dialog_id, const Message *m);
void do_send_screenshot_taken_notification_message(DialogId dialog_id, const Message *m, uint64 log_event_id); void do_send_screenshot_taken_notification_message(DialogId dialog_id, const Message *m, uint64 log_event_id);
@ -1939,7 +1940,7 @@ class MessagesManager final : public Actor {
bool can_get_message_statistics(DialogId dialog_id, const Message *m) const; bool can_get_message_statistics(DialogId dialog_id, const Message *m) const;
static bool can_delete_channel_message(DialogParticipantStatus status, const Message *m, bool is_bot); static bool can_delete_channel_message(const DialogParticipantStatus &status, const Message *m, bool is_bot);
bool can_delete_message(DialogId dialog_id, const Message *m) const; bool can_delete_message(DialogId dialog_id, const Message *m) const;
@ -2121,7 +2122,7 @@ class MessagesManager final : public Actor {
void on_dialog_updated(DialogId dialog_id, const char *source); void on_dialog_updated(DialogId dialog_id, const char *source);
BufferSlice get_dialog_database_value(const Dialog *d); static BufferSlice get_dialog_database_value(const Dialog *d);
void save_dialog_to_database(DialogId dialog_id); void save_dialog_to_database(DialogId dialog_id);
@ -2204,9 +2205,9 @@ class MessagesManager final : public Actor {
void do_delete_message_log_event(const DeleteMessageLogEvent &log_event) const; void do_delete_message_log_event(const DeleteMessageLogEvent &log_event) const;
void attach_message_to_previous(Dialog *d, MessageId message_id, const char *source); static void attach_message_to_previous(Dialog *d, MessageId message_id, const char *source);
void attach_message_to_next(Dialog *d, MessageId message_id, const char *source); static void attach_message_to_next(Dialog *d, MessageId message_id, const char *source);
bool update_message(Dialog *d, Message *old_message, unique_ptr<Message> new_message, bool *need_update_dialog_pos, bool update_message(Dialog *d, Message *old_message, unique_ptr<Message> new_message, bool *need_update_dialog_pos,
bool is_message_in_dialog); bool is_message_in_dialog);
@ -2245,7 +2246,7 @@ class MessagesManager final : public Actor {
vector<Notification> get_message_notifications_from_database_force(Dialog *d, bool from_mentions, int32 limit); vector<Notification> get_message_notifications_from_database_force(Dialog *d, bool from_mentions, int32 limit);
Result<vector<MessagesDbDialogMessage>> do_get_message_notifications_from_database_force( static Result<vector<MessagesDbDialogMessage>> do_get_message_notifications_from_database_force(
Dialog *d, bool from_mentions, NotificationId from_notification_id, MessageId from_message_id, int32 limit); Dialog *d, bool from_mentions, NotificationId from_notification_id, MessageId from_message_id, int32 limit);
void do_get_message_notifications_from_database(Dialog *d, bool from_mentions, void do_get_message_notifications_from_database(Dialog *d, bool from_mentions,
@ -2339,7 +2340,7 @@ class MessagesManager final : public Actor {
void send_update_chat_has_scheduled_messages(Dialog *d, bool from_deletion); void send_update_chat_has_scheduled_messages(Dialog *d, bool from_deletion);
void send_update_user_chat_action(DialogId dialog_id, MessageId top_thread_message_id, UserId user_id, void send_update_user_chat_action(DialogId dialog_id, MessageId top_thread_message_id, UserId user_id,
DialogAction action); const DialogAction &action);
void repair_dialog_action_bar(Dialog *d, const char *source); void repair_dialog_action_bar(Dialog *d, const char *source);
@ -2385,7 +2386,7 @@ class MessagesManager final : public Actor {
td_api::object_ptr<td_api::updateUnreadChatCount> get_update_unread_chat_count_object(const DialogList &list) const; td_api::object_ptr<td_api::updateUnreadChatCount> get_update_unread_chat_count_object(const DialogList &list) const;
void save_unread_chat_count(const DialogList &list); static void save_unread_chat_count(const DialogList &list);
void set_dialog_last_read_inbox_message_id(Dialog *d, MessageId message_id, int32 server_unread_count, void set_dialog_last_read_inbox_message_id(Dialog *d, MessageId message_id, int32 server_unread_count,
int32 local_unread_count, bool force_update, const char *source); int32 local_unread_count, bool force_update, const char *source);
@ -2466,7 +2467,8 @@ class MessagesManager final : public Actor {
static string get_notification_settings_scope_database_key(NotificationSettingsScope scope); static string get_notification_settings_scope_database_key(NotificationSettingsScope scope);
void save_scope_notification_settings(NotificationSettingsScope scope, const ScopeNotificationSettings &new_settings); static void save_scope_notification_settings(NotificationSettingsScope scope,
const ScopeNotificationSettings &new_settings);
bool update_dialog_notification_settings(DialogId dialog_id, DialogNotificationSettings *current_settings, bool update_dialog_notification_settings(DialogId dialog_id, DialogNotificationSettings *current_settings,
const DialogNotificationSettings &new_settings); const DialogNotificationSettings &new_settings);
@ -2531,7 +2533,7 @@ class MessagesManager final : public Actor {
Dialog *get_dialog_force(DialogId dialog_id, const char *source = "get_dialog_force"); Dialog *get_dialog_force(DialogId dialog_id, const char *source = "get_dialog_force");
Dialog *on_load_dialog_from_database(DialogId dialog_id, const BufferSlice &value, const char *source); Dialog *on_load_dialog_from_database(DialogId dialog_id, BufferSlice &&value, const char *source);
void on_get_dialogs_from_database(FolderId folder_id, int32 limit, DialogDbGetDialogsResult &&dialogs, void on_get_dialogs_from_database(FolderId folder_id, int32 limit, DialogDbGetDialogsResult &&dialogs,
Promise<Unit> &&promise); Promise<Unit> &&promise);
@ -2544,7 +2546,7 @@ class MessagesManager final : public Actor {
void reload_pinned_dialogs(DialogListId dialog_list_id, Promise<Unit> &&promise); void reload_pinned_dialogs(DialogListId dialog_list_id, Promise<Unit> &&promise);
double get_dialog_filters_cache_time() const; static double get_dialog_filters_cache_time();
void schedule_dialog_filters_reload(double timeout); void schedule_dialog_filters_reload(double timeout);
@ -2614,11 +2616,11 @@ class MessagesManager final : public Actor {
bool has_dialogs_from_folder(const DialogList &list, const DialogFolder &folder) const; bool has_dialogs_from_folder(const DialogList &list, const DialogFolder &folder) const;
bool is_dialog_in_list(const Dialog *d, DialogListId dialog_list_id) const; static bool is_dialog_in_list(const Dialog *d, DialogListId dialog_list_id);
void add_dialog_to_list(Dialog *d, DialogListId dialog_list_id) const; static void add_dialog_to_list(Dialog *d, DialogListId dialog_list_id);
void remove_dialog_from_list(Dialog *d, DialogListId dialog_list_id) const; static void remove_dialog_from_list(Dialog *d, DialogListId dialog_list_id);
bool need_dialog_in_filter(const Dialog *d, const DialogFilter *filter) const; bool need_dialog_in_filter(const Dialog *d, const DialogFilter *filter) const;
@ -2631,7 +2633,8 @@ class MessagesManager final : public Actor {
std::unordered_map<DialogListId, DialogPositionInList, DialogListIdHash> get_dialog_positions(const Dialog *d) const; std::unordered_map<DialogListId, DialogPositionInList, DialogListIdHash> get_dialog_positions(const Dialog *d) const;
vector<DialogListId> get_dialog_list_ids(const Dialog *d) const; static vector<DialogListId> get_dialog_list_ids(const Dialog *d);
DialogListView get_dialog_lists(const Dialog *d); DialogListView get_dialog_lists(const Dialog *d);
DialogList &add_dialog_list(DialogListId dialog_list_id); DialogList &add_dialog_list(DialogListId dialog_list_id);
@ -3031,50 +3034,54 @@ class MessagesManager final : public Actor {
static void add_message_dependencies(Dependencies &dependencies, const Message *m); static void add_message_dependencies(Dependencies &dependencies, const Message *m);
void save_send_message_log_event(DialogId dialog_id, const Message *m); static void save_send_message_log_event(DialogId dialog_id, const Message *m);
uint64 save_toggle_dialog_report_spam_state_on_server_log_event(DialogId dialog_id, bool is_spam_dialog); static uint64 save_toggle_dialog_report_spam_state_on_server_log_event(DialogId dialog_id, bool is_spam_dialog);
uint64 save_delete_messages_from_server_log_event(DialogId dialog_id, const vector<MessageId> &message_ids, static uint64 save_delete_messages_from_server_log_event(DialogId dialog_id, const vector<MessageId> &message_ids,
bool revoke); bool revoke);
uint64 save_delete_scheduled_messages_from_server_log_event(DialogId dialog_id, const vector<MessageId> &message_ids); static uint64 save_delete_scheduled_messages_from_server_log_event(DialogId dialog_id,
const vector<MessageId> &message_ids);
uint64 save_delete_dialog_history_from_server_log_event(DialogId dialog_id, MessageId max_message_id, static uint64 save_delete_dialog_history_from_server_log_event(DialogId dialog_id, MessageId max_message_id,
bool remove_from_dialog_list, bool revoke); bool remove_from_dialog_list, bool revoke);
uint64 save_delete_all_call_messages_from_server_log_event(bool revoke); static uint64 save_delete_all_call_messages_from_server_log_event(bool revoke);
uint64 save_block_message_sender_from_replies_on_server_log_event(MessageId message_id, bool delete_message, static uint64 save_block_message_sender_from_replies_on_server_log_event(MessageId message_id, bool delete_message,
bool delete_all_messages, bool report_spam); bool delete_all_messages, bool report_spam);
uint64 save_delete_all_channel_messages_from_user_on_server_log_event(ChannelId channel_id, UserId user_id); static uint64 save_delete_all_channel_messages_from_user_on_server_log_event(ChannelId channel_id, UserId user_id);
uint64 save_read_all_dialog_mentions_on_server_log_event(DialogId dialog_id); static uint64 save_read_all_dialog_mentions_on_server_log_event(DialogId dialog_id);
uint64 save_toggle_dialog_is_pinned_on_server_log_event(DialogId dialog_id, bool is_pinned); static uint64 save_toggle_dialog_is_pinned_on_server_log_event(DialogId dialog_id, bool is_pinned);
uint64 save_reorder_pinned_dialogs_on_server_log_event(FolderId folder_id, const vector<DialogId> &dialog_ids); static uint64 save_reorder_pinned_dialogs_on_server_log_event(FolderId folder_id, const vector<DialogId> &dialog_ids);
uint64 save_toggle_dialog_is_marked_as_unread_on_server_log_event(DialogId dialog_id, bool is_marked_as_unread); static uint64 save_toggle_dialog_is_marked_as_unread_on_server_log_event(DialogId dialog_id,
bool is_marked_as_unread);
uint64 save_toggle_dialog_is_blocked_on_server_log_event(DialogId dialog_id, bool is_blocked); static uint64 save_toggle_dialog_is_blocked_on_server_log_event(DialogId dialog_id, bool is_blocked);
uint64 save_read_message_contents_on_server_log_event(DialogId dialog_id, const vector<MessageId> &message_ids); static uint64 save_read_message_contents_on_server_log_event(DialogId dialog_id,
const vector<MessageId> &message_ids);
uint64 save_update_scope_notification_settings_on_server_log_event(NotificationSettingsScope scope); static uint64 save_update_scope_notification_settings_on_server_log_event(NotificationSettingsScope scope);
uint64 save_reset_all_notification_settings_on_server_log_event(); static uint64 save_reset_all_notification_settings_on_server_log_event();
uint64 save_get_dialog_from_server_log_event(DialogId dialog_id); static uint64 save_get_dialog_from_server_log_event(DialogId dialog_id);
uint64 save_forward_messages_log_event(DialogId to_dialog_id, DialogId from_dialog_id, static uint64 save_forward_messages_log_event(DialogId to_dialog_id, DialogId from_dialog_id,
const vector<Message *> &messages, const vector<MessageId> &message_ids); const vector<Message *> &messages,
const vector<MessageId> &message_ids);
uint64 save_unpin_all_dialog_messages_on_server_log_event(DialogId dialog_id); static uint64 save_unpin_all_dialog_messages_on_server_log_event(DialogId dialog_id);
void suffix_load_loop(Dialog *d); void suffix_load_loop(Dialog *d);
void suffix_load_update_first_message_id(Dialog *d); static void suffix_load_update_first_message_id(Dialog *d);
void suffix_load_query_ready(DialogId dialog_id); void suffix_load_query_ready(DialogId dialog_id);
void suffix_load_add_query(Dialog *d, std::pair<Promise<>, std::function<bool(const Message *)>> query); void suffix_load_add_query(Dialog *d, std::pair<Promise<>, std::function<bool(const Message *)>> query);
void suffix_load_till_date(Dialog *d, int32 date, Promise<> promise); void suffix_load_till_date(Dialog *d, int32 date, Promise<> promise);
@ -3310,7 +3317,10 @@ class MessagesManager final : public Actor {
double start_time; double start_time;
ActiveDialogAction(MessageId top_thread_message_id, UserId user_id, DialogAction action, double start_time) ActiveDialogAction(MessageId top_thread_message_id, UserId user_id, DialogAction action, double start_time)
: top_thread_message_id(top_thread_message_id), user_id(user_id), action(action), start_time(start_time) { : top_thread_message_id(top_thread_message_id)
, user_id(user_id)
, action(std::move(action))
, start_time(start_time) {
} }
}; };

View File

@ -237,7 +237,7 @@ void NotificationManager::init() {
last_loaded_notification_group_key_.last_notification_date = std::numeric_limits<int32>::max(); last_loaded_notification_group_key_.last_notification_date = std::numeric_limits<int32>::max();
if (max_notification_group_count_ != 0) { if (max_notification_group_count_ != 0) {
int32 loaded_groups = 0; int32 loaded_groups = 0;
int32 needed_groups = static_cast<int32>(max_notification_group_count_); auto needed_groups = static_cast<int32>(max_notification_group_count_);
do { do {
loaded_groups += load_message_notification_groups_from_database(needed_groups, false); loaded_groups += load_message_notification_groups_from_database(needed_groups, false);
} while (loaded_groups < needed_groups && last_loaded_notification_group_key_.last_notification_date != 0); } while (loaded_groups < needed_groups && last_loaded_notification_group_key_.last_notification_date != 0);
@ -1765,7 +1765,7 @@ void NotificationManager::on_notifications_removed(
void NotificationManager::remove_added_notifications_from_pending_updates( void NotificationManager::remove_added_notifications_from_pending_updates(
NotificationGroupId group_id, NotificationGroupId group_id,
std::function<bool(const td_api::object_ptr<td_api::notification> &notification)> is_removed) { const std::function<bool(const td_api::object_ptr<td_api::notification> &notification)> &is_removed) {
auto it = pending_updates_.find(group_id.get()); auto it = pending_updates_.find(group_id.get());
if (it == pending_updates_.end()) { if (it == pending_updates_.end()) {
return; return;

View File

@ -111,7 +111,7 @@ class NotificationManager final : public Actor {
void process_push_notification(string payload, Promise<Unit> &&user_promise); void process_push_notification(string payload, Promise<Unit> &&user_promise);
static Result<int64> get_push_receiver_id(string push); static Result<int64> get_push_receiver_id(string payload);
static Result<string> decrypt_push(int64 encryption_key_id, string encryption_key, string push); // public for tests static Result<string> decrypt_push(int64 encryption_key_id, string encryption_key, string push); // public for tests
@ -290,7 +290,7 @@ class NotificationManager final : public Actor {
void remove_added_notifications_from_pending_updates( void remove_added_notifications_from_pending_updates(
NotificationGroupId group_id, NotificationGroupId group_id,
std::function<bool(const td_api::object_ptr<td_api::notification> &notification)> is_removed); const std::function<bool(const td_api::object_ptr<td_api::notification> &notification)> &is_removed);
void flush_pending_updates(int32 group_id, const char *source); void flush_pending_updates(int32 group_id, const char *source);

View File

@ -656,7 +656,7 @@ Result<PasswordManager::PasswordInputSettings> PasswordManager::get_password_inp
new_password_hash = new_hash.move_as_ok(); new_password_hash = new_hash.move_as_ok();
new_algo = make_tl_object<telegram_api::passwordKdfAlgoSHA256SHA256PBKDF2HMACSHA512iter100000SHA256ModPow>( new_algo = make_tl_object<telegram_api::passwordKdfAlgoSHA256SHA256PBKDF2HMACSHA512iter100000SHA256ModPow>(
std::move(new_client_salt), BufferSlice(state.server_salt), state.srp_g, BufferSlice(state.srp_p)); std::move(new_client_salt), BufferSlice(state.server_salt), state.srp_g, BufferSlice(state.srp_p));
new_hint = std::move(update_settings.new_hint); new_hint = update_settings.new_hint;
if (have_secret) { if (have_secret) {
update_secure_secret = true; update_secure_secret = true;
} }

View File

@ -1228,7 +1228,7 @@ void send_payment_form(Td *td, FullMessageId full_message_id, int64 payment_form
if (!clean_input_string(credentials_id)) { if (!clean_input_string(credentials_id)) {
return promise.set_error(Status::Error(400, "Credentials identifier must be encoded in UTF-8")); return promise.set_error(Status::Error(400, "Credentials identifier must be encoded in UTF-8"));
} }
auto temp_password_state = td->password_manager_->get_actor_unsafe()->get_temp_password_state_sync(); auto temp_password_state = PasswordManager::get_temp_password_state_sync();
if (!temp_password_state.has_temp_password) { if (!temp_password_state.has_temp_password) {
return promise.set_error(Status::Error(400, "Temporary password required to use saved credentials")); return promise.set_error(Status::Error(400, "Temporary password required to use saved credentials"));
} }

View File

@ -47,7 +47,7 @@ class PhoneNumberManager final : public NetActor {
void on_new_query(uint64 query_id); void on_new_query(uint64 query_id);
void on_query_error(Status status); void on_query_error(Status status);
void on_query_error(uint64 id, Status status); static void on_query_error(uint64 id, Status status);
void on_query_ok(); void on_query_ok();
void start_net_query(NetQueryType net_query_type, NetQueryPtr net_query); void start_net_query(NetQueryType net_query_type, NetQueryPtr net_query);

View File

@ -430,8 +430,8 @@ Variant<PhotoSize, string> get_photo_size(FileManager *file_manager, PhotoSizeSo
source.thumbnail().thumbnail_type = res.type; source.thumbnail().thumbnail_type = res.type;
} }
res.file_id = res.file_id = register_photo(file_manager, source, id, access_hash, std::move(file_reference), owner_dialog_id,
register_photo(file_manager, source, id, access_hash, file_reference, owner_dialog_id, res.size, dc_id, format); res.size, dc_id, format);
if (!content.empty()) { if (!content.empty()) {
file_manager->set_content(res.file_id, std::move(content)); file_manager->set_content(res.file_id, std::move(content));
@ -463,8 +463,8 @@ AnimationSize get_animation_size(FileManager *file_manager, PhotoSizeSource sour
source.thumbnail().thumbnail_type = res.type; source.thumbnail().thumbnail_type = res.type;
} }
res.file_id = register_photo(file_manager, source, id, access_hash, file_reference, owner_dialog_id, res.size, dc_id, res.file_id = register_photo(file_manager, source, id, access_hash, std::move(file_reference), owner_dialog_id,
PhotoFormat::Mpeg4); res.size, dc_id, PhotoFormat::Mpeg4);
return res; return res;
} }

View File

@ -150,7 +150,7 @@ string PhotoSizeSource::get_unique_name(int64 photo_id) const {
UNREACHABLE(); UNREACHABLE();
break; break;
} }
return 0; return string();
} }
static bool operator==(const PhotoSizeSource::Legacy &lhs, const PhotoSizeSource::Legacy &rhs) { static bool operator==(const PhotoSizeSource::Legacy &lhs, const PhotoSizeSource::Legacy &rhs) {

View File

@ -616,7 +616,6 @@ PollId PollManager::create_poll(string &&question, vector<string> &&options, boo
CHECK(is_local_poll_id(poll_id)); CHECK(is_local_poll_id(poll_id));
bool is_inserted = polls_.emplace(poll_id, std::move(poll)).second; bool is_inserted = polls_.emplace(poll_id, std::move(poll)).second;
CHECK(is_inserted); CHECK(is_inserted);
LOG(INFO) << "Created " << poll_id << " with question \"" << oneline(poll->question) << '"';
return poll_id; return poll_id;
} }
@ -978,7 +977,7 @@ void PollManager::get_poll_voters(PollId poll_id, FullMessageId full_message_id,
auto query_promise = auto query_promise =
PromiseCreator::lambda([actor_id = actor_id(this), poll_id, option_id, offset = voters.next_offset, PromiseCreator::lambda([actor_id = actor_id(this), poll_id, option_id, offset = voters.next_offset,
limit](Result<tl_object_ptr<telegram_api::messages_votesList>> &&result) { limit](Result<tl_object_ptr<telegram_api::messages_votesList>> &&result) mutable {
send_closure(actor_id, &PollManager::on_get_poll_voters, poll_id, option_id, std::move(offset), limit, send_closure(actor_id, &PollManager::on_get_poll_voters, poll_id, option_id, std::move(offset), limit,
std::move(result)); std::move(result));
}); });

View File

@ -165,7 +165,7 @@ class PollManager final : public Actor {
static string get_poll_database_key(PollId poll_id); static string get_poll_database_key(PollId poll_id);
void save_poll(const Poll *poll, PollId poll_id); static void save_poll(const Poll *poll, PollId poll_id);
void on_load_poll_from_database(PollId poll_id, string value); void on_load_poll_from_database(PollId poll_id, string value);

View File

@ -259,7 +259,7 @@ std::pair<int32, vector<DialogId>> RecentDialogList::get_dialogs(int32 limit, Pr
update_dialogs(); update_dialogs();
CHECK(limit >= 0); CHECK(limit >= 0);
int32 total_count = narrow_cast<int32>(dialog_ids_.size()); auto total_count = narrow_cast<int32>(dialog_ids_.size());
return {total_count, vector<DialogId>(dialog_ids_.begin(), dialog_ids_.begin() + min(limit, total_count))}; return {total_count, vector<DialogId>(dialog_ids_.begin(), dialog_ids_.begin() + min(limit, total_count))};
} }

View File

@ -132,8 +132,10 @@ void SecretChatActor::on_result_resendable(NetQueryPtr net_query, Promise<NetQue
return on_read_history(std::move(net_query)); return on_read_history(std::move(net_query));
case static_cast<uint8>(QueryType::Ignore): case static_cast<uint8>(QueryType::Ignore):
return Status::OK(); return Status::OK();
} default:
UNREACHABLE(); UNREACHABLE();
return Status::OK();
}
}()); }());
loop(); loop();
@ -963,8 +965,8 @@ Status SecretChatActor::do_inbound_message_decrypted_unchecked(unique_ptr<log_ev
auto *action_resend = auto *action_resend =
static_cast<secret_api::decryptedMessageActionResend *>(decrypted_message_service->action_.get()); static_cast<secret_api::decryptedMessageActionResend *>(decrypted_message_service->action_.get());
uint32 start_seq_no = static_cast<uint32>(action_resend->start_seq_no_ / 2); auto start_seq_no = static_cast<uint32>(action_resend->start_seq_no_ / 2);
uint32 finish_seq_no = static_cast<uint32>(action_resend->end_seq_no_ / 2); auto finish_seq_no = static_cast<uint32>(action_resend->end_seq_no_ / 2);
if (start_seq_no + MAX_RESEND_COUNT < finish_seq_no) { if (start_seq_no + MAX_RESEND_COUNT < finish_seq_no) {
message->promise.set_value(Unit()); message->promise.set_value(Unit());
return Status::Error(PSLICE() << "Won't resend more than " << MAX_RESEND_COUNT << " messages"); return Status::Error(PSLICE() << "Won't resend more than " << MAX_RESEND_COUNT << " messages");
@ -1976,29 +1978,36 @@ void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionSetMe
context_->secret_chat_db()->set_value(config_state_); context_->secret_chat_db()->set_value(config_state_);
send_update_secret_chat(); send_update_secret_chat();
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionReadMessages &read_messages) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionReadMessages &read_messages) {
// TODO // TODO
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionDeleteMessages &delete_messages) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionDeleteMessages &delete_messages) {
// Corresponding log event won't be deleted before promise returned by add_changes is set. // Corresponding log event won't be deleted before promise returned by add_changes is set.
on_delete_messages(delete_messages.random_ids_).ensure(); on_delete_messages(delete_messages.random_ids_).ensure();
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionScreenshotMessages &screenshot) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionScreenshotMessages &screenshot) {
// noting to do // nothing to do
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionFlushHistory &flush_history) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionFlushHistory &flush_history) {
on_flush_history(pfs_state_.message_id).ensure(); on_flush_history(pfs_state_.message_id).ensure();
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionResend &resend) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionResend &resend) {
if (seq_no_state_.resend_end_seq_no < resend.end_seq_no_ / 2) { // replay protection if (seq_no_state_.resend_end_seq_no < resend.end_seq_no_ / 2) { // replay protection
seq_no_state_.resend_end_seq_no = resend.end_seq_no_ / 2; seq_no_state_.resend_end_seq_no = resend.end_seq_no_ / 2;
on_seq_no_state_changed(); on_seq_no_state_changed();
} }
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionNotifyLayer &notify_layer) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionNotifyLayer &notify_layer) {
config_state_.my_layer = notify_layer.layer_; config_state_.my_layer = notify_layer.layer_;
context_->secret_chat_db()->set_value(config_state_); context_->secret_chat_db()->set_value(config_state_);
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionTyping &typing) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionTyping &typing) {
// noop // noop
} }
@ -2009,23 +2018,29 @@ Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionSetM
send_update_secret_chat(); send_update_secret_chat();
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionReadMessages &read_messages) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionReadMessages &read_messages) {
// TODO // TODO
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionDeleteMessages &delete_messages) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionDeleteMessages &delete_messages) {
return on_delete_messages(delete_messages.random_ids_); return on_delete_messages(delete_messages.random_ids_);
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionScreenshotMessages &screenshot) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionScreenshotMessages &screenshot) {
// TODO // TODO
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionFlushHistory &screenshot) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionFlushHistory &screenshot) {
return on_flush_history(pfs_state_.message_id); return on_flush_history(pfs_state_.message_id);
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionResend &resend) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionResend &resend) {
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionNotifyLayer &notify_layer) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionNotifyLayer &notify_layer) {
if (notify_layer.layer_ > config_state_.his_layer) { if (notify_layer.layer_ > config_state_.his_layer) {
config_state_.his_layer = notify_layer.layer_; config_state_.his_layer = notify_layer.layer_;
@ -2034,6 +2049,7 @@ Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionNoti
} }
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionTyping &typing) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionTyping &typing) {
// noop // noop
return Status::OK(); return Status::OK();
@ -2045,16 +2061,19 @@ void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionReque
pfs_state_.state = PfsState::WaitRequestResponse; pfs_state_.state = PfsState::WaitRequestResponse;
on_pfs_state_changed(); on_pfs_state_changed();
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionAcceptKey &accept_key) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionAcceptKey &accept_key) {
CHECK(pfs_state_.state == PfsState::WaitSendAccept || pfs_state_.state == PfsState::SendAccept); CHECK(pfs_state_.state == PfsState::WaitSendAccept || pfs_state_.state == PfsState::SendAccept);
pfs_state_.state = PfsState::WaitAcceptResponse; pfs_state_.state = PfsState::WaitAcceptResponse;
pfs_state_.handshake = mtproto::DhHandshake(); pfs_state_.handshake = mtproto::DhHandshake();
on_pfs_state_changed(); on_pfs_state_changed();
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionAbortKey &abort_key) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionAbortKey &abort_key) {
// TODO // TODO
LOG(FATAL) << "TODO"; LOG(FATAL) << "TODO";
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionCommitKey &commit_key) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionCommitKey &commit_key) {
CHECK(pfs_state_.state == PfsState::WaitSendCommit || pfs_state_.state == PfsState::SendCommit); CHECK(pfs_state_.state == PfsState::WaitSendCommit || pfs_state_.state == PfsState::SendCommit);
@ -2069,11 +2088,11 @@ void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionCommi
on_pfs_state_changed(); on_pfs_state_changed();
} }
void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionNoop &noop) { void SecretChatActor::on_outbound_action(secret_api::decryptedMessageActionNoop &noop) {
// noop // noop
} }
// decryptedMessageActionRequestKey#f3c9611b exchange_id:long g_a:bytes = DecryptedMessageAction;
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionRequestKey &request_key) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionRequestKey &request_key) {
if (pfs_state_.state == PfsState::WaitRequestResponse || pfs_state_.state == PfsState::SendRequest) { if (pfs_state_.state == PfsState::WaitRequestResponse || pfs_state_.state == PfsState::SendRequest) {
if (pfs_state_.exchange_id > request_key.exchange_id_) { if (pfs_state_.exchange_id > request_key.exchange_id_) {
@ -2112,7 +2131,6 @@ Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionRequ
return Status::OK(); return Status::OK();
} }
// decryptedMessageActionAcceptKey#6fe1735b exchange_id:long g_b:bytes key_fingerprint:long = DecryptedMessageAction;
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionAcceptKey &accept_key) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionAcceptKey &accept_key) {
if (pfs_state_.state != PfsState::WaitRequestResponse) { if (pfs_state_.state != PfsState::WaitRequestResponse) {
return Status::Error("AcceptKey: unexpected"); return Status::Error("AcceptKey: unexpected");
@ -2136,6 +2154,7 @@ Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionAcce
on_pfs_state_changed(); on_pfs_state_changed();
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionAbortKey &abort_key) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionAbortKey &abort_key) {
if (pfs_state_.exchange_id != abort_key.exchange_id_) { if (pfs_state_.exchange_id != abort_key.exchange_id_) {
LOG(INFO) << "AbortKey: exchange_id mismatch: " << tag("my exchange_id", pfs_state_.exchange_id) LOG(INFO) << "AbortKey: exchange_id mismatch: " << tag("my exchange_id", pfs_state_.exchange_id)
@ -2151,6 +2170,7 @@ Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionAbor
on_pfs_state_changed(); on_pfs_state_changed();
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionCommitKey &commit_key) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionCommitKey &commit_key) {
if (pfs_state_.state != PfsState::WaitAcceptResponse) { if (pfs_state_.state != PfsState::WaitAcceptResponse) {
return Status::Error("CommitKey: unexpected"); return Status::Error("CommitKey: unexpected");
@ -2174,6 +2194,7 @@ Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionComm
on_pfs_state_changed(); on_pfs_state_changed();
return Status::OK(); return Status::OK();
} }
Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionNoop &noop) { Status SecretChatActor::on_inbound_action(secret_api::decryptedMessageActionNoop &noop) {
// noop // noop
return Status::OK(); return Status::OK();
@ -2224,7 +2245,6 @@ void SecretChatActor::on_outbound_action(secret_api::DecryptedMessageAction &act
downcast_call(action, [&](auto &obj) { this->on_outbound_action(obj); }); downcast_call(action, [&](auto &obj) { this->on_outbound_action(obj); });
} }
// decryptedMessageActionRequestKey#f3c9611b exchange_id:long g_a:bytes = DecryptedMessageAction;
void SecretChatActor::request_new_key() { void SecretChatActor::request_new_key() {
CHECK(!auth_state_.dh_config.empty()); CHECK(!auth_state_.dh_config.empty());

View File

@ -645,7 +645,7 @@ class SecretChatActor final : public NetQueryCallback {
Status save_common_info(T &update); Status save_common_info(T &update);
int32 current_layer() const { int32 current_layer() const {
int32 layer = static_cast<int32>(SecretChatLayer::Current); auto layer = static_cast<int32>(SecretChatLayer::Current);
if (config_state_.his_layer < layer) { if (config_state_.his_layer < layer) {
layer = config_state_.his_layer; layer = config_state_.his_layer;
} }

View File

@ -169,7 +169,7 @@ void SecretChatsManager::on_update_chat(tl_object_ptr<telegram_api::updateEncryp
return; return;
} }
bool chat_requested = update->chat_->get_id() == telegram_api::encryptedChatRequested::ID; bool chat_requested = update->chat_->get_id() == telegram_api::encryptedChatRequested::ID;
pending_chat_updates_.push_back({Timestamp::in(chat_requested ? 1 : 0), std::move(update)}); pending_chat_updates_.emplace_back(Timestamp::in(chat_requested ? 1 : 0), std::move(update));
flush_pending_chat_updates(); flush_pending_chat_updates();
} }

View File

@ -104,11 +104,11 @@ class SetSecureValue final : public NetQueryCallback {
void on_upload_ok(FileId file_id, tl_object_ptr<telegram_api::InputFile> input_file) final; void on_upload_ok(FileId file_id, tl_object_ptr<telegram_api::InputFile> input_file) final;
void on_upload_encrypted_ok(FileId file_id, tl_object_ptr<telegram_api::InputEncryptedFile> input_file) final; void on_upload_encrypted_ok(FileId file_id, tl_object_ptr<telegram_api::InputEncryptedFile> input_file) final;
void on_upload_secure_ok(FileId file_id, tl_object_ptr<telegram_api::InputSecureFile> input_file) final; void on_upload_secure_ok(FileId file_id, tl_object_ptr<telegram_api::InputSecureFile> input_file) final;
void on_upload_error(FileId file_id, Status status) final; void on_upload_error(FileId file_id, Status error) final;
}; };
void on_upload_ok(FileId file_id, tl_object_ptr<telegram_api::InputSecureFile> input_file, uint32 upload_generation); void on_upload_ok(FileId file_id, tl_object_ptr<telegram_api::InputSecureFile> input_file, uint32 upload_generation);
void on_upload_error(FileId file_id, Status status, uint32 upload_generation); void on_upload_error(FileId file_id, Status error, uint32 upload_generation);
void on_error(Status error); void on_error(Status error);
@ -125,7 +125,7 @@ class SetSecureValue final : public NetQueryCallback {
void cancel_upload(); void cancel_upload();
void start_upload_all(); void start_upload_all();
void start_upload(FileManager *file_manager, FileId &file_id, SecureInputFile &info); void start_upload(FileManager *file_manager, FileId &file_id, SecureInputFile &info);
void merge(FileManager *file_manager, FileId file_id, EncryptedSecureFile &encrypted_file); static void merge(FileManager *file_manager, FileId file_id, EncryptedSecureFile &encrypted_file);
}; };
class SetSecureValueErrorsQuery final : public Td::ResultHandler { class SetSecureValueErrorsQuery final : public Td::ResultHandler {
@ -285,7 +285,7 @@ void GetAllSecureValues::loop() {
auto secure_values = transform(r_secure_values.move_as_ok(), auto secure_values = transform(r_secure_values.move_as_ok(),
[](SecureValueWithCredentials &&value) { return std::move(value.value); }); [](SecureValueWithCredentials &&value) { return std::move(value.value); });
promise_.set_value(get_passport_elements_object(file_manager, std::move(secure_values))); promise_.set_value(get_passport_elements_object(file_manager, secure_values));
stop(); stop();
} }
@ -959,7 +959,7 @@ void SecureManager::get_passport_authorization_form(UserId bot_user_id, string s
form.bot_user_id = bot_user_id; form.bot_user_id = bot_user_id;
form.scope = scope; form.scope = scope;
form.public_key = public_key; form.public_key = public_key;
form.nonce = nonce; form.nonce = std::move(nonce);
auto new_promise = PromiseCreator::lambda( auto new_promise = PromiseCreator::lambda(
[actor_id = actor_id(this), authorization_form_id, promise = std::move(promise)]( [actor_id = actor_id(this), authorization_form_id, promise = std::move(promise)](
Result<telegram_api::object_ptr<telegram_api::account_authorizationForm>> r_authorization_form) mutable { Result<telegram_api::object_ptr<telegram_api::account_authorizationForm>> r_authorization_form) mutable {
@ -1100,7 +1100,7 @@ void SecureManager::on_get_passport_authorization_form_secret(int32 authorizatio
on_get_secure_value(r_secure_value.ok()); on_get_secure_value(r_secure_value.ok());
auto secure_value = r_secure_value.move_as_ok(); auto secure_value = r_secure_value.move_as_ok();
auto r_passport_element = get_passport_element_object(file_manager, std::move(secure_value.value)); auto r_passport_element = get_passport_element_object(file_manager, secure_value.value);
if (r_passport_element.is_error()) { if (r_passport_element.is_error()) {
LOG(ERROR) << "Failed to get passport element object: " << r_passport_element.error(); LOG(ERROR) << "Failed to get passport element object: " << r_passport_element.error();
break; break;

View File

@ -39,9 +39,13 @@ class SecureManager final : public NetQueryCallback {
explicit SecureManager(ActorShared<> parent); explicit SecureManager(ActorShared<> parent);
void get_secure_value(std::string password, SecureValueType type, Promise<TdApiSecureValue> promise); void get_secure_value(std::string password, SecureValueType type, Promise<TdApiSecureValue> promise);
void get_all_secure_values(std::string password, Promise<TdApiSecureValues> promise); void get_all_secure_values(std::string password, Promise<TdApiSecureValues> promise);
void set_secure_value(string password, SecureValue secure_value, Promise<TdApiSecureValue> promise); void set_secure_value(string password, SecureValue secure_value, Promise<TdApiSecureValue> promise);
void delete_secure_value(SecureValueType type, Promise<Unit> promise); void delete_secure_value(SecureValueType type, Promise<Unit> promise);
void set_secure_value_errors(Td *td, tl_object_ptr<telegram_api::InputUser> input_user, void set_secure_value_errors(Td *td, tl_object_ptr<telegram_api::InputUser> input_user,
vector<tl_object_ptr<td_api::inputPassportElementError>> errors, Promise<Unit> promise); vector<tl_object_ptr<td_api::inputPassportElementError>> errors, Promise<Unit> promise);

View File

@ -208,7 +208,7 @@ Secret Secret::create_new() {
auto secret_slice = ::td::as_slice(secret); auto secret_slice = ::td::as_slice(secret);
Random::secure_bytes(secret_slice); Random::secure_bytes(secret_slice);
auto checksum_diff = secret_checksum(secret_slice); auto checksum_diff = secret_checksum(secret_slice);
uint8 new_byte = static_cast<uint8>((static_cast<uint32>(secret_slice.ubegin()[0]) + checksum_diff) % 255); auto new_byte = static_cast<uint8>((static_cast<uint32>(secret_slice.ubegin()[0]) + checksum_diff) % 255);
secret_slice.ubegin()[0] = new_byte; secret_slice.ubegin()[0] = new_byte;
return create(secret_slice).move_as_ok(); return create(secret_slice).move_as_ok();
} }
@ -364,7 +364,7 @@ Result<BufferSlice> decrypt_value(const Secret &secret, const ValueHash &hash, S
return std::move(decrypted_value); return std::move(decrypted_value);
} }
Result<ValueHash> encrypt_file(const Secret &secret, std::string src, std::string dest) { Result<ValueHash> encrypt_file(const Secret &secret, const string &src, const string &dest) {
TRY_RESULT(src_file, FileFd::open(src, FileFd::Flags::Read)); TRY_RESULT(src_file, FileFd::open(src, FileFd::Flags::Read));
TRY_RESULT(dest_file, FileFd::open(dest, FileFd::Flags::Truncate | FileFd::Flags::Write | FileFd::Create)); TRY_RESULT(dest_file, FileFd::open(dest, FileFd::Flags::Truncate | FileFd::Flags::Write | FileFd::Create));
TRY_RESULT(src_file_size, src_file.get_size()); TRY_RESULT(src_file_size, src_file.get_size());
@ -382,7 +382,7 @@ Result<ValueHash> encrypt_file(const Secret &secret, std::string src, std::strin
return std::move(hash); return std::move(hash);
} }
Status decrypt_file(const Secret &secret, const ValueHash &hash, std::string src, std::string dest) { Status decrypt_file(const Secret &secret, const ValueHash &hash, const string &src, const string &dest) {
TRY_RESULT(src_file, FileFd::open(src, FileFd::Flags::Read)); TRY_RESULT(src_file, FileFd::open(src, FileFd::Flags::Read));
TRY_RESULT(dest_file, FileFd::open(dest, FileFd::Flags::Truncate | FileFd::Flags::Write | FileFd::Create)); TRY_RESULT(dest_file, FileFd::open(dest, FileFd::Flags::Truncate | FileFd::Flags::Write | FileFd::Create));
TRY_RESULT(src_file_size, src_file.get_size()); TRY_RESULT(src_file_size, src_file.get_size());

View File

@ -184,10 +184,12 @@ struct EncryptedValue {
}; };
Result<EncryptedValue> encrypt_value(const Secret &secret, Slice data); Result<EncryptedValue> encrypt_value(const Secret &secret, Slice data);
Result<ValueHash> encrypt_file(const Secret &secret, std::string src, std::string dest);
Result<BufferSlice> decrypt_value(const Secret &secret, const ValueHash &hash, Slice data); Result<BufferSlice> decrypt_value(const Secret &secret, const ValueHash &hash, Slice data);
Status decrypt_file(const Secret &secret, const ValueHash &hash, std::string src, std::string dest);
Result<ValueHash> encrypt_file(const Secret &secret, const string &src, const string &dest);
Status decrypt_file(const Secret &secret, const ValueHash &hash, const string &src, const string &dest);
} // namespace secure_storage } // namespace secure_storage
} // namespace td } // namespace td

View File

@ -847,8 +847,7 @@ static Status check_document_number(string &number) {
} }
static Result<DatedFile> get_secure_file(FileManager *file_manager, td_api::object_ptr<td_api::InputFile> &&file) { static Result<DatedFile> get_secure_file(FileManager *file_manager, td_api::object_ptr<td_api::InputFile> &&file) {
TRY_RESULT(file_id, TRY_RESULT(file_id, file_manager->get_input_file_id(FileType::Secure, file, DialogId(), false, false, false, true));
file_manager->get_input_file_id(FileType::Secure, std::move(file), DialogId(), false, false, false, true));
DatedFile result; DatedFile result;
result.file_id = file_id; result.file_id = file_id;
result.date = G()->unix_time(); result.date = G()->unix_time();
@ -1293,7 +1292,7 @@ static EncryptedSecureFile encrypt_secure_file(FileManager *file_manager, const
static vector<EncryptedSecureFile> encrypt_secure_files(FileManager *file_manager, static vector<EncryptedSecureFile> encrypt_secure_files(FileManager *file_manager,
const secure_storage::Secret &master_secret, const secure_storage::Secret &master_secret,
vector<DatedFile> files, string &to_hash) { const vector<DatedFile> &files, string &to_hash) {
return transform( return transform(
files, [&](auto dated_file) { return encrypt_secure_file(file_manager, master_secret, dated_file, to_hash); }); files, [&](auto dated_file) { return encrypt_secure_file(file_manager, master_secret, dated_file, to_hash); });
/* /*

View File

@ -53,9 +53,9 @@ telegram_api::object_ptr<telegram_api::codeSettings> SendCodeHelper::get_input_c
false /*ignored*/); false /*ignored*/);
} }
telegram_api::auth_sendCode SendCodeHelper::send_code(Slice phone_number, const Settings &settings, int32 api_id, telegram_api::auth_sendCode SendCodeHelper::send_code(string phone_number, const Settings &settings, int32 api_id,
const string &api_hash) { const string &api_hash) {
phone_number_ = phone_number.str(); phone_number_ = std::move(phone_number);
return telegram_api::auth_sendCode(phone_number_, api_id, api_hash, get_input_code_settings(settings)); return telegram_api::auth_sendCode(phone_number_, api_id, api_hash, get_input_code_settings(settings));
} }
@ -86,11 +86,11 @@ SendCodeHelper::AuthenticationCodeInfo SendCodeHelper::get_authentication_code_i
switch (code_type_ptr->get_id()) { switch (code_type_ptr->get_id()) {
case telegram_api::auth_codeTypeSms::ID: case telegram_api::auth_codeTypeSms::ID:
return {AuthenticationCodeInfo::Type::Sms, 0, ""}; return {AuthenticationCodeInfo::Type::Sms, 0, string()};
case telegram_api::auth_codeTypeCall::ID: case telegram_api::auth_codeTypeCall::ID:
return {AuthenticationCodeInfo::Type::Call, 0, ""}; return {AuthenticationCodeInfo::Type::Call, 0, string()};
case telegram_api::auth_codeTypeFlashCall::ID: case telegram_api::auth_codeTypeFlashCall::ID:
return {AuthenticationCodeInfo::Type::FlashCall, 0, ""}; return {AuthenticationCodeInfo::Type::FlashCall, 0, string()};
default: default:
UNREACHABLE(); UNREACHABLE();
return AuthenticationCodeInfo(); return AuthenticationCodeInfo();

View File

@ -25,7 +25,7 @@ class SendCodeHelper {
using Settings = td_api::object_ptr<td_api::phoneNumberAuthenticationSettings>; using Settings = td_api::object_ptr<td_api::phoneNumberAuthenticationSettings>;
telegram_api::auth_sendCode send_code(Slice phone_number, const Settings &settings, int32 api_id, telegram_api::auth_sendCode send_code(string phone_number, const Settings &settings, int32 api_id,
const string &api_hash); const string &api_hash);
telegram_api::account_sendChangePhoneCode send_change_phone_code(Slice phone_number, const Settings &settings); telegram_api::account_sendChangePhoneCode send_change_phone_code(Slice phone_number, const Settings &settings);

View File

@ -624,7 +624,7 @@ class ReorderStickerSetsQuery final : public Td::ResultHandler {
bool is_masks_; bool is_masks_;
public: public:
void send(bool is_masks, vector<StickerSetId> sticker_set_ids) { void send(bool is_masks, const vector<StickerSetId> &sticker_set_ids) {
is_masks_ = is_masks; is_masks_ = is_masks;
int32 flags = 0; int32 flags = 0;
if (is_masks) { if (is_masks) {
@ -833,7 +833,7 @@ class UninstallStickerSetQuery final : public Td::ResultHandler {
class ReadFeaturedStickerSetsQuery final : public Td::ResultHandler { class ReadFeaturedStickerSetsQuery final : public Td::ResultHandler {
public: public:
void send(vector<StickerSetId> sticker_set_ids) { void send(const vector<StickerSetId> &sticker_set_ids) {
LOG(INFO) << "Read trending sticker sets " << format::as_array(sticker_set_ids); LOG(INFO) << "Read trending sticker sets " << format::as_array(sticker_set_ids);
send_query(G()->net_query_creator().create( send_query(G()->net_query_creator().create(
telegram_api::messages_readFeaturedStickers(StickersManager::convert_sticker_set_ids(sticker_set_ids)))); telegram_api::messages_readFeaturedStickers(StickersManager::convert_sticker_set_ids(sticker_set_ids))));
@ -2340,11 +2340,11 @@ void StickersManager::add_sticker_thumbnail(Sticker *s, PhotoSize thumbnail) {
return; return;
} }
if (thumbnail.type == 'm') { if (thumbnail.type == 'm') {
s->m_thumbnail = thumbnail; s->m_thumbnail = std::move(thumbnail);
return; return;
} }
if (thumbnail.type == 's' || thumbnail.type == 't') { if (thumbnail.type == 's' || thumbnail.type == 't') {
s->s_thumbnail = thumbnail; s->s_thumbnail = std::move(thumbnail);
return; return;
} }
LOG(ERROR) << "Receive sticker thumbnail of unsupported type " << thumbnail.type; LOG(ERROR) << "Receive sticker thumbnail of unsupported type " << thumbnail.type;
@ -2364,7 +2364,7 @@ void StickersManager::create_sticker(FileId file_id, string minithumbnail, Photo
if (!td_->auth_manager_->is_bot()) { if (!td_->auth_manager_->is_bot()) {
s->minithumbnail = std::move(minithumbnail); s->minithumbnail = std::move(minithumbnail);
} }
add_sticker_thumbnail(s.get(), thumbnail); add_sticker_thumbnail(s.get(), std::move(thumbnail));
if (sticker != nullptr) { if (sticker != nullptr) {
s->set_id = on_get_input_sticker_set(file_id, std::move(sticker->stickerset_), load_data_multipromise_ptr); s->set_id = on_get_input_sticker_set(file_id, std::move(sticker->stickerset_), load_data_multipromise_ptr);
s->alt = std::move(sticker->alt_); s->alt = std::move(sticker->alt_);
@ -4343,15 +4343,15 @@ void StickersManager::schedule_update_animated_emoji_clicked(const StickerSet *s
auto now = Time::now(); auto now = Time::now();
auto start_time = max(now, next_update_animated_emoji_clicked_time_); auto start_time = max(now, next_update_animated_emoji_clicked_time_);
for (size_t i = 0; i < clicks.size(); i++) { for (const auto &click : clicks) {
auto index = clicks[i].first; auto index = click.first;
auto sticker_id = sticker_ids[index]; auto sticker_id = sticker_ids[index];
if (!sticker_id.is_valid()) { if (!sticker_id.is_valid()) {
LOG(INFO) << "Failed to find sticker for " << emoji << " with index " << index; LOG(INFO) << "Failed to find sticker for " << emoji << " with index " << index;
return; return;
} }
create_actor<SleepActor>( create_actor<SleepActor>(
"SendUpdateAnimatedEmojiClicked", start_time + clicks[i].second - now, "SendUpdateAnimatedEmojiClicked", start_time + click.second - now,
PromiseCreator::lambda([actor_id = actor_id(this), full_message_id, sticker_id](Result<Unit> result) { PromiseCreator::lambda([actor_id = actor_id(this), full_message_id, sticker_id](Result<Unit> result) {
send_closure(actor_id, &StickersManager::send_update_animated_emoji_clicked, full_message_id, sticker_id); send_closure(actor_id, &StickersManager::send_update_animated_emoji_clicked, full_message_id, sticker_id);
})) }))
@ -5482,7 +5482,7 @@ void StickersManager::on_new_stickers_uploaded(int64 random_id, Result<Unit> res
td_->create_handler<CreateNewStickerSetQuery>(std::move(pending_new_sticker_set->promise)) td_->create_handler<CreateNewStickerSetQuery>(std::move(pending_new_sticker_set->promise))
->send(std::move(input_user), pending_new_sticker_set->title, pending_new_sticker_set->short_name, is_masks, ->send(std::move(input_user), pending_new_sticker_set->title, pending_new_sticker_set->short_name, is_masks,
is_animated, std::move(input_stickers), std::move(pending_new_sticker_set->software)); is_animated, std::move(input_stickers), pending_new_sticker_set->software);
} }
void StickersManager::add_sticker_to_set(UserId user_id, string &short_name, void StickersManager::add_sticker_to_set(UserId user_id, string &short_name,

View File

@ -173,7 +173,7 @@ class StickersManager final : public Actor {
FileId upload_sticker_file(UserId user_id, tl_object_ptr<td_api::InputSticker> &&sticker, Promise<Unit> &&promise); FileId upload_sticker_file(UserId user_id, tl_object_ptr<td_api::InputSticker> &&sticker, Promise<Unit> &&promise);
void get_suggested_sticker_set_name(string short_name, Promise<string> &&promise); void get_suggested_sticker_set_name(string title, Promise<string> &&promise);
enum class CheckStickerSetNameResult : uint8 { Ok, Invalid, Occupied }; enum class CheckStickerSetNameResult : uint8 { Ok, Invalid, Occupied };
void check_sticker_set_name(const string &name, Promise<CheckStickerSetNameResult> &&promise); void check_sticker_set_name(const string &name, Promise<CheckStickerSetNameResult> &&promise);
@ -282,7 +282,7 @@ class StickersManager final : public Actor {
void on_uploaded_sticker_file(FileId file_id, tl_object_ptr<telegram_api::MessageMedia> media, void on_uploaded_sticker_file(FileId file_id, tl_object_ptr<telegram_api::MessageMedia> media,
Promise<Unit> &&promise); Promise<Unit> &&promise);
void on_find_stickers_success(const string &emoji, tl_object_ptr<telegram_api::messages_Stickers> &&sticker_sets); void on_find_stickers_success(const string &emoji, tl_object_ptr<telegram_api::messages_Stickers> &&stickers);
void on_find_stickers_fail(const string &emoji, Status &&error); void on_find_stickers_fail(const string &emoji, Status &&error);

View File

@ -165,7 +165,7 @@ void StickersManager::store_sticker_set(const StickerSet *sticker_set, bool with
store(sticker_set->minithumbnail, storer); store(sticker_set->minithumbnail, storer);
} }
uint32 stored_sticker_count = narrow_cast<uint32>(is_full ? sticker_set->sticker_ids.size() : stickers_limit); auto stored_sticker_count = narrow_cast<uint32>(is_full ? sticker_set->sticker_ids.size() : stickers_limit);
store(stored_sticker_count, storer); store(stored_sticker_count, storer);
for (uint32 i = 0; i < stored_sticker_count; i++) { for (uint32 i = 0; i < stored_sticker_count; i++) {
auto sticker_id = sticker_set->sticker_ids[i]; auto sticker_id = sticker_set->sticker_ids[i];

View File

@ -65,7 +65,7 @@ void StorageManager::get_storage_stats(bool need_all_files, int32 dialog_limit,
if (is_closed_) { if (is_closed_) {
return promise.set_error(Global::request_aborted_error()); return promise.set_error(Global::request_aborted_error());
} }
if (pending_storage_stats_.size() != 0) { if (!pending_storage_stats_.empty()) {
if (stats_dialog_limit_ == dialog_limit && need_all_files == stats_need_all_files_) { if (stats_dialog_limit_ == dialog_limit && need_all_files == stats_need_all_files_) {
pending_storage_stats_.emplace_back(std::move(promise)); pending_storage_stats_.emplace_back(std::move(promise));
return; return;
@ -118,11 +118,11 @@ void StorageManager::run_gc(FileGcParameters parameters, bool return_deleted_fil
bool split_by_owner_dialog_id = !parameters.owner_dialog_ids.empty() || bool split_by_owner_dialog_id = !parameters.owner_dialog_ids.empty() ||
!parameters.exclude_owner_dialog_ids.empty() || parameters.dialog_limit != 0; !parameters.exclude_owner_dialog_ids.empty() || parameters.dialog_limit != 0;
get_storage_stats(true /*need_all_files*/, split_by_owner_dialog_id, get_storage_stats(
true /*need_all_files*/, split_by_owner_dialog_id,
PromiseCreator::lambda( PromiseCreator::lambda(
[actor_id = actor_id(this), parameters = std::move(parameters)](Result<FileStats> file_stats) { [actor_id = actor_id(this), parameters = std::move(parameters)](Result<FileStats> file_stats) mutable {
send_closure(actor_id, &StorageManager::on_all_files, std::move(parameters), send_closure(actor_id, &StorageManager::on_all_files, std::move(parameters), std::move(file_stats));
std::move(file_stats));
})); }));
//NB: get_storage_stats will cancel all garbage collection queries, so promise needs to be added after the call //NB: get_storage_stats will cancel all garbage collection queries, so promise needs to be added after the call

View File

@ -24,7 +24,7 @@ namespace td {
struct DatabaseStats { struct DatabaseStats {
string debug; string debug;
DatabaseStats() = default; DatabaseStats() = default;
explicit DatabaseStats(string debug) : debug(debug) { explicit DatabaseStats(string debug) : debug(std::move(debug)) {
} }
tl_object_ptr<td_api::databaseStatistics> get_database_statistics_object() const; tl_object_ptr<td_api::databaseStatistics> get_database_statistics_object() const;
}; };
@ -64,7 +64,7 @@ class StorageManager final : public Actor {
void on_file_stats(Result<FileStats> r_file_stats, uint32 generation); void on_file_stats(Result<FileStats> r_file_stats, uint32 generation);
void create_stats_worker(); void create_stats_worker();
void update_fast_stats(const FileStats &stats); void update_fast_stats(const FileStats &stats);
void send_stats(FileStats &&stats, int32 dialog_limit, std::vector<Promise<FileStats>> &&promises); static void send_stats(FileStats &&stats, int32 dialog_limit, std::vector<Promise<FileStats>> &&promises);
void save_fast_stat(); void save_fast_stat();
void load_fast_stat(); void load_fast_stat();

View File

@ -142,8 +142,7 @@ void update_suggested_actions(vector<SuggestedAction> &suggested_actions,
} }
CHECK(!added_actions.empty() || !removed_actions.empty()); CHECK(!added_actions.empty() || !removed_actions.empty());
suggested_actions = std::move(new_suggested_actions); suggested_actions = std::move(new_suggested_actions);
send_closure(G()->td(), &Td::send_update, send_closure(G()->td(), &Td::send_update, get_update_suggested_actions_object(added_actions, removed_actions));
get_update_suggested_actions_object(std::move(added_actions), std::move(removed_actions)));
} }
void remove_suggested_action(vector<SuggestedAction> &suggested_actions, SuggestedAction suggested_action) { void remove_suggested_action(vector<SuggestedAction> &suggested_actions, SuggestedAction suggested_action) {

View File

@ -801,8 +801,8 @@ class LoadChatsRequest final : public RequestActor<> {
// 1 for database + 1 for server request + 1 for server request at the end + 1 for return + 1 just in case // 1 for database + 1 for server request + 1 for server request at the end + 1 for return + 1 just in case
set_tries(5); set_tries(5);
if (limit > 100) { if (limit_ > 100) {
limit = 100; limit_ = 100;
} }
} }
}; };
@ -2826,10 +2826,11 @@ void Td::on_get_terms_of_service(Result<std::pair<int32, TermsOfService>> result
if (result.is_error()) { if (result.is_error()) {
expires_in = Random::fast(10, 60); expires_in = Random::fast(10, 60);
} else { } else {
pending_terms_of_service_ = std::move(result.ok().second); auto terms = result.move_as_ok();
pending_terms_of_service_ = std::move(terms.second);
auto update = get_update_terms_of_service_object(); auto update = get_update_terms_of_service_object();
if (update == nullptr) { if (update == nullptr) {
expires_in = min(max(result.ok().first, G()->unix_time() + 3600) - G()->unix_time(), 86400); expires_in = min(max(terms.first, G()->unix_time() + 3600) - G()->unix_time(), 86400);
} else { } else {
send_update(std::move(update)); send_update(std::move(update));
} }
@ -4091,7 +4092,7 @@ void Td::init_file_manager() {
} }
void reload_photo(PhotoSizeSource source, Promise<Unit> promise) final { void reload_photo(PhotoSizeSource source, Promise<Unit> promise) final {
send_closure(G()->file_reference_manager(), &FileReferenceManager::reload_photo, source, std::move(promise)); FileReferenceManager::reload_photo(std::move(source), std::move(promise));
} }
ActorShared<> create_reference() final { ActorShared<> create_reference() final {
@ -4530,7 +4531,7 @@ void Td::on_request(uint64 id, td_api::checkAuthenticationBotToken &request) {
void Td::on_request(uint64 id, td_api::confirmQrCodeAuthentication &request) { void Td::on_request(uint64 id, td_api::confirmQrCodeAuthentication &request) {
CLEAN_INPUT_STRING(request.link_); CLEAN_INPUT_STRING(request.link_);
CREATE_REQUEST_PROMISE(); CREATE_REQUEST_PROMISE();
contacts_manager_->confirm_qr_code_authentication(std::move(request.link_), std::move(promise)); contacts_manager_->confirm_qr_code_authentication(request.link_, std::move(promise));
} }
void Td::on_request(uint64 id, const td_api::getCurrentState &request) { void Td::on_request(uint64 id, const td_api::getCurrentState &request) {
@ -4624,7 +4625,7 @@ void Td::on_request(uint64 id, td_api::checkRecoveryEmailAddressCode &request) {
CHECK_IS_USER(); CHECK_IS_USER();
CLEAN_INPUT_STRING(request.code_); CLEAN_INPUT_STRING(request.code_);
CREATE_REQUEST_PROMISE(); CREATE_REQUEST_PROMISE();
send_closure(password_manager_, &PasswordManager::check_recovery_email_address_code, request.code_, send_closure(password_manager_, &PasswordManager::check_recovery_email_address_code, std::move(request.code_),
std::move(promise)); std::move(promise));
} }
@ -5533,7 +5534,7 @@ void Td::on_request(uint64 id, td_api::editInlineMessageText &request) {
CHECK_IS_BOT(); CHECK_IS_BOT();
CLEAN_INPUT_STRING(request.inline_message_id_); CLEAN_INPUT_STRING(request.inline_message_id_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
messages_manager_->edit_inline_message_text(std::move(request.inline_message_id_), std::move(request.reply_markup_), messages_manager_->edit_inline_message_text(request.inline_message_id_, std::move(request.reply_markup_),
std::move(request.input_message_content_), std::move(promise)); std::move(request.input_message_content_), std::move(promise));
} }
@ -5541,16 +5542,16 @@ void Td::on_request(uint64 id, td_api::editInlineMessageLiveLocation &request) {
CHECK_IS_BOT(); CHECK_IS_BOT();
CLEAN_INPUT_STRING(request.inline_message_id_); CLEAN_INPUT_STRING(request.inline_message_id_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
messages_manager_->edit_inline_message_live_location( messages_manager_->edit_inline_message_live_location(request.inline_message_id_, std::move(request.reply_markup_),
std::move(request.inline_message_id_), std::move(request.reply_markup_), std::move(request.location_), std::move(request.location_), request.heading_,
request.heading_, request.proximity_alert_radius_, std::move(promise)); request.proximity_alert_radius_, std::move(promise));
} }
void Td::on_request(uint64 id, td_api::editInlineMessageMedia &request) { void Td::on_request(uint64 id, td_api::editInlineMessageMedia &request) {
CHECK_IS_BOT(); CHECK_IS_BOT();
CLEAN_INPUT_STRING(request.inline_message_id_); CLEAN_INPUT_STRING(request.inline_message_id_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
messages_manager_->edit_inline_message_media(std::move(request.inline_message_id_), std::move(request.reply_markup_), messages_manager_->edit_inline_message_media(request.inline_message_id_, std::move(request.reply_markup_),
std::move(request.input_message_content_), std::move(promise)); std::move(request.input_message_content_), std::move(promise));
} }
@ -5558,17 +5559,16 @@ void Td::on_request(uint64 id, td_api::editInlineMessageCaption &request) {
CHECK_IS_BOT(); CHECK_IS_BOT();
CLEAN_INPUT_STRING(request.inline_message_id_); CLEAN_INPUT_STRING(request.inline_message_id_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
messages_manager_->edit_inline_message_caption(std::move(request.inline_message_id_), messages_manager_->edit_inline_message_caption(request.inline_message_id_, std::move(request.reply_markup_),
std::move(request.reply_markup_), std::move(request.caption_), std::move(request.caption_), std::move(promise));
std::move(promise));
} }
void Td::on_request(uint64 id, td_api::editInlineMessageReplyMarkup &request) { void Td::on_request(uint64 id, td_api::editInlineMessageReplyMarkup &request) {
CHECK_IS_BOT(); CHECK_IS_BOT();
CLEAN_INPUT_STRING(request.inline_message_id_); CLEAN_INPUT_STRING(request.inline_message_id_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
messages_manager_->edit_inline_message_reply_markup(std::move(request.inline_message_id_), messages_manager_->edit_inline_message_reply_markup(request.inline_message_id_, std::move(request.reply_markup_),
std::move(request.reply_markup_), std::move(promise)); std::move(promise));
} }
void Td::on_request(uint64 id, td_api::editMessageSchedulingState &request) { void Td::on_request(uint64 id, td_api::editMessageSchedulingState &request) {
@ -5589,8 +5589,8 @@ void Td::on_request(uint64 id, td_api::setInlineGameScore &request) {
CHECK_IS_BOT(); CHECK_IS_BOT();
CLEAN_INPUT_STRING(request.inline_message_id_); CLEAN_INPUT_STRING(request.inline_message_id_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
game_manager_->set_inline_game_score(std::move(request.inline_message_id_), request.edit_message_, game_manager_->set_inline_game_score(request.inline_message_id_, request.edit_message_, UserId(request.user_id_),
UserId(request.user_id_), request.score_, request.force_, std::move(promise)); request.score_, request.force_, std::move(promise));
} }
void Td::on_request(uint64 id, td_api::getGameHighScores &request) { void Td::on_request(uint64 id, td_api::getGameHighScores &request) {
@ -6202,8 +6202,8 @@ void Td::on_request(uint64 id, const td_api::leaveChat &request) {
} }
} }
contacts_manager_->set_dialog_participant_status( contacts_manager_->set_dialog_participant_status(
dialog_id, td_api::make_object<td_api::messageSenderUser>(contacts_manager_->get_my_id().get()), dialog_id, td_api::make_object<td_api::messageSenderUser>(contacts_manager_->get_my_id().get()), new_status,
std::move(new_status), std::move(promise)); std::move(promise));
} }
void Td::on_request(uint64 id, const td_api::addChatMember &request) { void Td::on_request(uint64 id, const td_api::addChatMember &request) {
@ -6222,8 +6222,8 @@ void Td::on_request(uint64 id, const td_api::addChatMembers &request) {
void Td::on_request(uint64 id, td_api::setChatMemberStatus &request) { void Td::on_request(uint64 id, td_api::setChatMemberStatus &request) {
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
contacts_manager_->set_dialog_participant_status(DialogId(request.chat_id_), std::move(request.member_id_), contacts_manager_->set_dialog_participant_status(DialogId(request.chat_id_), request.member_id_, request.status_,
request.status_, std::move(promise)); std::move(promise));
} }
void Td::on_request(uint64 id, const td_api::banChatMember &request) { void Td::on_request(uint64 id, const td_api::banChatMember &request) {
@ -6256,8 +6256,7 @@ void Td::on_request(uint64 id, td_api::transferChatOwnership &request) {
void Td::on_request(uint64 id, td_api::getChatMember &request) { void Td::on_request(uint64 id, td_api::getChatMember &request) {
CREATE_REQUEST_PROMISE(); CREATE_REQUEST_PROMISE();
contacts_manager_->get_dialog_participant(DialogId(request.chat_id_), std::move(request.member_id_), contacts_manager_->get_dialog_participant(DialogId(request.chat_id_), request.member_id_, std::move(promise));
std::move(promise));
} }
void Td::on_request(uint64 id, td_api::searchChatMembers &request) { void Td::on_request(uint64 id, td_api::searchChatMembers &request) {
@ -7044,7 +7043,8 @@ void Td::on_request(uint64 id, td_api::getStatisticalGraph &request) {
CHECK_IS_USER(); CHECK_IS_USER();
CLEAN_INPUT_STRING(request.token_); CLEAN_INPUT_STRING(request.token_);
CREATE_REQUEST_PROMISE(); CREATE_REQUEST_PROMISE();
contacts_manager_->load_statistics_graph(DialogId(request.chat_id_), request.token_, request.x_, std::move(promise)); contacts_manager_->load_statistics_graph(DialogId(request.chat_id_), std::move(request.token_), request.x_,
std::move(promise));
} }
void Td::on_request(uint64 id, td_api::setChatNotificationSettings &request) { void Td::on_request(uint64 id, td_api::setChatNotificationSettings &request) {
@ -7763,8 +7763,8 @@ void Td::on_request(uint64 id, td_api::sendEmailAddressVerificationCode &request
CHECK_IS_USER(); CHECK_IS_USER();
CLEAN_INPUT_STRING(request.email_address_); CLEAN_INPUT_STRING(request.email_address_);
CREATE_REQUEST_PROMISE(); CREATE_REQUEST_PROMISE();
send_closure(password_manager_, &PasswordManager::send_email_address_verification_code, request.email_address_, send_closure(password_manager_, &PasswordManager::send_email_address_verification_code,
std::move(promise)); std::move(request.email_address_), std::move(promise));
} }
void Td::on_request(uint64 id, const td_api::resendEmailAddressVerificationCode &request) { void Td::on_request(uint64 id, const td_api::resendEmailAddressVerificationCode &request) {
@ -7777,7 +7777,7 @@ void Td::on_request(uint64 id, td_api::checkEmailAddressVerificationCode &reques
CHECK_IS_USER(); CHECK_IS_USER();
CLEAN_INPUT_STRING(request.code_); CLEAN_INPUT_STRING(request.code_);
CREATE_OK_REQUEST_PROMISE(); CREATE_OK_REQUEST_PROMISE();
send_closure(password_manager_, &PasswordManager::check_email_address_verification_code, request.code_, send_closure(password_manager_, &PasswordManager::check_email_address_verification_code, std::move(request.code_),
std::move(promise)); std::move(promise));
} }
@ -8266,7 +8266,8 @@ td_api::object_ptr<td_api::Object> Td::do_static_request(const td_api::getLangua
td_api::object_ptr<td_api::Object> Td::do_static_request(const td_api::getPhoneNumberInfoSync &request) { td_api::object_ptr<td_api::Object> Td::do_static_request(const td_api::getPhoneNumberInfoSync &request) {
// don't check language_code/phone number UTF-8 correctness // don't check language_code/phone number UTF-8 correctness
return CountryInfoManager::get_phone_number_info_sync(request.language_code_, request.phone_number_prefix_); return CountryInfoManager::get_phone_number_info_sync(request.language_code_,
std::move(request.phone_number_prefix_));
} }
td_api::object_ptr<td_api::Object> Td::do_static_request(const td_api::getPushReceiverId &request) { td_api::object_ptr<td_api::Object> Td::do_static_request(const td_api::getPushReceiverId &request) {

View File

@ -328,7 +328,7 @@ class Td final : public Actor {
void on_get_terms_of_service(Result<std::pair<int32, TermsOfService>> result, bool dummy); void on_get_terms_of_service(Result<std::pair<int32, TermsOfService>> result, bool dummy);
void on_get_promo_data(Result<telegram_api::object_ptr<telegram_api::help_PromoData>> result, bool dummy); void on_get_promo_data(Result<telegram_api::object_ptr<telegram_api::help_PromoData>> r_promo_data, bool dummy);
template <class T> template <class T>
friend class RequestActor; // uses send_result/send_error friend class RequestActor; // uses send_result/send_error
@ -346,7 +346,7 @@ class Td final : public Actor {
void on_config_option_updated(const string &name); void on_config_option_updated(const string &name);
void send(NetQueryPtr &&query); static void send(NetQueryPtr &&query);
class OnRequest; class OnRequest;

View File

@ -52,7 +52,7 @@ std::string get_sqlite_path(const TdParameters &parameters) {
Result<TdDb::EncryptionInfo> check_encryption(string path) { Result<TdDb::EncryptionInfo> check_encryption(string path) {
Binlog binlog; Binlog binlog;
auto status = binlog.init(path, Binlog::Callback()); auto status = binlog.init(std::move(path), Binlog::Callback());
if (status.is_error() && status.code() != Binlog::Error::WrongPassword) { if (status.is_error() && status.code() != Binlog::Error::WrongPassword) {
LOG(WARNING) << "Failed to check binlog: " << status; LOG(WARNING) << "Failed to check binlog: " << status;
return Status::Error(400, status.message()); return Status::Error(400, status.message());
@ -281,7 +281,7 @@ void TdDb::do_close(Promise<> on_finished, bool destroy_flag) {
lock.set_value(Unit()); lock.set_value(Unit());
} }
Status TdDb::init_sqlite(int32 scheduler_id, const TdParameters &parameters, DbKey key, DbKey old_key, Status TdDb::init_sqlite(int32 scheduler_id, const TdParameters &parameters, const DbKey &key, const DbKey &old_key,
BinlogKeyValue<Binlog> &binlog_pmc) { BinlogKeyValue<Binlog> &binlog_pmc) {
CHECK(!parameters.use_message_db || parameters.use_chat_info_db); CHECK(!parameters.use_message_db || parameters.use_chat_info_db);
CHECK(!parameters.use_chat_info_db || parameters.use_file_db); CHECK(!parameters.use_chat_info_db || parameters.use_file_db);
@ -489,7 +489,7 @@ Status TdDb::destroy(const TdParameters &parameters) {
return Status::OK(); return Status::OK();
} }
void TdDb::with_db_path(std::function<void(CSlice)> callback) { void TdDb::with_db_path(const std::function<void(CSlice)> &callback) {
SqliteDb::with_db_path(sqlite_path(), callback); SqliteDb::with_db_path(sqlite_path(), callback);
callback(binlog_path()); callback(binlog_path());
} }

View File

@ -97,7 +97,7 @@ class TdDb {
void change_key(DbKey key, Promise<> promise); void change_key(DbKey key, Promise<> promise);
void with_db_path(std::function<void(CSlice)> callback); void with_db_path(const std::function<void(CSlice)> &callback);
Result<string> get_stats(); Result<string> get_stats();
@ -121,7 +121,7 @@ class TdDb {
std::shared_ptr<ConcurrentBinlog> binlog_; std::shared_ptr<ConcurrentBinlog> binlog_;
Status init(int32 scheduler_id, const TdParameters &parameters, DbKey key, Events &events); Status init(int32 scheduler_id, const TdParameters &parameters, DbKey key, Events &events);
Status init_sqlite(int32 scheduler_id, const TdParameters &parameters, DbKey key, DbKey old_key, Status init_sqlite(int32 scheduler_id, const TdParameters &parameters, const DbKey &key, const DbKey &old_key,
BinlogKeyValue<Binlog> &binlog_pmc); BinlogKeyValue<Binlog> &binlog_pmc);
void do_close(Promise<> on_finished, bool destroy_flag); void do_close(Promise<> on_finished, bool destroy_flag);

View File

@ -65,9 +65,9 @@ class AcceptTermsOfServiceQuery final : public Td::ResultHandler {
explicit AcceptTermsOfServiceQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) { explicit AcceptTermsOfServiceQuery(Promise<Unit> &&promise) : promise_(std::move(promise)) {
} }
void send(string terms_of_service_id) { void send(const string &terms_of_service_id) {
send_query(G()->net_query_creator().create(telegram_api::help_acceptTermsOfService( send_query(G()->net_query_creator().create(telegram_api::help_acceptTermsOfService(
telegram_api::make_object<telegram_api::dataJSON>(std::move(terms_of_service_id))))); telegram_api::make_object<telegram_api::dataJSON>(terms_of_service_id))));
} }
void on_result(uint64 id, BufferSlice packet) final { void on_result(uint64 id, BufferSlice packet) final {
@ -116,7 +116,7 @@ void get_terms_of_service(Td *td, Promise<std::pair<int32, TermsOfService>> prom
} }
void accept_terms_of_service(Td *td, string &&terms_of_service_id, Promise<Unit> &&promise) { void accept_terms_of_service(Td *td, string &&terms_of_service_id, Promise<Unit> &&promise) {
td->create_handler<AcceptTermsOfServiceQuery>(std::move(promise))->send(std::move(terms_of_service_id)); td->create_handler<AcceptTermsOfServiceQuery>(std::move(promise))->send(terms_of_service_id);
} }
} // namespace td } // namespace td

View File

@ -1878,7 +1878,8 @@ void UpdatesManager::process_updates(vector<tl_object_ptr<telegram_api::Update>>
} }
if (force_apply) { if (force_apply) {
for (auto &update : updates) { for (auto &update : updates) {
if (update != nullptr && is_pts_update(update.get())) { if (update != nullptr) {
if (is_pts_update(update.get())) {
auto constructor_id = update->get_id(); auto constructor_id = update->get_id();
if (constructor_id == telegram_api::updateWebPage::ID) { if (constructor_id == telegram_api::updateWebPage::ID) {
auto update_web_page = move_tl_object_as<telegram_api::updateWebPage>(update); auto update_web_page = move_tl_object_as<telegram_api::updateWebPage>(update);
@ -1893,16 +1894,15 @@ void UpdatesManager::process_updates(vector<tl_object_ptr<telegram_api::Update>>
} }
process_pts_update(std::move(update)); process_pts_update(std::move(update));
} } else if (is_qts_update(update.get())) {
if (update != nullptr && is_qts_update(update.get())) {
process_qts_update(std::move(update), 0, mpas.get_promise()); process_qts_update(std::move(update), 0, mpas.get_promise());
} } else if (update->get_id() == telegram_api::updateChannelTooLong::ID) {
if (update != nullptr && update->get_id() == telegram_api::updateChannelTooLong::ID) {
td_->messages_manager_->on_update_channel_too_long( td_->messages_manager_->on_update_channel_too_long(
move_tl_object_as<telegram_api::updateChannelTooLong>(update), true); move_tl_object_as<telegram_api::updateChannelTooLong>(update), true);
} }
} }
} }
}
for (auto &update : updates) { for (auto &update : updates) {
if (update != nullptr) { if (update != nullptr) {
LOG(INFO) << "Process update " << to_string(update); LOG(INFO) << "Process update " << to_string(update);
@ -2101,8 +2101,7 @@ void UpdatesManager::process_qts_update(tl_object_ptr<telegram_api::Update> &&up
} }
case telegram_api::updateBotStopped::ID: { case telegram_api::updateBotStopped::ID: {
auto update = move_tl_object_as<telegram_api::updateBotStopped>(update_ptr); auto update = move_tl_object_as<telegram_api::updateBotStopped>(update_ptr);
td_->contacts_manager_->on_update_bot_stopped(UserId(update->user_id_), update->date_, td_->contacts_manager_->on_update_bot_stopped(UserId(update->user_id_), update->date_, update->stopped_);
std::move(update->stopped_));
add_qts(qts).set_value(Unit()); add_qts(qts).set_value(Unit());
break; break;
} }

View File

@ -2228,7 +2228,7 @@ unique_ptr<WebPageBlock> get_web_page_block(Td *td, tl_object_ptr<telegram_api::
} }
case telegram_api::pageBlockMap::ID: { case telegram_api::pageBlockMap::ID: {
auto page_block = move_tl_object_as<telegram_api::pageBlockMap>(page_block_ptr); auto page_block = move_tl_object_as<telegram_api::pageBlockMap>(page_block_ptr);
Location location(std::move(page_block->geo_)); Location location(page_block->geo_);
auto zoom = page_block->zoom_; auto zoom = page_block->zoom_;
Dimensions dimensions = get_dimensions(page_block->w_, page_block->h_, "pageBlockMap"); Dimensions dimensions = get_dimensions(page_block->w_, page_block->h_, "pageBlockMap");
if (location.empty()) { if (location.empty()) {

View File

@ -1055,17 +1055,18 @@ void WebPagesManager::get_web_page_by_url(const string &url, Promise<WebPageId>
load_web_page_by_url(url, std::move(promise)); load_web_page_by_url(url, std::move(promise));
} }
void WebPagesManager::load_web_page_by_url(const string &url, Promise<WebPageId> &&promise) { void WebPagesManager::load_web_page_by_url(string url, Promise<WebPageId> &&promise) {
if (!G()->parameters().use_message_db) { if (!G()->parameters().use_message_db) {
return reload_web_page_by_url(url, std::move(promise)); return reload_web_page_by_url(url, std::move(promise));
} }
LOG(INFO) << "Load \"" << url << '"'; LOG(INFO) << "Load \"" << url << '"';
G()->td_db()->get_sqlite_pmc()->get( auto key = get_web_page_url_database_key(url);
get_web_page_url_database_key(url), G()->td_db()->get_sqlite_pmc()->get(key, PromiseCreator::lambda([actor_id = actor_id(this), url = std::move(url),
PromiseCreator::lambda([actor_id = actor_id(this), url, promise = std::move(promise)](string value) mutable { promise = std::move(promise)](string value) mutable {
send_closure(actor_id, &WebPagesManager::on_load_web_page_id_by_url_from_database, std::move(url), send_closure(actor_id,
std::move(value), std::move(promise)); &WebPagesManager::on_load_web_page_id_by_url_from_database,
std::move(url), std::move(value), std::move(promise));
})); }));
} }

View File

@ -162,7 +162,7 @@ class WebPagesManager final : public Actor {
static string get_web_page_url_database_key(const string &url); static string get_web_page_url_database_key(const string &url);
void load_web_page_by_url(const string &url, Promise<WebPageId> &&promise); void load_web_page_by_url(string url, Promise<WebPageId> &&promise);
void on_load_web_page_id_by_url_from_database(string url, string value, Promise<WebPageId> &&promise); void on_load_web_page_id_by_url_from_database(string url, string value, Promise<WebPageId> &&promise);

View File

@ -216,7 +216,7 @@ class CliClient final : public Actor {
, get_chat_list_(get_chat_list) , get_chat_list_(get_chat_list)
, disable_network_(disable_network) , disable_network_(disable_network)
, api_id_(api_id) , api_id_(api_id)
, api_hash_(api_hash) { , api_hash_(std::move(api_hash)) {
} }
static void quit_instance() { static void quit_instance() {
@ -563,7 +563,7 @@ class CliClient final : public Actor {
return it->second; return it->second;
} }
auto result = to_integer<int64>(str); auto result = to_integer<int64>(str);
int64 shift = static_cast<int64>(-1000000000000ll); auto shift = static_cast<int64>(-1000000000000ll);
if (result <= shift) { if (result <= shift) {
return shift - result; return shift - result;
} }
@ -573,7 +573,7 @@ class CliClient final : public Actor {
static int32 as_secret_chat_id(Slice str) { static int32 as_secret_chat_id(Slice str) {
str = trim(str); str = trim(str);
auto result = to_integer<int64>(str); auto result = to_integer<int64>(str);
int64 shift = static_cast<int64>(-2000000000000ll); auto shift = static_cast<int64>(-2000000000000ll);
if (result <= shift + std::numeric_limits<int32>::max()) { if (result <= shift + std::numeric_limits<int32>::max()) {
return static_cast<int32>(result - shift); return static_cast<int32>(result - shift);
} }
@ -598,7 +598,8 @@ class CliClient final : public Actor {
static td_api::object_ptr<td_api::InputFile> as_generated_file(string original_path, string conversion, static td_api::object_ptr<td_api::InputFile> as_generated_file(string original_path, string conversion,
int32 expected_size = 0) { int32 expected_size = 0) {
return td_api::make_object<td_api::inputFileGenerated>(trim(original_path), trim(conversion), expected_size); return td_api::make_object<td_api::inputFileGenerated>(trim(std::move(original_path)), trim(std::move(conversion)),
expected_size);
} }
static td_api::object_ptr<td_api::InputFile> as_input_file(string str) { static td_api::object_ptr<td_api::InputFile> as_input_file(string str) {
@ -645,7 +646,8 @@ class CliClient final : public Actor {
return to_integer<int32>(trim(std::move(str))); return to_integer<int32>(trim(std::move(str)));
} }
static td_api::object_ptr<td_api::location> as_location(string latitude, string longitude, string accuracy = "") { static td_api::object_ptr<td_api::location> as_location(const string &latitude, const string &longitude,
const string &accuracy) {
if (trim(latitude).empty() && trim(longitude).empty()) { if (trim(latitude).empty() && trim(longitude).empty()) {
return nullptr; return nullptr;
} }
@ -836,6 +838,8 @@ class CliClient final : public Actor {
case td_api::updateConnectionState::ID: case td_api::updateConnectionState::ID:
LOG(WARNING) << result_str; LOG(WARNING) << result_str;
break; break;
default:
break;
} }
} }
@ -1027,7 +1031,7 @@ class CliClient final : public Actor {
#endif #endif
static td_api::object_ptr<td_api::formattedText> as_formatted_text( static td_api::object_ptr<td_api::formattedText> as_formatted_text(
string text, vector<td_api::object_ptr<td_api::textEntity>> entities = {}) { const string &text, vector<td_api::object_ptr<td_api::textEntity>> entities = {}) {
if (entities.empty() && !text.empty()) { if (entities.empty() && !text.empty()) {
auto parsed_text = execute( auto parsed_text = execute(
td_api::make_object<td_api::parseTextEntities>(text, td_api::make_object<td_api::textParseModeMarkdown>(2))); td_api::make_object<td_api::parseTextEntities>(text, td_api::make_object<td_api::textParseModeMarkdown>(2)));
@ -1039,7 +1043,7 @@ class CliClient final : public Actor {
} }
static td_api::object_ptr<td_api::formattedText> as_caption( static td_api::object_ptr<td_api::formattedText> as_caption(
string caption, vector<td_api::object_ptr<td_api::textEntity>> entities = {}) { const string &caption, vector<td_api::object_ptr<td_api::textEntity>> entities = {}) {
return as_formatted_text(caption, std::move(entities)); return as_formatted_text(caption, std::move(entities));
} }
@ -1198,7 +1202,7 @@ class CliClient final : public Actor {
} }
static td_api::object_ptr<td_api::SupergroupMembersFilter> get_supergroup_members_filter(MutableSlice filter, static td_api::object_ptr<td_api::SupergroupMembersFilter> get_supergroup_members_filter(MutableSlice filter,
string query, const string &query,
Slice message_thread_id) { Slice message_thread_id) {
filter = trim(filter); filter = trim(filter);
to_lower_inplace(filter); to_lower_inplace(filter);
@ -1434,8 +1438,9 @@ class CliClient final : public Actor {
return transform(full_split(types, get_delimiter(types)), [](Slice str) { return as_passport_element_type(str); }); return transform(full_split(types, get_delimiter(types)), [](Slice str) { return as_passport_element_type(str); });
} }
static td_api::object_ptr<td_api::InputPassportElement> as_input_passport_element(string passport_element_type, static td_api::object_ptr<td_api::InputPassportElement> as_input_passport_element(const string &passport_element_type,
string arg, bool with_selfie) { const string &arg,
bool with_selfie) {
vector<td_api::object_ptr<td_api::InputFile>> input_files; vector<td_api::object_ptr<td_api::InputFile>> input_files;
td_api::object_ptr<td_api::InputFile> selfie; td_api::object_ptr<td_api::InputFile> selfie;
if (!arg.empty()) { if (!arg.empty()) {
@ -1445,7 +1450,7 @@ class CliClient final : public Actor {
selfie = as_input_file(files.back()); selfie = as_input_file(files.back());
files.pop_back(); files.pop_back();
} }
for (auto file : files) { for (const auto &file : files) {
input_files.push_back(as_input_file(file)); input_files.push_back(as_input_file(file));
} }
} }
@ -1484,7 +1489,7 @@ class CliClient final : public Actor {
std::move(input_files))); std::move(input_files)));
} }
} else if (passport_element_type == "internal_passport" || passport_element_type == "ip") { } else if (passport_element_type == "internal_passport" || passport_element_type == "ip") {
if (input_files.size() >= 1) { if (!input_files.empty()) {
auto front_side = std::move(input_files[0]); auto front_side = std::move(input_files[0]);
input_files.erase(input_files.begin()); input_files.erase(input_files.begin());
return td_api::make_object<td_api::inputPassportElementInternalPassport>( return td_api::make_object<td_api::inputPassportElementInternalPassport>(
@ -1590,7 +1595,7 @@ class CliClient final : public Actor {
} }
} }
static int32 get_log_tag_verbosity_level(string name) { static int32 get_log_tag_verbosity_level(const string &name) {
auto level = ClientActor::execute(td_api::make_object<td_api::getLogTagVerbosityLevel>(name)); auto level = ClientActor::execute(td_api::make_object<td_api::getLogTagVerbosityLevel>(name));
if (level->get_id() == td_api::error::ID) { if (level->get_id() == td_api::error::ID) {
return -1; return -1;
@ -1825,7 +1830,7 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::setPassportElement>( send_request(td_api::make_object<td_api::setPassportElement>(
as_input_passport_element(passport_element_type, arg, op == "spes"), password)); as_input_passport_element(passport_element_type, arg, op == "spes"), password));
} else if (op == "dpe") { } else if (op == "dpe") {
string passport_element_type = args; string passport_element_type = std::move(args);
send_request(td_api::make_object<td_api::deletePassportElement>(as_passport_element_type(passport_element_type))); send_request(td_api::make_object<td_api::deletePassportElement>(as_passport_element_type(passport_element_type)));
} else if (op == "ppn") { } else if (op == "ppn") {
send_request(td_api::make_object<td_api::processPushNotification>(args)); send_request(td_api::make_object<td_api::processPushNotification>(args));
@ -1945,7 +1950,7 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::addContact>( send_request(td_api::make_object<td_api::addContact>(
td_api::make_object<td_api::contact>(string(), first_name, last_name, string(), as_user_id(user_id)), false)); td_api::make_object<td_api::contact>(string(), first_name, last_name, string(), as_user_id(user_id)), false));
} else if (op == "spn") { } else if (op == "spn") {
string user_id = args; string user_id = std::move(args);
send_request(td_api::make_object<td_api::sharePhoneNumber>(as_user_id(user_id))); send_request(td_api::make_object<td_api::sharePhoneNumber>(as_user_id(user_id)));
} else if (op == "ImportContacts" || op == "cic") { } else if (op == "ImportContacts" || op == "cic") {
vector<string> contacts_str = full_split(args, ';'); vector<string> contacts_str = full_split(args, ';');
@ -2007,7 +2012,7 @@ class CliClient final : public Actor {
offset, as_limit(limit), op == "ghl")); offset, as_limit(limit), op == "ghl"));
} }
} else if (op == "gcsm") { } else if (op == "gcsm") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::getChatScheduledMessages>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::getChatScheduledMessages>(as_chat_id(chat_id)));
} else if (op == "gmpf") { } else if (op == "gmpf") {
string chat_id; string chat_id;
@ -2136,10 +2141,10 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::getLanguagePackString>(language_database_path, language_pack, send_request(td_api::make_object<td_api::getLanguagePackString>(language_database_path, language_pack,
language_code, key)); language_code, key));
} else if (op == "synclp") { } else if (op == "synclp") {
string language_code = args; string language_code = std::move(args);
send_request(td_api::make_object<td_api::synchronizeLanguagePack>(language_code)); send_request(td_api::make_object<td_api::synchronizeLanguagePack>(language_code));
} else if (op == "acslp") { } else if (op == "acslp") {
string language_code = args; string language_code = std::move(args);
send_request(td_api::make_object<td_api::addCustomServerLanguagePack>(language_code)); send_request(td_api::make_object<td_api::addCustomServerLanguagePack>(language_code));
} else if (op == "sclp") { } else if (op == "sclp") {
string language_code; string language_code;
@ -2374,24 +2379,24 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::optimizeStorage>()); send_request(td_api::make_object<td_api::optimizeStorage>());
} else if (op == "clean_photos") { } else if (op == "clean_photos") {
std::vector<td_api::object_ptr<td_api::FileType>> types; std::vector<td_api::object_ptr<td_api::FileType>> types;
types.push_back(td_api::make_object<td_api::fileTypePhoto>()); types.emplace_back(td_api::make_object<td_api::fileTypePhoto>());
send_request(td_api::make_object<td_api::optimizeStorage>(0, 0, 0, 0, std::move(types), as_chat_ids(""), send_request(td_api::make_object<td_api::optimizeStorage>(0, 0, 0, 0, std::move(types), as_chat_ids(""),
as_chat_ids(""), true, 20)); as_chat_ids(""), true, 20));
} else if (op == "clean_storage") { } else if (op == "clean_storage") {
std::vector<td_api::object_ptr<td_api::FileType>> types; std::vector<td_api::object_ptr<td_api::FileType>> types;
types.push_back(td_api::make_object<td_api::fileTypeThumbnail>()); types.emplace_back(td_api::make_object<td_api::fileTypeThumbnail>());
types.push_back(td_api::make_object<td_api::fileTypeProfilePhoto>()); types.emplace_back(td_api::make_object<td_api::fileTypeProfilePhoto>());
types.push_back(td_api::make_object<td_api::fileTypePhoto>()); types.emplace_back(td_api::make_object<td_api::fileTypePhoto>());
types.push_back(td_api::make_object<td_api::fileTypeVoiceNote>()); types.emplace_back(td_api::make_object<td_api::fileTypeVoiceNote>());
types.push_back(td_api::make_object<td_api::fileTypeVideo>()); types.emplace_back(td_api::make_object<td_api::fileTypeVideo>());
types.push_back(td_api::make_object<td_api::fileTypeDocument>()); types.emplace_back(td_api::make_object<td_api::fileTypeDocument>());
types.push_back(td_api::make_object<td_api::fileTypeSecret>()); types.emplace_back(td_api::make_object<td_api::fileTypeSecret>());
types.push_back(td_api::make_object<td_api::fileTypeUnknown>()); types.emplace_back(td_api::make_object<td_api::fileTypeUnknown>());
types.push_back(td_api::make_object<td_api::fileTypeSticker>()); types.emplace_back(td_api::make_object<td_api::fileTypeSticker>());
types.push_back(td_api::make_object<td_api::fileTypeAudio>()); types.emplace_back(td_api::make_object<td_api::fileTypeAudio>());
types.push_back(td_api::make_object<td_api::fileTypeAnimation>()); types.emplace_back(td_api::make_object<td_api::fileTypeAnimation>());
types.push_back(td_api::make_object<td_api::fileTypeVideoNote>()); types.emplace_back(td_api::make_object<td_api::fileTypeVideoNote>());
types.push_back(td_api::make_object<td_api::fileTypeSecure>()); types.emplace_back(td_api::make_object<td_api::fileTypeSecure>());
send_request(td_api::make_object<td_api::optimizeStorage>(0, -1, -1, 0, std::move(types), as_chat_ids(args), send_request(td_api::make_object<td_api::optimizeStorage>(0, -1, -1, 0, std::move(types), as_chat_ids(args),
as_chat_ids(""), true, 20)); as_chat_ids(""), true, 20));
} else if (op == "network") { } else if (op == "network") {
@ -2433,10 +2438,10 @@ class CliClient final : public Actor {
get_args(args, chat_id, category); get_args(args, chat_id, category);
send_request(td_api::make_object<td_api::removeTopChat>(get_top_chat_category(category), as_chat_id(chat_id))); send_request(td_api::make_object<td_api::removeTopChat>(get_top_chat_category(category), as_chat_id(chat_id)));
} else if (op == "gsssn") { } else if (op == "gsssn") {
string title = args; string title = std::move(args);
send_request(td_api::make_object<td_api::getSuggestedStickerSetName>(title)); send_request(td_api::make_object<td_api::getSuggestedStickerSetName>(title));
} else if (op == "cssn") { } else if (op == "cssn") {
string name = args; string name = std::move(args);
send_request(td_api::make_object<td_api::checkStickerSetName>(name)); send_request(td_api::make_object<td_api::checkStickerSetName>(name));
} else if (op == "usf" || op == "usfa") { } else if (op == "usf" || op == "usfa") {
td_api::object_ptr<td_api::InputSticker> input_sticker; td_api::object_ptr<td_api::InputSticker> input_sticker;
@ -2453,7 +2458,7 @@ class CliClient final : public Actor {
get_args(args, title, name, stickers); get_args(args, title, name, stickers);
auto input_stickers = auto input_stickers =
transform(full_split(stickers, get_delimiter(stickers)), transform(full_split(stickers, get_delimiter(stickers)),
[op](string sticker) -> td_api::object_ptr<td_api::InputSticker> { [op](const string &sticker) -> td_api::object_ptr<td_api::InputSticker> {
if (op == "cnssa") { if (op == "cnssa") {
return td_api::make_object<td_api::inputStickerAnimated>(as_input_file(sticker), "😀"); return td_api::make_object<td_api::inputStickerAnimated>(as_input_file(sticker), "😀");
} else { } else {
@ -2546,7 +2551,7 @@ class CliClient final : public Actor {
get_args(args, chat_id, member_id); get_args(args, chat_id, member_id);
send_request(td_api::make_object<td_api::getChatMember>(as_chat_id(chat_id), as_message_sender(member_id))); send_request(td_api::make_object<td_api::getChatMember>(as_chat_id(chat_id), as_message_sender(member_id)));
} else if (op == "GetChatAdministrators") { } else if (op == "GetChatAdministrators") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::getChatAdministrators>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::getChatAdministrators>(as_chat_id(chat_id)));
} else if (op == "GetSupergroupAdministrators" || op == "GetSupergroupBanned" || op == "GetSupergroupBots" || } else if (op == "GetSupergroupAdministrators" || op == "GetSupergroupBanned" || op == "GetSupergroupBots" ||
op == "GetSupergroupContacts" || op == "GetSupergroupMembers" || op == "GetSupergroupRestricted" || op == "GetSupergroupContacts" || op == "GetSupergroupMembers" || op == "GetSupergroupRestricted" ||
@ -2602,7 +2607,7 @@ class CliClient final : public Actor {
get_args(args, chat_id, message_id); get_args(args, chat_id, message_id);
send_request(td_api::make_object<td_api::getMessageViewers>(as_chat_id(chat_id), as_message_id(message_id))); send_request(td_api::make_object<td_api::getMessageViewers>(as_chat_id(chat_id), as_message_id(message_id)));
} else if (op == "gcpm") { } else if (op == "gcpm") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::getChatPinnedMessage>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::getChatPinnedMessage>(as_chat_id(chat_id)));
} else if (op == "gms") { } else if (op == "gms") {
string chat_id; string chat_id;
@ -2664,8 +2669,8 @@ class CliClient final : public Actor {
int32 scale; int32 scale;
string chat_id; string chat_id;
get_args(args, latitude, longitude, zoom, width, height, scale, chat_id); get_args(args, latitude, longitude, zoom, width, height, scale, chat_id);
send_request(td_api::make_object<td_api::getMapThumbnailFile>(as_location(latitude, longitude), zoom, width, send_request(td_api::make_object<td_api::getMapThumbnailFile>(as_location(latitude, longitude, string()), zoom,
height, scale, as_chat_id(chat_id))); width, height, scale, as_chat_id(chat_id)));
} else if (op == "df" || op == "DownloadFile" || op == "dff" || op == "dfs") { } else if (op == "df" || op == "DownloadFile" || op == "dff" || op == "dfs") {
string file_id; string file_id;
int32 priority; int32 priority;
@ -2712,7 +2717,7 @@ class CliClient final : public Actor {
} else if (op == "cuf") { } else if (op == "cuf") {
send_request(td_api::make_object<td_api::cancelUploadFile>(as_file_id(args))); send_request(td_api::make_object<td_api::cancelUploadFile>(as_file_id(args)));
} else if (op == "delf" || op == "DeleteFile") { } else if (op == "delf" || op == "DeleteFile") {
string file_id = args; string file_id = std::move(args);
send_request(td_api::make_object<td_api::deleteFile>(as_file_id(file_id))); send_request(td_api::make_object<td_api::deleteFile>(as_file_id(file_id)));
} else if (op == "dm" || op == "dmr") { } else if (op == "dm" || op == "dmr") {
string chat_id; string chat_id;
@ -2842,7 +2847,7 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::toggleGroupCallScreenSharingIsPaused>(as_group_call_id(group_call_id), send_request(td_api::make_object<td_api::toggleGroupCallScreenSharingIsPaused>(as_group_call_id(group_call_id),
is_paused)); is_paused));
} else if (op == "egcss") { } else if (op == "egcss") {
string group_call_id = args; string group_call_id = std::move(args);
send_request(td_api::make_object<td_api::endGroupCallScreenSharing>(as_group_call_id(group_call_id))); send_request(td_api::make_object<td_api::endGroupCallScreenSharing>(as_group_call_id(group_call_id)));
} else if (op == "sgct") { } else if (op == "sgct") {
string chat_id; string chat_id;
@ -2894,7 +2899,7 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::startGroupCallRecording>(as_group_call_id(chat_id), title, record_video, send_request(td_api::make_object<td_api::startGroupCallRecording>(as_group_call_id(chat_id), title, record_video,
use_portrait_orientation)); use_portrait_orientation));
} else if (op == "egcr") { } else if (op == "egcr") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::endGroupCallRecording>(as_group_call_id(chat_id))); send_request(td_api::make_object<td_api::endGroupCallRecording>(as_group_call_id(chat_id)));
} else if (op == "tgcpim") { } else if (op == "tgcpim") {
string group_call_id; string group_call_id;
@ -2928,7 +2933,7 @@ class CliClient final : public Actor {
} else if (op == "dgc") { } else if (op == "dgc") {
send_request(td_api::make_object<td_api::discardGroupCall>(as_group_call_id(args))); send_request(td_api::make_object<td_api::discardGroupCall>(as_group_call_id(args)));
} else if (op == "rpcil") { } else if (op == "rpcil") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::replacePrimaryChatInviteLink>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::replacePrimaryChatInviteLink>(as_chat_id(chat_id)));
} else if (op == "ccilt") { } else if (op == "ccilt") {
string chat_id; string chat_id;
@ -2950,7 +2955,7 @@ class CliClient final : public Actor {
get_args(args, chat_id, invite_link); get_args(args, chat_id, invite_link);
send_request(td_api::make_object<td_api::revokeChatInviteLink>(as_chat_id(chat_id), invite_link)); send_request(td_api::make_object<td_api::revokeChatInviteLink>(as_chat_id(chat_id), invite_link));
} else if (op == "gcilc") { } else if (op == "gcilc") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::getChatInviteLinkCounts>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::getChatInviteLinkCounts>(as_chat_id(chat_id)));
} else if (op == "gcil") { } else if (op == "gcil") {
string chat_id; string chat_id;
@ -3035,21 +3040,21 @@ class CliClient final : public Actor {
test_get_json_string(td_api::make_object<td_api::jsonValueString>("aba\200caba")); test_get_json_string(td_api::make_object<td_api::jsonValueString>("aba\200caba"));
auto inner_array = td_api::make_object<td_api::jsonValueArray>(); auto inner_array = td_api::make_object<td_api::jsonValueArray>();
inner_array->values_.push_back(td_api::make_object<td_api::jsonValueBoolean>(false)); inner_array->values_.emplace_back(td_api::make_object<td_api::jsonValueBoolean>(false));
auto array = td_api::make_object<td_api::jsonValueArray>(); auto array = td_api::make_object<td_api::jsonValueArray>();
array->values_.push_back(nullptr); array->values_.emplace_back(nullptr);
array->values_.push_back(std::move(inner_array)); array->values_.emplace_back(std::move(inner_array));
array->values_.push_back(td_api::make_object<td_api::jsonValueNull>()); array->values_.emplace_back(td_api::make_object<td_api::jsonValueNull>());
array->values_.push_back(td_api::make_object<td_api::jsonValueNumber>(-1)); array->values_.emplace_back(td_api::make_object<td_api::jsonValueNumber>(-1));
test_get_json_string(std::move(array)); test_get_json_string(std::move(array));
auto object = td_api::make_object<td_api::jsonValueObject>(); auto object = td_api::make_object<td_api::jsonValueObject>();
object->members_.push_back( object->members_.emplace_back(
td_api::make_object<td_api::jsonObjectMember>("", td_api::make_object<td_api::jsonValueString>("test"))); td_api::make_object<td_api::jsonObjectMember>("", td_api::make_object<td_api::jsonValueString>("test")));
object->members_.push_back(td_api::make_object<td_api::jsonObjectMember>("a", nullptr)); object->members_.emplace_back(td_api::make_object<td_api::jsonObjectMember>("a", nullptr));
object->members_.push_back(td_api::make_object<td_api::jsonObjectMember>("\x80", nullptr)); object->members_.emplace_back(td_api::make_object<td_api::jsonObjectMember>("\x80", nullptr));
object->members_.push_back(nullptr); object->members_.emplace_back(nullptr);
object->members_.push_back( object->members_.emplace_back(
td_api::make_object<td_api::jsonObjectMember>("a", td_api::make_object<td_api::jsonValueNull>())); td_api::make_object<td_api::jsonObjectMember>("a", td_api::make_object<td_api::jsonValueNull>()));
test_get_json_string(std::move(object)); test_get_json_string(std::move(object));
} else if (op == "gac") { } else if (op == "gac") {
@ -3159,9 +3164,9 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::searchSecretMessages>(as_chat_id(chat_id), query.query, offset, send_request(td_api::make_object<td_api::searchSecretMessages>(as_chat_id(chat_id), query.query, offset,
query.limit, as_search_messages_filter(filter))); query.limit, as_search_messages_filter(filter)));
} else if (op == "ssd") { } else if (op == "ssd") {
schedule_date_ = args; schedule_date_ = std::move(args);
} else if (op == "smti") { } else if (op == "smti") {
message_thread_id_ = args; message_thread_id_ = std::move(args);
} else if (op == "sm" || op == "sms" || op == "smr" || op == "smf") { } else if (op == "sm" || op == "sms" || op == "smr" || op == "smf") {
string chat_id; string chat_id;
string reply_to_message_id; string reply_to_message_id;
@ -3332,8 +3337,8 @@ class CliClient final : public Actor {
string bot_id; string bot_id;
string query; string query;
get_args(args, bot_id, query); get_args(args, bot_id, query);
send_request(td_api::make_object<td_api::getInlineQueryResults>(as_user_id(bot_id), 0, as_location("1.1", "2.2"), send_request(td_api::make_object<td_api::getInlineQueryResults>(as_user_id(bot_id), 0,
query, "")); as_location("1.1", "2.2", ""), query, ""));
} else if (op == "siqr" || op == "siqrh") { } else if (op == "siqr" || op == "siqrh") {
string chat_id; string chat_id;
int64 query_id; int64 query_id;
@ -3688,8 +3693,8 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::createNewSupergroupChat>(args, false, "Description", nullptr, false)); send_request(td_api::make_object<td_api::createNewSupergroupChat>(args, false, "Description", nullptr, false));
} else if (op == "cnsgcloc") { } else if (op == "cnsgcloc") {
send_request(td_api::make_object<td_api::createNewSupergroupChat>( send_request(td_api::make_object<td_api::createNewSupergroupChat>(
args, false, "Description", td_api::make_object<td_api::chatLocation>(as_location("40.0", "60.0"), "address"), args, false, "Description",
false)); td_api::make_object<td_api::chatLocation>(as_location("40.0", "60.0", ""), "address"), false));
} else if (op == "cnsgcimport") { } else if (op == "cnsgcimport") {
send_request(td_api::make_object<td_api::createNewSupergroupChat>(args, false, "Description", nullptr, true)); send_request(td_api::make_object<td_api::createNewSupergroupChat>(args, false, "Description", nullptr, true));
} else if (op == "UpgradeBasicGroupChatToSupergroupChat") { } else if (op == "UpgradeBasicGroupChatToSupergroupChat") {
@ -3726,10 +3731,10 @@ class CliClient final : public Actor {
get_args(args, supergroup_id, force); get_args(args, supergroup_id, force);
send_request(td_api::make_object<td_api::createSupergroupChat>(as_supergroup_id(supergroup_id), force)); send_request(td_api::make_object<td_api::createSupergroupChat>(as_supergroup_id(supergroup_id), force));
} else if (op == "gcltac") { } else if (op == "gcltac") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::getChatListsToAddChat>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::getChatListsToAddChat>(as_chat_id(chat_id)));
} else if (op == "actl" || op == "actla" || begins_with(op, "actl-")) { } else if (op == "actl" || op == "actla" || begins_with(op, "actl-")) {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::addChatToList>(as_chat_id(chat_id), as_chat_list(op))); send_request(td_api::make_object<td_api::addChatToList>(as_chat_id(chat_id), as_chat_list(op)));
} else if (op == "gcf") { } else if (op == "gcf") {
send_request(td_api::make_object<td_api::getChatFilter>(as_chat_filter_id(args))); send_request(td_api::make_object<td_api::getChatFilter>(as_chat_filter_id(args)));
@ -3760,7 +3765,7 @@ class CliClient final : public Actor {
get_args(args, chat_id, title); get_args(args, chat_id, title);
send_request(td_api::make_object<td_api::setChatTitle>(as_chat_id(chat_id), title)); send_request(td_api::make_object<td_api::setChatTitle>(as_chat_id(chat_id), title));
} else if (op == "scpe") { } else if (op == "scpe") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::setChatPhoto>(as_chat_id(chat_id), nullptr)); send_request(td_api::make_object<td_api::setChatPhoto>(as_chat_id(chat_id), nullptr));
} else if (op == "scpp") { } else if (op == "scpp") {
string chat_id; string chat_id;
@ -4006,7 +4011,8 @@ class CliClient final : public Actor {
string longitude; string longitude;
get_args(args, chat_id, latitude, longitude); get_args(args, chat_id, latitude, longitude);
send_request(td_api::make_object<td_api::setChatLocation>( send_request(td_api::make_object<td_api::setChatLocation>(
as_chat_id(chat_id), td_api::make_object<td_api::chatLocation>(as_location(latitude, longitude), "address"))); as_chat_id(chat_id),
td_api::make_object<td_api::chatLocation>(as_location(latitude, longitude, string()), "address")));
} else if (op == "scsmd") { } else if (op == "scsmd") {
string chat_id; string chat_id;
int32 slow_mode_delay; int32 slow_mode_delay;
@ -4024,7 +4030,7 @@ class CliClient final : public Actor {
get_args(args, chat_id, message_id); get_args(args, chat_id, message_id);
send_request(td_api::make_object<td_api::unpinChatMessage>(as_chat_id(chat_id), as_message_id(message_id))); send_request(td_api::make_object<td_api::unpinChatMessage>(as_chat_id(chat_id), as_message_id(message_id)));
} else if (op == "uacm") { } else if (op == "uacm") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::unpinAllChatMessages>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::unpinAllChatMessages>(as_chat_id(chat_id)));
} else if (op == "grib") { } else if (op == "grib") {
send_request(td_api::make_object<td_api::getRecentInlineBots>()); send_request(td_api::make_object<td_api::getRecentInlineBots>());
@ -4044,12 +4050,12 @@ class CliClient final : public Actor {
string latitude; string latitude;
string longitude; string longitude;
get_args(args, latitude, longitude); get_args(args, latitude, longitude);
send_request(td_api::make_object<td_api::searchChatsNearby>(as_location(latitude, longitude))); send_request(td_api::make_object<td_api::searchChatsNearby>(as_location(latitude, longitude, string())));
} else if (op == "sloc") { } else if (op == "sloc") {
string latitude; string latitude;
string longitude; string longitude;
get_args(args, latitude, longitude); get_args(args, latitude, longitude);
send_request(td_api::make_object<td_api::setLocation>(as_location(latitude, longitude))); send_request(td_api::make_object<td_api::setLocation>(as_location(latitude, longitude, string())));
} else if (op == "sco") { } else if (op == "sco") {
SearchQuery query; SearchQuery query;
get_args(args, query); get_args(args, query);
@ -4109,16 +4115,16 @@ class CliClient final : public Actor {
send_request( send_request(
td_api::make_object<td_api::clickAnimatedEmojiMessage>(as_chat_id(chat_id), as_message_id(message_id))); td_api::make_object<td_api::clickAnimatedEmojiMessage>(as_chat_id(chat_id), as_message_id(message_id)));
} else if (op == "gilt") { } else if (op == "gilt") {
string link = args; string link = std::move(args);
send_request(td_api::make_object<td_api::getInternalLinkType>(link)); send_request(td_api::make_object<td_api::getInternalLinkType>(link));
} else if (op == "geli") { } else if (op == "geli") {
string link = args; string link = std::move(args);
send_request(td_api::make_object<td_api::getExternalLinkInfo>(link)); send_request(td_api::make_object<td_api::getExternalLinkInfo>(link));
} else if (op == "gel" || op == "gelw") { } else if (op == "gel" || op == "gelw") {
string link = args; string link = std::move(args);
send_request(td_api::make_object<td_api::getExternalLink>(link, op == "gelw")); send_request(td_api::make_object<td_api::getExternalLink>(link, op == "gelw"));
} else if (op == "racm") { } else if (op == "racm") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::readAllChatMentions>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::readAllChatMentions>(as_chat_id(chat_id)));
} else if (op == "tre") { } else if (op == "tre") {
send_request(td_api::make_object<td_api::testReturnError>( send_request(td_api::make_object<td_api::testReturnError>(
@ -4169,7 +4175,7 @@ class CliClient final : public Actor {
get_args(args, group_id, max_notification_id); get_args(args, group_id, max_notification_id);
send_request(td_api::make_object<td_api::removeNotificationGroup>(group_id, max_notification_id)); send_request(td_api::make_object<td_api::removeNotificationGroup>(group_id, max_notification_id));
} else if (op == "rcab") { } else if (op == "rcab") {
string chat_id = args; string chat_id = std::move(args);
send_request(td_api::make_object<td_api::removeChatActionBar>(as_chat_id(chat_id))); send_request(td_api::make_object<td_api::removeChatActionBar>(as_chat_id(chat_id)));
} else if (op == "rc") { } else if (op == "rc") {
string chat_id; string chat_id;
@ -4348,7 +4354,7 @@ class CliClient final : public Actor {
execute(std::move(request)); execute(std::move(request));
} }
} else if (op == "gltvl" || op == "gltvle" || op == "gtag") { } else if (op == "gltvl" || op == "gltvle" || op == "gtag") {
string tag = args; string tag = std::move(args);
auto request = td_api::make_object<td_api::getLogTagVerbosityLevel>(tag); auto request = td_api::make_object<td_api::getLogTagVerbosityLevel>(tag);
if (op == "gltvl") { if (op == "gltvl") {
send_request(std::move(request)); send_request(std::move(request));

View File

@ -106,11 +106,11 @@ int64 Bitmask::get_total_size(int64 part_size, int64 file_size) const {
bool Bitmask::get(int64 offset_part) const { bool Bitmask::get(int64 offset_part) const {
if (offset_part < 0) { if (offset_part < 0) {
return 0; return false;
} }
auto index = narrow_cast<size_t>(offset_part / 8); auto index = narrow_cast<size_t>(offset_part / 8);
if (index >= data_.size()) { if (index >= data_.size()) {
return 0; return false;
} }
return (static_cast<uint8>(data_[index]) & (1 << static_cast<int>(offset_part % 8))) != 0; return (static_cast<uint8>(data_[index]) & (1 << static_cast<int>(offset_part % 8))) != 0;
} }
@ -148,7 +148,7 @@ int64 Bitmask::size() const {
} }
StringBuilder &operator<<(StringBuilder &sb, const Bitmask &mask) { StringBuilder &operator<<(StringBuilder &sb, const Bitmask &mask) {
bool prev = 0; bool prev = false;
int32 cnt = 0; int32 cnt = 0;
for (int64 i = 0; i <= mask.size(); i++) { for (int64 i = 0; i <= mask.size(); i++) {
bool cur = mask.get(i); bool cur = mask.get(i);

View File

@ -446,7 +446,7 @@ Result<FileLoader::CheckInfo> FileDownloader::check_loop(int64 checked_prefix_si
} }
end_offset = ready_prefix_size; end_offset = ready_prefix_size;
} }
size_t size = narrow_cast<size_t>(end_offset - begin_offset); auto size = narrow_cast<size_t>(end_offset - begin_offset);
auto slice = BufferSlice(size); auto slice = BufferSlice(size);
TRY_STATUS(acquire_fd()); TRY_STATUS(acquire_fd());
TRY_RESULT(read_size, fd_.pread(slice.as_slice(), begin_offset)); TRY_RESULT(read_size, fd_.pread(slice.as_slice(), begin_offset));

View File

@ -28,8 +28,8 @@ class FileDownloader final : public FileLoader {
class Callback : public FileLoader::Callback { class Callback : public FileLoader::Callback {
public: public:
virtual void on_start_download() = 0; virtual void on_start_download() = 0;
virtual void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size, int64 size) = 0; virtual void on_partial_download(PartialLocalFileLocation partial_local, int64 ready_size, int64 size) = 0;
virtual void on_ok(const FullLocalFileLocation &full_local, int64 size, bool is_new) = 0; virtual void on_ok(FullLocalFileLocation full_local, int64 size, bool is_new) = 0;
virtual void on_error(Status status) = 0; virtual void on_error(Status status) = 0;
}; };

View File

@ -18,8 +18,8 @@ FileFromBytes::FileFromBytes(FileType type, BufferSlice bytes, string name, uniq
} }
void FileFromBytes::wakeup() { void FileFromBytes::wakeup() {
int64 size = narrow_cast<int64>(bytes_.size()); auto size = narrow_cast<int64>(bytes_.size());
auto r_result = save_file_bytes(type_, std::move(bytes_), std::move(name_)); auto r_result = save_file_bytes(type_, std::move(bytes_), name_);
if (r_result.is_error()) { if (r_result.is_error()) {
callback_->on_error(r_result.move_as_error()); callback_->on_error(r_result.move_as_error());
} else { } else {

View File

@ -55,7 +55,7 @@ void FileGcWorker::run_gc(const FileGcParameters &parameters, std::vector<FullFi
} }
for (int32 i = 0; i < MAX_FILE_TYPE; i++) { for (int32 i = 0; i < MAX_FILE_TYPE; i++) {
auto main_file_type = narrow_cast<size_t>(get_main_file_type(static_cast<FileType>(i))); auto main_file_type = narrow_cast<size_t>(get_main_file_type(static_cast<FileType>(i)));
if (immune_types[main_file_type] == false) { if (!immune_types[main_file_type]) {
immune_types[i] = false; immune_types[i] = false;
} }
} }

View File

@ -99,7 +99,7 @@ class FileDownloadGenerateActor final : public FileGenerateActor {
if (file_view.has_local_location()) { if (file_view.has_local_location()) {
auto location = file_view.local_location(); auto location = file_view.local_location();
location.file_type_ = file_type; location.file_type_ = file_type;
callback->on_ok(location); callback->on_ok(std::move(location));
} else { } else {
LOG(ERROR) << "Expected to have local location"; LOG(ERROR) << "Expected to have local location";
callback->on_error(Status::Error(500, "Unknown")); callback->on_error(Status::Error(500, "Unknown"));

View File

@ -26,8 +26,8 @@ class FileGenerateCallback {
FileGenerateCallback &operator=(const FileGenerateCallback &) = delete; FileGenerateCallback &operator=(const FileGenerateCallback &) = delete;
virtual ~FileGenerateCallback() = default; virtual ~FileGenerateCallback() = default;
virtual void on_partial_generate(const PartialLocalFileLocation &partial_local, int32 expected_size) = 0; virtual void on_partial_generate(PartialLocalFileLocation partial_local, int32 expected_size) = 0;
virtual void on_ok(const FullLocalFileLocation &local) = 0; virtual void on_ok(FullLocalFileLocation local) = 0;
virtual void on_error(Status error) = 0; virtual void on_error(Status error) = 0;
}; };

View File

@ -27,7 +27,8 @@ class FileHashUploader final : public FileLoaderActor {
Callback(const Callback &) = delete; Callback(const Callback &) = delete;
Callback &operator=(const Callback &) = delete; Callback &operator=(const Callback &) = delete;
virtual ~Callback() = default; virtual ~Callback() = default;
virtual void on_ok(const FullRemoteFileLocation &locatioin) = 0;
virtual void on_ok(FullRemoteFileLocation location) = 0;
virtual void on_error(Status status) = 0; virtual void on_error(Status status) = 0;
}; };

View File

@ -192,14 +192,15 @@ void FileLoadManager::on_start_download() {
} }
} }
void FileLoadManager::on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size, int64 size) { void FileLoadManager::on_partial_download(PartialLocalFileLocation partial_local, int64 ready_size, int64 size) {
auto node_id = get_link_token(); auto node_id = get_link_token();
auto node = nodes_container_.get(node_id); auto node = nodes_container_.get(node_id);
if (node == nullptr) { if (node == nullptr) {
return; return;
} }
if (!stop_flag_) { if (!stop_flag_) {
send_closure(callback_, &Callback::on_partial_download, node->query_id_, partial_local, ready_size, size); send_closure(callback_, &Callback::on_partial_download, node->query_id_, std::move(partial_local), ready_size,
size);
} }
} }
@ -214,51 +215,51 @@ void FileLoadManager::on_hash(string hash) {
} }
} }
void FileLoadManager::on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size) { void FileLoadManager::on_partial_upload(PartialRemoteFileLocation partial_remote, int64 ready_size) {
auto node_id = get_link_token(); auto node_id = get_link_token();
auto node = nodes_container_.get(node_id); auto node = nodes_container_.get(node_id);
if (node == nullptr) { if (node == nullptr) {
return; return;
} }
if (!stop_flag_) { if (!stop_flag_) {
send_closure(callback_, &Callback::on_partial_upload, node->query_id_, partial_remote, ready_size); send_closure(callback_, &Callback::on_partial_upload, node->query_id_, std::move(partial_remote), ready_size);
} }
} }
void FileLoadManager::on_ok_download(const FullLocalFileLocation &local, int64 size, bool is_new) { void FileLoadManager::on_ok_download(FullLocalFileLocation local, int64 size, bool is_new) {
auto node_id = get_link_token(); auto node_id = get_link_token();
auto node = nodes_container_.get(node_id); auto node = nodes_container_.get(node_id);
if (node == nullptr) { if (node == nullptr) {
return; return;
} }
if (!stop_flag_) { if (!stop_flag_) {
send_closure(callback_, &Callback::on_download_ok, node->query_id_, local, size, is_new); send_closure(callback_, &Callback::on_download_ok, node->query_id_, std::move(local), size, is_new);
} }
close_node(node_id); close_node(node_id);
loop(); loop();
} }
void FileLoadManager::on_ok_upload(FileType file_type, const PartialRemoteFileLocation &remote, int64 size) { void FileLoadManager::on_ok_upload(FileType file_type, PartialRemoteFileLocation remote, int64 size) {
auto node_id = get_link_token(); auto node_id = get_link_token();
auto node = nodes_container_.get(node_id); auto node = nodes_container_.get(node_id);
if (node == nullptr) { if (node == nullptr) {
return; return;
} }
if (!stop_flag_) { if (!stop_flag_) {
send_closure(callback_, &Callback::on_upload_ok, node->query_id_, file_type, remote, size); send_closure(callback_, &Callback::on_upload_ok, node->query_id_, file_type, std::move(remote), size);
} }
close_node(node_id); close_node(node_id);
loop(); loop();
} }
void FileLoadManager::on_ok_upload_full(const FullRemoteFileLocation &remote) { void FileLoadManager::on_ok_upload_full(FullRemoteFileLocation remote) {
auto node_id = get_link_token(); auto node_id = get_link_token();
auto node = nodes_container_.get(node_id); auto node = nodes_container_.get(node_id);
if (node == nullptr) { if (node == nullptr) {
return; return;
} }
if (!stop_flag_) { if (!stop_flag_) {
send_closure(callback_, &Callback::on_upload_full_ok, node->query_id_, remote); send_closure(callback_, &Callback::on_upload_full_ok, node->query_id_, std::move(remote));
} }
close_node(node_id); close_node(node_id);
loop(); loop();

View File

@ -33,17 +33,18 @@ class FileLoadManager final : public Actor {
class Callback : public Actor { class Callback : public Actor {
public: public:
virtual void on_start_download(QueryId id) = 0; virtual void on_start_download(QueryId id) = 0;
virtual void on_partial_download(QueryId id, const PartialLocalFileLocation &partial_local, int64 ready_size, virtual void on_partial_download(QueryId id, PartialLocalFileLocation partial_local, int64 ready_size,
int64 size) = 0; int64 size) = 0;
virtual void on_partial_upload(QueryId id, const PartialRemoteFileLocation &partial_remote, int64 ready_size) = 0; virtual void on_partial_upload(QueryId id, PartialRemoteFileLocation partial_remote, int64 ready_size) = 0;
virtual void on_hash(QueryId id, string hash) = 0; virtual void on_hash(QueryId id, string hash) = 0;
virtual void on_upload_ok(QueryId id, FileType file_type, const PartialRemoteFileLocation &remtoe, int64 size) = 0; virtual void on_upload_ok(QueryId id, FileType file_type, PartialRemoteFileLocation remtoe, int64 size) = 0;
virtual void on_upload_full_ok(QueryId id, const FullRemoteFileLocation &remote) = 0; virtual void on_upload_full_ok(QueryId id, FullRemoteFileLocation remote) = 0;
virtual void on_download_ok(QueryId id, const FullLocalFileLocation &local, int64 size, bool is_new) = 0; virtual void on_download_ok(QueryId id, FullLocalFileLocation local, int64 size, bool is_new) = 0;
virtual void on_error(QueryId id, Status status) = 0; virtual void on_error(QueryId id, Status status) = 0;
}; };
explicit FileLoadManager(ActorShared<Callback> callback, ActorShared<> parent); explicit FileLoadManager(ActorShared<Callback> callback, ActorShared<> parent);
void download(QueryId id, const FullRemoteFileLocation &remote_location, const LocalFileLocation &local, int64 size, void download(QueryId id, const FullRemoteFileLocation &remote_location, const LocalFileLocation &local, int64 size,
string name, const FileEncryptionKey &encryption_key, bool search_file, int64 offset, int64 limit, string name, const FileEncryptionKey &encryption_key, bool search_file, int64 offset, int64 limit,
int8 priority); int8 priority);
@ -55,6 +56,7 @@ class FileLoadManager final : public Actor {
void cancel(QueryId id); void cancel(QueryId id);
void update_local_file_location(QueryId id, const LocalFileLocation &local); void update_local_file_location(QueryId id, const LocalFileLocation &local);
void update_downloaded_part(QueryId id, int64 offset, int64 limit); void update_downloaded_part(QueryId id, int64 offset, int64 limit);
void get_content(const FullLocalFileLocation &local_location, Promise<BufferSlice> promise); void get_content(const FullLocalFileLocation &local_location, Promise<BufferSlice> promise);
private: private:
@ -84,12 +86,12 @@ class FileLoadManager final : public Actor {
ActorOwn<ResourceManager> &get_download_resource_manager(bool is_small, DcId dc_id); ActorOwn<ResourceManager> &get_download_resource_manager(bool is_small, DcId dc_id);
void on_start_download(); void on_start_download();
void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size, int64 size); void on_partial_download(PartialLocalFileLocation partial_local, int64 ready_size, int64 size);
void on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size); void on_partial_upload(PartialRemoteFileLocation partial_remote, int64 ready_size);
void on_hash(string hash); void on_hash(string hash);
void on_ok_download(const FullLocalFileLocation &local, int64 size, bool is_new); void on_ok_download(FullLocalFileLocation local, int64 size, bool is_new);
void on_ok_upload(FileType file_type, const PartialRemoteFileLocation &remote, int64 size); void on_ok_upload(FileType file_type, PartialRemoteFileLocation remote, int64 size);
void on_ok_upload_full(const FullRemoteFileLocation &remote); void on_ok_upload_full(FullRemoteFileLocation remote);
void on_error(Status status); void on_error(Status status);
void on_error_impl(NodeId node_id, Status status); void on_error_impl(NodeId node_id, Status status);
@ -104,11 +106,11 @@ class FileLoadManager final : public Actor {
void on_start_download() final { void on_start_download() final {
send_closure(actor_id_, &FileLoadManager::on_start_download); send_closure(actor_id_, &FileLoadManager::on_start_download);
} }
void on_partial_download(const PartialLocalFileLocation &partial_local, int64 ready_size, int64 size) final { void on_partial_download(PartialLocalFileLocation partial_local, int64 ready_size, int64 size) final {
send_closure(actor_id_, &FileLoadManager::on_partial_download, partial_local, ready_size, size); send_closure(actor_id_, &FileLoadManager::on_partial_download, std::move(partial_local), ready_size, size);
} }
void on_ok(const FullLocalFileLocation &full_local, int64 size, bool is_new) final { void on_ok(FullLocalFileLocation full_local, int64 size, bool is_new) final {
send_closure(std::move(actor_id_), &FileLoadManager::on_ok_download, full_local, size, is_new); send_closure(std::move(actor_id_), &FileLoadManager::on_ok_download, std::move(full_local), size, is_new);
} }
void on_error(Status status) final { void on_error(Status status) final {
send_closure(std::move(actor_id_), &FileLoadManager::on_error, std::move(status)); send_closure(std::move(actor_id_), &FileLoadManager::on_error, std::move(status));
@ -126,11 +128,11 @@ class FileLoadManager final : public Actor {
void on_hash(string hash) final { void on_hash(string hash) final {
send_closure(actor_id_, &FileLoadManager::on_hash, std::move(hash)); send_closure(actor_id_, &FileLoadManager::on_hash, std::move(hash));
} }
void on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size) final { void on_partial_upload(PartialRemoteFileLocation partial_remote, int64 ready_size) final {
send_closure(actor_id_, &FileLoadManager::on_partial_upload, partial_remote, ready_size); send_closure(actor_id_, &FileLoadManager::on_partial_upload, std::move(partial_remote), ready_size);
} }
void on_ok(FileType file_type, const PartialRemoteFileLocation &partial_remote, int64 size) final { void on_ok(FileType file_type, PartialRemoteFileLocation partial_remote, int64 size) final {
send_closure(std::move(actor_id_), &FileLoadManager::on_ok_upload, file_type, partial_remote, size); send_closure(std::move(actor_id_), &FileLoadManager::on_ok_upload, file_type, std::move(partial_remote), size);
} }
void on_error(Status status) final { void on_error(Status status) final {
send_closure(std::move(actor_id_), &FileLoadManager::on_error, std::move(status)); send_closure(std::move(actor_id_), &FileLoadManager::on_error, std::move(status));
@ -144,8 +146,8 @@ class FileLoadManager final : public Actor {
private: private:
ActorShared<FileLoadManager> actor_id_; ActorShared<FileLoadManager> actor_id_;
void on_ok(const FullRemoteFileLocation &remote) final { void on_ok(FullRemoteFileLocation remote) final {
send_closure(std::move(actor_id_), &FileLoadManager::on_ok_upload_full, remote); send_closure(std::move(actor_id_), &FileLoadManager::on_ok_upload_full, std::move(remote));
} }
void on_error(Status status) final { void on_error(Status status) final {
send_closure(std::move(actor_id_), &FileLoadManager::on_error, std::move(status)); send_closure(std::move(actor_id_), &FileLoadManager::on_error, std::move(status));

View File

@ -630,9 +630,9 @@ class RemoteFileLocation {
RemoteFileLocation() : variant_{EmptyRemoteFileLocation{}} { RemoteFileLocation() : variant_{EmptyRemoteFileLocation{}} {
} }
explicit RemoteFileLocation(const FullRemoteFileLocation &full) : variant_(full) { explicit RemoteFileLocation(FullRemoteFileLocation full) : variant_(std::move(full)) {
} }
explicit RemoteFileLocation(const PartialRemoteFileLocation &partial) : variant_(partial) { explicit RemoteFileLocation(PartialRemoteFileLocation partial) : variant_(std::move(partial)) {
} }
private: private:
@ -771,13 +771,15 @@ struct PartialLocalFileLocationPtr {
PartialLocalFileLocationPtr() : location_(make_unique<PartialLocalFileLocation>()) { PartialLocalFileLocationPtr() : location_(make_unique<PartialLocalFileLocation>()) {
} }
explicit PartialLocalFileLocationPtr(PartialLocalFileLocation location) explicit PartialLocalFileLocationPtr(PartialLocalFileLocation location)
: location_(make_unique<PartialLocalFileLocation>(location)) { : location_(make_unique<PartialLocalFileLocation>(std::move(location))) {
} }
PartialLocalFileLocationPtr(const PartialLocalFileLocationPtr &other) PartialLocalFileLocationPtr(const PartialLocalFileLocationPtr &other)
: location_(make_unique<PartialLocalFileLocation>(*other.location_)) { : location_(make_unique<PartialLocalFileLocation>(*other.location_)) {
} }
PartialLocalFileLocationPtr &operator=(const PartialLocalFileLocationPtr &other) { PartialLocalFileLocationPtr &operator=(const PartialLocalFileLocationPtr &other) {
if (this != &other) {
*location_ = *other.location_; *location_ = *other.location_;
}
return *this; return *this;
} }
PartialLocalFileLocationPtr(PartialLocalFileLocationPtr &&other) noexcept PartialLocalFileLocationPtr(PartialLocalFileLocationPtr &&other) noexcept
@ -839,9 +841,10 @@ class LocalFileLocation {
LocalFileLocation() : variant_{EmptyLocalFileLocation()} { LocalFileLocation() : variant_{EmptyLocalFileLocation()} {
} }
explicit LocalFileLocation(const PartialLocalFileLocation &partial) : variant_(PartialLocalFileLocationPtr(partial)) { explicit LocalFileLocation(PartialLocalFileLocation partial)
: variant_(PartialLocalFileLocationPtr(std::move(partial))) {
} }
explicit LocalFileLocation(const FullLocalFileLocation &full) : variant_(full) { explicit LocalFileLocation(FullLocalFileLocation full) : variant_(std::move(full)) {
} }
LocalFileLocation(FileType file_type, string path, uint64 mtime_nsec) LocalFileLocation(FileType file_type, string path, uint64 mtime_nsec)
: variant_(FullLocalFileLocation{file_type, std::move(path), mtime_nsec}) { : variant_(FullLocalFileLocation{file_type, std::move(path), mtime_nsec}) {

View File

@ -270,7 +270,7 @@ void FileNode::delete_partial_remote_location() {
} }
} }
void FileNode::set_partial_remote_location(const PartialRemoteFileLocation &remote, int64 ready_size) { void FileNode::set_partial_remote_location(PartialRemoteFileLocation remote, int64 ready_size) {
if (remote_.is_full_alive) { if (remote_.is_full_alive) {
VLOG(update_file) << "File " << main_file_id_ << " remote is still alive, so there is NO reason to update partial"; VLOG(update_file) << "File " << main_file_id_ << " remote is still alive, so there is NO reason to update partial";
return; return;
@ -293,7 +293,7 @@ void FileNode::set_partial_remote_location(const PartialRemoteFileLocation &remo
} }
VLOG(update_file) << "File " << main_file_id_ << " partial location has changed to " << remote; VLOG(update_file) << "File " << main_file_id_ << " partial location has changed to " << remote;
remote_.partial = make_unique<PartialRemoteFileLocation>(remote); remote_.partial = make_unique<PartialRemoteFileLocation>(std::move(remote));
on_changed(); on_changed();
} }
@ -1036,7 +1036,7 @@ bool FileManager::try_fix_partial_local_location(FileNodePtr node) {
partial.ready_bitmask_ = new_mask.encode(); partial.ready_bitmask_ = new_mask.encode();
auto ready_size = new_mask.get_total_size(partial.part_size_, node->size_); auto ready_size = new_mask.get_total_size(partial.part_size_, node->size_);
node->set_local_location(LocalFileLocation(partial), ready_size, -1, -1); node->set_local_location(LocalFileLocation(std::move(partial)), ready_size, -1, -1);
LOG(INFO) << " ok: increase part_size " << old_part_size << "->" << new_part_size; LOG(INFO) << " ok: increase part_size " << old_part_size << "->" << new_part_size;
return true; return true;
} }
@ -1109,17 +1109,17 @@ Result<FileId> FileManager::register_local(FullLocalFileLocation location, Dialo
skip_file_size_checks); skip_file_size_checks);
} }
FileId FileManager::register_remote(const FullRemoteFileLocation &location, FileLocationSource file_location_source, FileId FileManager::register_remote(FullRemoteFileLocation location, FileLocationSource file_location_source,
DialogId owner_dialog_id, int64 size, int64 expected_size, string remote_name) { DialogId owner_dialog_id, int64 size, int64 expected_size, string remote_name) {
FileData data; FileData data;
data.remote_ = RemoteFileLocation(location); auto url = location.get_url();
data.remote_ = RemoteFileLocation(std::move(location));
data.owner_dialog_id_ = owner_dialog_id; data.owner_dialog_id_ = owner_dialog_id;
data.size_ = size; data.size_ = size;
data.expected_size_ = expected_size; data.expected_size_ = expected_size;
data.remote_name_ = std::move(remote_name); data.remote_name_ = std::move(remote_name);
auto file_id = register_file(std::move(data), file_location_source, "register_remote", false).move_as_ok(); auto file_id = register_file(std::move(data), file_location_source, "register_remote", false).move_as_ok();
auto url = location.get_url();
if (!url.empty()) { if (!url.empty()) {
auto file_node = get_file_node(file_id); auto file_node = get_file_node(file_id);
CHECK(file_node); CHECK(file_node);
@ -1273,8 +1273,8 @@ Result<FileId> FileManager::register_file(FileData &&data, FileLocationSource fi
// 1 -- choose y // 1 -- choose y
// 2 -- choose any // 2 -- choose any
static int merge_choose_local_location(const LocalFileLocation &x, const LocalFileLocation &y) { static int merge_choose_local_location(const LocalFileLocation &x, const LocalFileLocation &y) {
int32 x_type = static_cast<int32>(x.type()); auto x_type = static_cast<int32>(x.type());
int32 y_type = static_cast<int32>(y.type()); auto y_type = static_cast<int32>(y.type());
if (x_type != y_type) { if (x_type != y_type) {
return x_type < y_type; return x_type < y_type;
} }
@ -2382,7 +2382,7 @@ class FileManager::ForceUploadActor final : public Actor {
void on_upload_error(FileId file_id, Status error) final { void on_upload_error(FileId file_id, Status error) final {
send_closure(std::move(callback_), &ForceUploadActor::on_upload_error, std::move(error)); send_closure(std::move(callback_), &ForceUploadActor::on_upload_error, std::move(error));
} }
~UploadCallback() { ~UploadCallback() final {
if (callback_.empty()) { if (callback_.empty()) {
return; return;
} }
@ -2594,7 +2594,7 @@ bool FileManager::delete_partial_remote_location(FileId file_id) {
return true; return true;
} }
void FileManager::delete_file_reference(FileId file_id, string file_reference) { void FileManager::delete_file_reference(FileId file_id, Slice file_reference) {
VLOG(file_references) << "Delete file reference of file " << file_id << " " VLOG(file_references) << "Delete file reference of file " << file_id << " "
<< tag("reference_base64", base64_encode(file_reference)); << tag("reference_base64", base64_encode(file_reference));
auto node = get_sync_file_node(file_id); auto node = get_sync_file_node(file_id);
@ -2697,11 +2697,12 @@ void FileManager::run_generate(FileNodePtr node) {
public: public:
Callback(ActorId<FileManager> actor, QueryId id) : actor_(std::move(actor)), query_id_(id) { Callback(ActorId<FileManager> actor, QueryId id) : actor_(std::move(actor)), query_id_(id) {
} }
void on_partial_generate(const PartialLocalFileLocation &partial_local, int32 expected_size) final { void on_partial_generate(PartialLocalFileLocation partial_local, int32 expected_size) final {
send_closure(actor_, &FileManager::on_partial_generate, query_id_, partial_local, expected_size); send_closure(actor_, &FileManager::on_partial_generate, query_id_, std::move(partial_local),
expected_size);
} }
void on_ok(const FullLocalFileLocation &local) final { void on_ok(FullLocalFileLocation local) final {
send_closure(actor_, &FileManager::on_generate_ok, query_id_, local); send_closure(actor_, &FileManager::on_generate_ok, query_id_, std::move(local));
} }
void on_error(Status error) final { void on_error(Status error) final {
send_closure(actor_, &FileManager::on_error, query_id_, std::move(error)); send_closure(actor_, &FileManager::on_error, query_id_, std::move(error));
@ -2972,12 +2973,12 @@ td_api::object_ptr<td_api::file> FileManager::get_file_object(FileId file_id, bo
string persistent_file_id = file_view.get_persistent_file_id(); string persistent_file_id = file_view.get_persistent_file_id();
string unique_file_id = file_view.get_unique_file_id(); string unique_file_id = file_view.get_unique_file_id();
bool is_uploading_completed = !persistent_file_id.empty(); bool is_uploading_completed = !persistent_file_id.empty();
int32 size = narrow_cast<int32>(file_view.size()); auto size = narrow_cast<int32>(file_view.size());
int32 expected_size = narrow_cast<int32>(file_view.expected_size()); auto expected_size = narrow_cast<int32>(file_view.expected_size());
int32 download_offset = narrow_cast<int32>(file_view.download_offset()); auto download_offset = narrow_cast<int32>(file_view.download_offset());
int32 local_prefix_size = narrow_cast<int32>(file_view.local_prefix_size()); auto local_prefix_size = narrow_cast<int32>(file_view.local_prefix_size());
int32 local_total_size = narrow_cast<int32>(file_view.local_total_size()); auto local_total_size = narrow_cast<int32>(file_view.local_total_size());
int32 remote_size = narrow_cast<int32>(file_view.remote_size()); auto remote_size = narrow_cast<int32>(file_view.remote_size());
string path = file_view.path(); string path = file_view.path();
bool can_be_downloaded = file_view.can_download_from_server() || file_view.can_generate(); bool can_be_downloaded = file_view.can_download_from_server() || file_view.can_generate();
bool can_be_deleted = file_view.can_delete(); bool can_be_deleted = file_view.can_delete();
@ -3189,8 +3190,8 @@ Result<FileId> FileManager::get_map_thumbnail_file_id(Location location, int32 z
const double PI = 3.14159265358979323846; const double PI = 3.14159265358979323846;
double sin_latitude = std::sin(location.get_latitude() * PI / 180); double sin_latitude = std::sin(location.get_latitude() * PI / 180);
int32 size = 256 * (1 << zoom); int32 size = 256 * (1 << zoom);
int32 x = static_cast<int32>((location.get_longitude() + 180) / 360 * size); auto x = static_cast<int32>((location.get_longitude() + 180) / 360 * size);
int32 y = static_cast<int32>((0.5 - std::log((1 + sin_latitude) / (1 - sin_latitude)) / (4 * PI)) * size); auto y = static_cast<int32>((0.5 - std::log((1 + sin_latitude) / (1 - sin_latitude)) / (4 * PI)) * size);
x = clamp(x, 0, size - 1); // just in case x = clamp(x, 0, size - 1); // just in case
y = clamp(y, 0, size - 1); // just in case y = clamp(y, 0, size - 1); // just in case
@ -3352,7 +3353,7 @@ FileId FileManager::next_file_id() {
} }
FileManager::FileNodeId FileManager::next_file_node_id() { FileManager::FileNodeId FileManager::next_file_node_id() {
FileNodeId res = static_cast<FileNodeId>(file_nodes_.size()); auto res = static_cast<FileNodeId>(file_nodes_.size());
file_nodes_.emplace_back(nullptr); file_nodes_.emplace_back(nullptr);
return res; return res;
} }
@ -3379,7 +3380,7 @@ void FileManager::on_start_download(QueryId query_id) {
file_node->is_download_started_ = true; file_node->is_download_started_ = true;
} }
void FileManager::on_partial_download(QueryId query_id, const PartialLocalFileLocation &partial_local, int64 ready_size, void FileManager::on_partial_download(QueryId query_id, PartialLocalFileLocation partial_local, int64 ready_size,
int64 size) { int64 size) {
if (is_closed_) { if (is_closed_) {
return; return;
@ -3405,7 +3406,7 @@ void FileManager::on_partial_download(QueryId query_id, const PartialLocalFileLo
file_node->set_size(size); file_node->set_size(size);
} }
} }
file_node->set_local_location(LocalFileLocation(partial_local), ready_size, -1, -1 /* TODO */); file_node->set_local_location(LocalFileLocation(std::move(partial_local)), ready_size, -1, -1 /* TODO */);
try_flush_node(file_node, "on_partial_download"); try_flush_node(file_node, "on_partial_download");
} }
@ -3431,8 +3432,7 @@ void FileManager::on_hash(QueryId query_id, string hash) {
file_node->encryption_key_.set_value_hash(secure_storage::ValueHash::create(hash).move_as_ok()); file_node->encryption_key_.set_value_hash(secure_storage::ValueHash::create(hash).move_as_ok());
} }
void FileManager::on_partial_upload(QueryId query_id, const PartialRemoteFileLocation &partial_remote, void FileManager::on_partial_upload(QueryId query_id, PartialRemoteFileLocation partial_remote, int64 ready_size) {
int64 ready_size) {
if (is_closed_) { if (is_closed_) {
return; return;
} }
@ -3451,11 +3451,11 @@ void FileManager::on_partial_upload(QueryId query_id, const PartialRemoteFileLoc
return; return;
} }
file_node->set_partial_remote_location(partial_remote, ready_size); file_node->set_partial_remote_location(std::move(partial_remote), ready_size);
try_flush_node(file_node, "on_partial_upload"); try_flush_node(file_node, "on_partial_upload");
} }
void FileManager::on_download_ok(QueryId query_id, const FullLocalFileLocation &local, int64 size, bool is_new) { void FileManager::on_download_ok(QueryId query_id, FullLocalFileLocation local, int64 size, bool is_new) {
if (is_closed_) { if (is_closed_) {
return; return;
} }
@ -3465,7 +3465,7 @@ void FileManager::on_download_ok(QueryId query_id, const FullLocalFileLocation &
std::tie(query, was_active) = finish_query(query_id); std::tie(query, was_active) = finish_query(query_id);
auto file_id = query.file_id_; auto file_id = query.file_id_;
LOG(INFO) << "ON DOWNLOAD OK of " << (is_new ? "new" : "checked") << " file " << file_id << " of size " << size; LOG(INFO) << "ON DOWNLOAD OK of " << (is_new ? "new" : "checked") << " file " << file_id << " of size " << size;
auto r_new_file_id = register_local(local, DialogId(), size, false, false, true); auto r_new_file_id = register_local(std::move(local), DialogId(), size, false, false, true);
Status status = Status::OK(); Status status = Status::OK();
if (r_new_file_id.is_error()) { if (r_new_file_id.is_error()) {
status = Status::Error(PSLICE() << "Can't register local file after download: " << r_new_file_id.error().message()); status = Status::Error(PSLICE() << "Can't register local file after download: " << r_new_file_id.error().message());
@ -3484,7 +3484,7 @@ void FileManager::on_download_ok(QueryId query_id, const FullLocalFileLocation &
} }
} }
void FileManager::on_upload_ok(QueryId query_id, FileType file_type, const PartialRemoteFileLocation &partial_remote, void FileManager::on_upload_ok(QueryId query_id, FileType file_type, PartialRemoteFileLocation partial_remote,
int64 size) { int64 size) {
if (is_closed_) { if (is_closed_) {
return; return;
@ -3561,19 +3561,18 @@ void FileManager::on_upload_ok(QueryId query_id, FileType file_type, const Parti
} }
} }
void FileManager::on_upload_full_ok(QueryId query_id, const FullRemoteFileLocation &remote) { void FileManager::on_upload_full_ok(QueryId query_id, FullRemoteFileLocation remote) {
if (is_closed_) { if (is_closed_) {
return; return;
} }
auto file_id = finish_query(query_id).first.file_id_; auto file_id = finish_query(query_id).first.file_id_;
LOG(INFO) << "ON UPLOAD FULL OK for file " << file_id; LOG(INFO) << "ON UPLOAD FULL OK for file " << file_id;
auto new_file_id = register_remote(remote, FileLocationSource::FromServer, DialogId(), 0, 0, ""); auto new_file_id = register_remote(std::move(remote), FileLocationSource::FromServer, DialogId(), 0, 0, "");
LOG_STATUS(merge(new_file_id, file_id)); LOG_STATUS(merge(new_file_id, file_id));
} }
void FileManager::on_partial_generate(QueryId query_id, const PartialLocalFileLocation &partial_local, void FileManager::on_partial_generate(QueryId query_id, PartialLocalFileLocation partial_local, int32 expected_size) {
int32 expected_size) {
if (is_closed_) { if (is_closed_) {
return; return;
} }
@ -3603,13 +3602,13 @@ void FileManager::on_partial_generate(QueryId query_id, const PartialLocalFileLo
} }
if (file_node->upload_id_ != 0) { if (file_node->upload_id_ != 0) {
send_closure(file_load_manager_, &FileLoadManager::update_local_file_location, file_node->upload_id_, send_closure(file_load_manager_, &FileLoadManager::update_local_file_location, file_node->upload_id_,
LocalFileLocation(partial_local)); LocalFileLocation(std::move(partial_local)));
} }
try_flush_node(file_node, "on_partial_generate"); try_flush_node(file_node, "on_partial_generate");
} }
void FileManager::on_generate_ok(QueryId query_id, const FullLocalFileLocation &local) { void FileManager::on_generate_ok(QueryId query_id, FullLocalFileLocation local) {
if (is_closed_) { if (is_closed_) {
return; return;
} }
@ -3653,7 +3652,7 @@ void FileManager::on_generate_ok(QueryId query_id, const FullLocalFileLocation &
if (was_active) { if (was_active) {
if (old_upload_id != 0 && old_upload_id == file_node->upload_id_) { if (old_upload_id != 0 && old_upload_id == file_node->upload_id_) {
send_closure(file_load_manager_, &FileLoadManager::update_local_file_location, file_node->upload_id_, send_closure(file_load_manager_, &FileLoadManager::update_local_file_location, file_node->upload_id_,
LocalFileLocation(local)); LocalFileLocation(std::move(local)));
} }
} }
} }

View File

@ -88,7 +88,7 @@ class FileNode {
int64 ready_prefix_size); int64 ready_prefix_size);
void set_new_remote_location(NewRemoteFileLocation remote); void set_new_remote_location(NewRemoteFileLocation remote);
void delete_partial_remote_location(); void delete_partial_remote_location();
void set_partial_remote_location(const PartialRemoteFileLocation &remote, int64 ready_size); void set_partial_remote_location(PartialRemoteFileLocation remote, int64 ready_size);
bool delete_file_reference(Slice file_reference); bool delete_file_reference(Slice file_reference);
void set_generate_location(unique_ptr<FullGenerateFileLocation> &&generate); void set_generate_location(unique_ptr<FullGenerateFileLocation> &&generate);
@ -98,7 +98,7 @@ class FileNode {
void set_url(string url); void set_url(string url);
void set_owner_dialog_id(DialogId owner_id); void set_owner_dialog_id(DialogId owner_id);
void set_encryption_key(FileEncryptionKey key); void set_encryption_key(FileEncryptionKey key);
void set_upload_pause(FileId file_id); void set_upload_pause(FileId upload_pause);
void set_download_priority(int8 priority); void set_download_priority(int8 priority);
void set_upload_priority(int8 priority); void set_upload_priority(int8 priority);
@ -419,7 +419,7 @@ class FileManager final : public FileLoadManager::Callback {
Result<FileId> register_local(FullLocalFileLocation location, DialogId owner_dialog_id, int64 size, Result<FileId> register_local(FullLocalFileLocation location, DialogId owner_dialog_id, int64 size,
bool get_by_hash = false, bool force = false, bool get_by_hash = false, bool force = false,
bool skip_file_size_checks = false) TD_WARN_UNUSED_RESULT; bool skip_file_size_checks = false) TD_WARN_UNUSED_RESULT;
FileId register_remote(const FullRemoteFileLocation &location, FileLocationSource file_location_source, FileId register_remote(FullRemoteFileLocation location, FileLocationSource file_location_source,
DialogId owner_dialog_id, int64 size, int64 expected_size, DialogId owner_dialog_id, int64 size, int64 expected_size,
string remote_name) TD_WARN_UNUSED_RESULT; string remote_name) TD_WARN_UNUSED_RESULT;
Result<FileId> register_generate(FileType file_type, FileLocationSource file_location_source, string original_path, Result<FileId> register_generate(FileType file_type, FileLocationSource file_location_source, string original_path,
@ -448,7 +448,7 @@ class FileManager final : public FileLoadManager::Callback {
int32 new_priority, uint64 upload_order, bool force = false, bool prefer_small = false); int32 new_priority, uint64 upload_order, bool force = false, bool prefer_small = false);
void cancel_upload(FileId file_id); void cancel_upload(FileId file_id);
bool delete_partial_remote_location(FileId file_id); bool delete_partial_remote_location(FileId file_id);
void delete_file_reference(FileId file_id, std::string file_reference); void delete_file_reference(FileId file_id, Slice file_reference);
void get_content(FileId file_id, Promise<BufferSlice> promise); void get_content(FileId file_id, Promise<BufferSlice> promise);
Result<string> get_suggested_file_name(FileId file_id, const string &directory); Result<string> get_suggested_file_name(FileId file_id, const string &directory);
@ -468,7 +468,7 @@ class FileManager final : public FileLoadManager::Callback {
td_api::object_ptr<td_api::file> get_file_object(FileId file_id, bool with_main_file_id = true); td_api::object_ptr<td_api::file> get_file_object(FileId file_id, bool with_main_file_id = true);
vector<int32> get_file_ids_object(const vector<FileId> &file_ids, bool with_main_file_id = true); vector<int32> get_file_ids_object(const vector<FileId> &file_ids, bool with_main_file_id = true);
Result<FileId> get_input_thumbnail_file_id(const tl_object_ptr<td_api::InputFile> &thumb_input_file, Result<FileId> get_input_thumbnail_file_id(const tl_object_ptr<td_api::InputFile> &thumbnail_input_file,
DialogId owner_dialog_id, bool is_encrypted) TD_WARN_UNUSED_RESULT; DialogId owner_dialog_id, bool is_encrypted) TD_WARN_UNUSED_RESULT;
Result<FileId> get_input_file_id(FileType type, const tl_object_ptr<td_api::InputFile> &file, Result<FileId> get_input_file_id(FileType type, const tl_object_ptr<td_api::InputFile> &file,
DialogId owner_dialog_id, bool allow_zero, bool is_encrypted, DialogId owner_dialog_id, bool allow_zero, bool is_encrypted,
@ -599,7 +599,7 @@ class FileManager final : public FileLoadManager::Callback {
FileId register_pmc_file_data(FileData &&data); FileId register_pmc_file_data(FileData &&data);
Status check_local_location(FileNodePtr node); Status check_local_location(FileNodePtr node);
bool try_fix_partial_local_location(FileNodePtr node); static bool try_fix_partial_local_location(FileNodePtr node);
Status check_local_location(FullLocalFileLocation &location, int64 &size, bool skip_file_size_checks); Status check_local_location(FullLocalFileLocation &location, int64 &size, bool skip_file_size_checks);
void try_flush_node_full(FileNodePtr node, bool new_remote, bool new_local, bool new_generate, FileDbId other_pmc_id); void try_flush_node_full(FileNodePtr node, bool new_remote, bool new_local, bool new_generate, FileDbId other_pmc_id);
void try_flush_node(FileNodePtr node, const char *source); void try_flush_node(FileNodePtr node, const char *source);
@ -614,7 +614,7 @@ class FileManager final : public FileLoadManager::Callback {
Result<FileId> from_persistent_id_v3(Slice binary, FileType file_type); Result<FileId> from_persistent_id_v3(Slice binary, FileType file_type);
Result<FileId> from_persistent_id_v23(Slice binary, FileType file_type, int32 version); Result<FileId> from_persistent_id_v23(Slice binary, FileType file_type, int32 version);
string fix_file_extension(Slice file_name, Slice file_type, Slice file_extension); static string fix_file_extension(Slice file_name, Slice file_type, Slice file_extension);
string get_file_name(FileType file_type, Slice path); string get_file_name(FileType file_type, Slice path);
ConstFileNodePtr get_file_node(FileId file_id) const { ConstFileNodePtr get_file_node(FileId file_id) const {
@ -638,20 +638,19 @@ class FileManager final : public FileLoadManager::Callback {
void run_generate(FileNodePtr node); void run_generate(FileNodePtr node);
void on_start_download(QueryId query_id) final; void on_start_download(QueryId query_id) final;
void on_partial_download(QueryId query_id, const PartialLocalFileLocation &partial_local, int64 ready_size, void on_partial_download(QueryId query_id, PartialLocalFileLocation partial_local, int64 ready_size,
int64 size) final; int64 size) final;
void on_hash(QueryId query_id, string hash) final; void on_hash(QueryId query_id, string hash) final;
void on_partial_upload(QueryId query_id, const PartialRemoteFileLocation &partial_remote, int64 ready_size) final; void on_partial_upload(QueryId query_id, PartialRemoteFileLocation partial_remote, int64 ready_size) final;
void on_download_ok(QueryId query_id, const FullLocalFileLocation &local, int64 size, bool is_new) final; void on_download_ok(QueryId query_id, FullLocalFileLocation local, int64 size, bool is_new) final;
void on_upload_ok(QueryId query_id, FileType file_type, const PartialRemoteFileLocation &partial_remote, void on_upload_ok(QueryId query_id, FileType file_type, PartialRemoteFileLocation partial_remote, int64 size) final;
int64 size) final; void on_upload_full_ok(QueryId query_id, FullRemoteFileLocation remote) final;
void on_upload_full_ok(QueryId query_id, const FullRemoteFileLocation &remote) final;
void on_error(QueryId query_id, Status status) final; void on_error(QueryId query_id, Status status) final;
void on_error_impl(FileNodePtr node, Query::Type type, bool was_active, Status status); void on_error_impl(FileNodePtr node, Query::Type type, bool was_active, Status status);
void on_partial_generate(QueryId, const PartialLocalFileLocation &partial_local, int32 expected_size); void on_partial_generate(QueryId, PartialLocalFileLocation partial_local, int32 expected_size);
void on_generate_ok(QueryId, const FullLocalFileLocation &local); void on_generate_ok(QueryId, FullLocalFileLocation local);
std::pair<Query, bool> finish_query(QueryId query_id); std::pair<Query, bool> finish_query(QueryId query_id);

View File

@ -137,7 +137,7 @@ td_api::object_ptr<td_api::storageStatisticsByChat> FileStats::get_storage_stati
auto stats = make_tl_object<td_api::storageStatisticsByChat>(dialog_id.get(), 0, 0, Auto()); auto stats = make_tl_object<td_api::storageStatisticsByChat>(dialog_id.get(), 0, 0, Auto());
FileStats::StatByType aggregated_stats; FileStats::StatByType aggregated_stats;
for (int32 i = 0; i < MAX_FILE_TYPE; i++) { for (int32 i = 0; i < MAX_FILE_TYPE; i++) {
size_t file_type = narrow_cast<size_t>(get_main_file_type(static_cast<FileType>(i))); auto file_type = narrow_cast<size_t>(get_main_file_type(static_cast<FileType>(i)));
aggregated_stats[file_type].size += stat_by_type_[i].size; aggregated_stats[file_type].size += stat_by_type_[i].size;
aggregated_stats[file_type].cnt += stat_by_type_[i].cnt; aggregated_stats[file_type].cnt += stat_by_type_[i].cnt;
} }
@ -150,7 +150,7 @@ td_api::object_ptr<td_api::storageStatisticsByChat> FileStats::get_storage_stati
continue; continue;
} }
FileType file_type = static_cast<FileType>(i); auto file_type = static_cast<FileType>(i);
stats->size_ += size; stats->size_ += size;
stats->count_ += cnt; stats->count_ += cnt;
stats->by_file_type_.push_back( stats->by_file_type_.push_back(

View File

@ -24,8 +24,8 @@ class FileUploader final : public FileLoader {
class Callback : public FileLoader::Callback { class Callback : public FileLoader::Callback {
public: public:
virtual void on_hash(string hash) = 0; virtual void on_hash(string hash) = 0;
virtual void on_partial_upload(const PartialRemoteFileLocation &partial_remote, int64 ready_size) = 0; virtual void on_partial_upload(PartialRemoteFileLocation partial_remote, int64 ready_size) = 0;
virtual void on_ok(FileType file_type, const PartialRemoteFileLocation &partial_remote, int64 size) = 0; virtual void on_ok(FileType file_type, PartialRemoteFileLocation partial_remote, int64 size) = 0;
virtual void on_error(Status status) = 0; virtual void on_error(Status status) = 0;
}; };

View File

@ -537,8 +537,8 @@ int64 PartsManager::get_unchecked_ready_prefix_size() {
} }
Part PartsManager::get_part(int id) const { Part PartsManager::get_part(int id) const {
int64 offset = narrow_cast<int64>(part_size_) * id; auto size = narrow_cast<int64>(part_size_);
int64 size = narrow_cast<int64>(part_size_); auto offset = size * id;
auto total_size = unknown_size_flag_ ? max_size_ : get_size(); auto total_size = unknown_size_flag_ ? max_size_ : get_size();
if (total_size < offset) { if (total_size < offset) {
size = 0; size = 0;

View File

@ -93,8 +93,9 @@ class PartsManager {
const std::vector<int> &ready_parts) TD_WARN_UNUSED_RESULT; const std::vector<int> &ready_parts) TD_WARN_UNUSED_RESULT;
Status init_no_size(size_t part_size, const std::vector<int> &ready_parts) TD_WARN_UNUSED_RESULT; Status init_no_size(size_t part_size, const std::vector<int> &ready_parts) TD_WARN_UNUSED_RESULT;
static Part get_empty_part();
Part get_part(int id) const; Part get_part(int id) const;
Part get_empty_part();
void on_part_start(int32 id); void on_part_start(int32 id);
void update_first_empty_part(); void update_first_empty_part();
void update_first_not_ready_part(); void update_first_not_ready_part();

View File

@ -74,7 +74,7 @@ bool clean_input_string(string &str) {
size_t str_size = str.size(); size_t str_size = str.size();
size_t new_size = 0; size_t new_size = 0;
for (size_t pos = 0; pos < str_size; pos++) { for (size_t pos = 0; pos < str_size; pos++) {
unsigned char c = static_cast<unsigned char>(str[pos]); auto c = static_cast<unsigned char>(str[pos]);
switch (c) { switch (c) {
// remove control characters // remove control characters
case 0: case 0:
@ -118,7 +118,7 @@ bool clean_input_string(string &str) {
default: default:
// remove \xe2\x80[\xa8-\xae] // remove \xe2\x80[\xa8-\xae]
if (c == 0xe2 && pos + 2 < str_size) { if (c == 0xe2 && pos + 2 < str_size) {
unsigned char next = static_cast<unsigned char>(str[pos + 1]); auto next = static_cast<unsigned char>(str[pos + 1]);
if (next == 0x80) { if (next == 0x80) {
next = static_cast<unsigned char>(str[pos + 2]); next = static_cast<unsigned char>(str[pos + 2]);
if (0xa8 <= next && next <= 0xae) { if (0xa8 <= next && next <= 0xae) {
@ -129,7 +129,7 @@ bool clean_input_string(string &str) {
} }
// remove vertical lines \xcc[\xb3\xbf\x8a] // remove vertical lines \xcc[\xb3\xbf\x8a]
if (c == 0xcc && pos + 1 < str_size) { if (c == 0xcc && pos + 1 < str_size) {
unsigned char next = static_cast<unsigned char>(str[pos + 1]); auto next = static_cast<unsigned char>(str[pos + 1]);
if (next == 0xb3 || next == 0xbf || next == 0x8a) { if (next == 0xb3 || next == 0xbf || next == 0x8a) {
pos++; pos++;
break; break;

View File

@ -672,7 +672,7 @@ Result<mtproto::TransportType> ConnectionCreator::get_transport_type(const Proxy
if (G()->is_test_dc()) { if (G()->is_test_dc()) {
int_dc_id += 10000; int_dc_id += 10000;
} }
int16 raw_dc_id = narrow_cast<int16>(info.option->is_media_only() ? -int_dc_id : int_dc_id); auto raw_dc_id = narrow_cast<int16>(info.option->is_media_only() ? -int_dc_id : int_dc_id);
if (proxy.use_mtproto_proxy()) { if (proxy.use_mtproto_proxy()) {
return mtproto::TransportType{mtproto::TransportType::ObfuscatedTcp, raw_dc_id, proxy.secret()}; return mtproto::TransportType{mtproto::TransportType::ObfuscatedTcp, raw_dc_id, proxy.secret()};
@ -736,7 +736,7 @@ Result<SocketFd> ConnectionCreator::find_connection(const Proxy &proxy, const IP
ActorOwn<> ConnectionCreator::prepare_connection(IPAddress ip_address, SocketFd socket_fd, const Proxy &proxy, ActorOwn<> ConnectionCreator::prepare_connection(IPAddress ip_address, SocketFd socket_fd, const Proxy &proxy,
const IPAddress &mtproto_ip_address, const IPAddress &mtproto_ip_address,
mtproto::TransportType transport_type, Slice actor_name_prefix, const mtproto::TransportType &transport_type, Slice actor_name_prefix,
Slice debug_str, Slice debug_str,
unique_ptr<mtproto::RawConnection::StatsCallback> stats_callback, unique_ptr<mtproto::RawConnection::StatsCallback> stats_callback,
ActorShared<> parent, bool use_connection_token, ActorShared<> parent, bool use_connection_token,
@ -934,12 +934,12 @@ void ConnectionCreator::client_loop(ClientInfo &client) {
client.checking_connections++; client.checking_connections++;
} }
auto promise = PromiseCreator::lambda( auto promise = PromiseCreator::lambda([actor_id = actor_id(this), check_mode, transport_type = extra.transport_type,
[actor_id = actor_id(this), check_mode, transport_type = extra.transport_type, hash = client.hash, hash = client.hash, debug_str = extra.debug_str,
debug_str = extra.debug_str, network_generation =
network_generation = network_generation_](Result<ConnectionData> r_connection_data) mutable { network_generation_](Result<ConnectionData> r_connection_data) mutable {
send_closure(std::move(actor_id), &ConnectionCreator::client_create_raw_connection, send_closure(std::move(actor_id), &ConnectionCreator::client_create_raw_connection, std::move(r_connection_data),
std::move(r_connection_data), check_mode, transport_type, hash, debug_str, network_generation); check_mode, std::move(transport_type), hash, std::move(debug_str), network_generation);
}); });
auto stats_callback = auto stats_callback =
@ -1060,17 +1060,16 @@ void ConnectionCreator::on_dc_options(DcOptions new_dc_options) {
} }
void ConnectionCreator::on_dc_update(DcId dc_id, string ip_port, Promise<> promise) { void ConnectionCreator::on_dc_update(DcId dc_id, string ip_port, Promise<> promise) {
promise.set_result([&]() -> Result<> {
if (!dc_id.is_exact()) { if (!dc_id.is_exact()) {
return Status::Error("Invalid dc_id"); return promise.set_error(Status::Error("Invalid dc_id"));
} }
IPAddress ip_address; IPAddress ip_address;
TRY_STATUS(ip_address.init_host_port(ip_port)); TRY_STATUS_PROMISE(promise, ip_address.init_host_port(ip_port));
DcOptions options; DcOptions options;
options.dc_options.emplace_back(dc_id, ip_address); options.dc_options.emplace_back(dc_id, ip_address);
send_closure(G()->config_manager(), &ConfigManager::on_dc_options_update, std::move(options)); send_closure(G()->config_manager(), &ConfigManager::on_dc_options_update, std::move(options));
return Unit(); promise.set_value(Unit());
}());
} }
void ConnectionCreator::update_mtproto_header(const Proxy &proxy) { void ConnectionCreator::update_mtproto_header(const Proxy &proxy) {
@ -1129,13 +1128,13 @@ void ConnectionCreator::start_up() {
for (auto &info : proxy_info) { for (auto &info : proxy_info) {
if (begins_with(info.first, "_used")) { if (begins_with(info.first, "_used")) {
int32 proxy_id = to_integer_safe<int32>(Slice(info.first).substr(5)).move_as_ok(); auto proxy_id = to_integer_safe<int32>(Slice(info.first).substr(5)).move_as_ok();
int32 last_used = to_integer_safe<int32>(info.second).move_as_ok(); auto last_used = to_integer_safe<int32>(info.second).move_as_ok();
proxy_last_used_date_[proxy_id] = last_used; proxy_last_used_date_[proxy_id] = last_used;
proxy_last_used_saved_date_[proxy_id] = last_used; proxy_last_used_saved_date_[proxy_id] = last_used;
} else { } else {
LOG_CHECK(!ends_with(info.first, "_max_id")) << info.first; LOG_CHECK(!ends_with(info.first, "_max_id")) << info.first;
int32 proxy_id = info.first == "" ? 1 : to_integer_safe<int32>(info.first).move_as_ok(); auto proxy_id = info.first.empty() ? static_cast<int32>(1) : to_integer_safe<int32>(info.first).move_as_ok();
CHECK(proxies_.count(proxy_id) == 0); CHECK(proxies_.count(proxy_id) == 0);
log_event_parse(proxies_[proxy_id], info.second).ensure(); log_event_parse(proxies_[proxy_id], info.second).ensure();
if (proxies_[proxy_id].type() == Proxy::Type::None) { if (proxies_[proxy_id].type() == Proxy::Type::None) {

View File

@ -89,8 +89,9 @@ class ConnectionCreator final : public NetQueryCallback {
static DcOptions get_default_dc_options(bool is_test); static DcOptions get_default_dc_options(bool is_test);
static ActorOwn<> prepare_connection(IPAddress ip_address, SocketFd socket_fd, const Proxy &proxy, static ActorOwn<> prepare_connection(IPAddress ip_address, SocketFd socket_fd, const Proxy &proxy,
const IPAddress &mtproto_ip_address, mtproto::TransportType transport_type, const IPAddress &mtproto_ip_address,
Slice actor_name_prefix, Slice debug_str, const mtproto::TransportType &transport_type, Slice actor_name_prefix,
Slice debug_str,
unique_ptr<mtproto::RawConnection::StatsCallback> stats_callback, unique_ptr<mtproto::RawConnection::StatsCallback> stats_callback,
ActorShared<> parent, bool use_connection_token, ActorShared<> parent, bool use_connection_token,
Promise<ConnectionData> promise); Promise<ConnectionData> promise);

View File

@ -93,7 +93,7 @@ DcAuthManager::DcInfo *DcAuthManager::find_dc(int32 dc_id) {
} }
void DcAuthManager::update_auth_key_state() { void DcAuthManager::update_auth_key_state() {
int32 dc_id = narrow_cast<int32>(get_link_token()); auto dc_id = narrow_cast<int32>(get_link_token());
auto &dc = get_dc(dc_id); auto &dc = get_dc(dc_id);
dc.auth_key_state = dc.shared_auth_data->get_auth_key_state(); dc.auth_key_state = dc.shared_auth_data->get_auth_key_state();
VLOG(dc) << "Update " << dc_id << " auth key state from " << dc.auth_key_state << " to " << dc.auth_key_state; VLOG(dc) << "Update " << dc_id << " auth key state from " << dc.auth_key_state << " to " << dc.auth_key_state;
@ -102,7 +102,7 @@ void DcAuthManager::update_auth_key_state() {
} }
void DcAuthManager::on_result(NetQueryPtr result) { void DcAuthManager::on_result(NetQueryPtr result) {
int32 dc_id = narrow_cast<int32>(get_link_token()); auto dc_id = narrow_cast<int32>(get_link_token());
auto &dc = get_dc(dc_id); auto &dc = get_dc(dc_id);
CHECK(dc.wait_id == result->id()); CHECK(dc.wait_id == result->id());
dc.wait_id = std::numeric_limits<decltype(dc.wait_id)>::max(); dc.wait_id = std::numeric_limits<decltype(dc.wait_id)>::max();

View File

@ -33,7 +33,7 @@ class MtprotoHeader {
} }
void set_proxy(Proxy proxy) { void set_proxy(Proxy proxy) {
options_.proxy = proxy; options_.proxy = std::move(proxy);
default_header_ = gen_header(options_, false); default_header_ = gen_header(options_, false);
} }
@ -42,7 +42,7 @@ class MtprotoHeader {
return false; return false;
} }
options_.parameters = parameters; options_.parameters = std::move(parameters);
default_header_ = gen_header(options_, false); default_header_ = gen_header(options_, false);
return true; return true;
} }

Some files were not shown because too many files have changed in this diff Show More