Ensure that bots don't load chat list.

GitOrigin-RevId: a516afafacb8ac290c91f5d72681793f737c5dad
This commit is contained in:
levlam 2020-04-29 17:13:17 +03:00
parent 1f58155cf1
commit c0adfe735d

View File

@ -13072,6 +13072,8 @@ bool MessagesManager::load_dialog(DialogId dialog_id, int left_tries, Promise<Un
vector<DialogId> MessagesManager::get_dialogs(FolderId folder_id, DialogDate offset, int32 limit, bool force, vector<DialogId> MessagesManager::get_dialogs(FolderId folder_id, DialogDate offset, int32 limit, bool force,
Promise<Unit> &&promise) { Promise<Unit> &&promise) {
CHECK(!td_->auth_manager_->is_bot());
auto &list = get_dialog_list(folder_id); auto &list = get_dialog_list(folder_id);
LOG(INFO) << "Get chats in " << folder_id << " with offset " << offset << " and limit " << limit LOG(INFO) << "Get chats in " << folder_id << " with offset " << offset << " and limit " << limit
<< ". Know about order of " << list.ordered_dialogs_.size() << ". Know about order of " << list.ordered_dialogs_.size()
@ -13119,6 +13121,7 @@ vector<DialogId> MessagesManager::get_dialogs(FolderId folder_id, DialogDate off
} }
void MessagesManager::load_dialog_list(FolderId folder_id, int32 limit, bool only_local, Promise<Unit> &&promise) { void MessagesManager::load_dialog_list(FolderId folder_id, int32 limit, bool only_local, Promise<Unit> &&promise) {
CHECK(!td_->auth_manager_->is_bot());
auto &list = get_dialog_list(folder_id); auto &list = get_dialog_list(folder_id);
if (list.last_dialog_date_ == MAX_DIALOG_DATE) { if (list.last_dialog_date_ == MAX_DIALOG_DATE) {
return promise.set_value(Unit()); return promise.set_value(Unit());
@ -13165,6 +13168,7 @@ void MessagesManager::load_dialog_list(FolderId folder_id, int32 limit, bool onl
} }
void MessagesManager::load_dialog_list_from_database(FolderId folder_id, int32 limit, Promise<Unit> &&promise) { void MessagesManager::load_dialog_list_from_database(FolderId folder_id, int32 limit, Promise<Unit> &&promise) {
CHECK(!td_->auth_manager_->is_bot());
auto &list = get_dialog_list(folder_id); auto &list = get_dialog_list(folder_id);
LOG(INFO) << "Load " << limit << " chats in " << folder_id << " from database from " LOG(INFO) << "Load " << limit << " chats in " << folder_id << " from database from "
<< list.last_loaded_database_dialog_date_ << list.last_loaded_database_dialog_date_
@ -13184,6 +13188,7 @@ void MessagesManager::load_dialog_list_from_database(FolderId folder_id, int32 l
void MessagesManager::on_get_dialogs_from_database(FolderId folder_id, int32 limit, DialogDbGetDialogsResult &&dialogs, void MessagesManager::on_get_dialogs_from_database(FolderId folder_id, int32 limit, DialogDbGetDialogsResult &&dialogs,
Promise<Unit> &&promise) { Promise<Unit> &&promise) {
CHECK(!td_->auth_manager_->is_bot());
auto &list = get_dialog_list(folder_id); auto &list = get_dialog_list(folder_id);
LOG(INFO) << "Receive " << dialogs.dialogs.size() << " from expected " << limit << " chats in " << folder_id LOG(INFO) << "Receive " << dialogs.dialogs.size() << " from expected " << limit << " chats in " << folder_id
<< " in from database with next order " << dialogs.next_order << " and next " << dialogs.next_dialog_id; << " in from database with next order " << dialogs.next_order << " and next " << dialogs.next_dialog_id;
@ -13247,6 +13252,7 @@ void MessagesManager::preload_dialog_list(FolderId folder_id) {
LOG(INFO) << "Skip chat list preload because of closing"; LOG(INFO) << "Skip chat list preload because of closing";
return; return;
} }
CHECK(!td_->auth_manager_->is_bot());
auto &list = get_dialog_list(folder_id); auto &list = get_dialog_list(folder_id);
CHECK(G()->parameters().use_message_db); CHECK(G()->parameters().use_message_db);
@ -13351,6 +13357,7 @@ void MessagesManager::send_search_public_dialogs_query(const string &query, Prom
std::pair<size_t, vector<DialogId>> MessagesManager::search_dialogs(const string &query, int32 limit, std::pair<size_t, vector<DialogId>> MessagesManager::search_dialogs(const string &query, int32 limit,
Promise<Unit> &&promise) { Promise<Unit> &&promise) {
LOG(INFO) << "Search chats with query \"" << query << "\" and limit " << limit; LOG(INFO) << "Search chats with query \"" << query << "\" and limit " << limit;
CHECK(!td_->auth_manager_->is_bot());
if (limit < 0) { if (limit < 0) {
promise.set_error(Status::Error(400, "Limit must be non-negative")); promise.set_error(Status::Error(400, "Limit must be non-negative"));
@ -15535,6 +15542,7 @@ int32 MessagesManager::get_scope_mute_until(DialogId dialog_id) const {
vector<DialogId> MessagesManager::get_dialog_notification_settings_exceptions(NotificationSettingsScope scope, vector<DialogId> MessagesManager::get_dialog_notification_settings_exceptions(NotificationSettingsScope scope,
bool filter_scope, bool compare_sound, bool filter_scope, bool compare_sound,
bool force, Promise<Unit> &&promise) { bool force, Promise<Unit> &&promise) {
CHECK(!td_->auth_manager_->is_bot());
bool have_all_dialogs = true; bool have_all_dialogs = true;
bool have_main_list = false; bool have_main_list = false;
bool have_archive_list = false; bool have_archive_list = false;
@ -23638,6 +23646,11 @@ bool MessagesManager::update_dialog_draft_message(Dialog *d, unique_ptr<DraftMes
} }
void MessagesManager::on_update_dialog_is_pinned(FolderId folder_id, DialogId dialog_id, bool is_pinned) { void MessagesManager::on_update_dialog_is_pinned(FolderId folder_id, DialogId dialog_id, bool is_pinned) {
if (td_->auth_manager_->is_bot()) {
// just in case
return;
}
if (!dialog_id.is_valid()) { if (!dialog_id.is_valid()) {
LOG(ERROR) << "Receive pin of invalid " << dialog_id; LOG(ERROR) << "Receive pin of invalid " << dialog_id;
return; return;
@ -23662,6 +23675,11 @@ void MessagesManager::on_update_dialog_is_pinned(FolderId folder_id, DialogId di
} }
void MessagesManager::on_update_pinned_dialogs(FolderId folder_id) { void MessagesManager::on_update_pinned_dialogs(FolderId folder_id) {
if (td_->auth_manager_->is_bot()) {
// just in case
return;
}
// TODO logevent + delete_logevent_promise // TODO logevent + delete_logevent_promise
auto query_promise = PromiseCreator::lambda([actor_id = actor_id(this), folder_id](Unit /* ignore result */) { auto query_promise = PromiseCreator::lambda([actor_id = actor_id(this), folder_id](Unit /* ignore result */) {
send_closure(actor_id, &MessagesManager::reload_pinned_dialogs, folder_id, Promise<Unit>()); send_closure(actor_id, &MessagesManager::reload_pinned_dialogs, folder_id, Promise<Unit>());
@ -30081,6 +30099,7 @@ void MessagesManager::save_recently_found_dialogs() {
} }
bool MessagesManager::load_recently_found_dialogs(Promise<Unit> &promise) { bool MessagesManager::load_recently_found_dialogs(Promise<Unit> &promise) {
CHECK(!td_->auth_manager_->is_bot());
if (recently_found_dialogs_loaded_ >= 2) { if (recently_found_dialogs_loaded_ >= 2) {
return true; return true;
} }
@ -30477,6 +30496,10 @@ void MessagesManager::on_get_sponsored_dialog(tl_object_ptr<telegram_api::Peer>
} }
void MessagesManager::add_sponsored_dialog(const Dialog *d, DialogSource source) { void MessagesManager::add_sponsored_dialog(const Dialog *d, DialogSource source) {
if (td_->auth_manager_->is_bot()) {
return;
}
CHECK(!sponsored_dialog_id_.is_valid()); CHECK(!sponsored_dialog_id_.is_valid());
sponsored_dialog_id_ = d->dialog_id; sponsored_dialog_id_ = d->dialog_id;
sponsored_dialog_source_ = std::move(source); sponsored_dialog_source_ = std::move(source);
@ -30511,6 +30534,10 @@ void MessagesManager::save_sponsored_dialog() {
} }
void MessagesManager::set_sponsored_dialog(DialogId dialog_id, DialogSource source) { void MessagesManager::set_sponsored_dialog(DialogId dialog_id, DialogSource source) {
if (td_->auth_manager_->is_bot()) {
return;
}
if (sponsored_dialog_id_ == dialog_id) { if (sponsored_dialog_id_ == dialog_id) {
if (sponsored_dialog_source_ != source) { if (sponsored_dialog_source_ != source) {
CHECK(sponsored_dialog_id_.is_valid()); CHECK(sponsored_dialog_id_.is_valid());