Merge remote-tracking branch 'td/master'

This commit is contained in:
Andrea Cavalli 2021-12-05 15:03:03 +01:00
commit 32224f0b5a
4 changed files with 88 additions and 51 deletions

View File

@ -4113,7 +4113,8 @@ unique_ptr<MessageContent> get_message_content(Td *td, FormattedText message,
tl_object_ptr<telegram_api::MessageMedia> &&media, tl_object_ptr<telegram_api::MessageMedia> &&media,
DialogId owner_dialog_id, bool is_content_read, UserId via_bot_user_id, DialogId owner_dialog_id, bool is_content_read, UserId via_bot_user_id,
int32 *ttl, bool *disable_web_page_preview) { int32 *ttl, bool *disable_web_page_preview) {
if (!td->auth_manager_->was_authorized() && !G()->close_flag() && media != nullptr) { if (!td->auth_manager_->was_authorized() && !G()->close_flag() && media != nullptr &&
media->get_id() != telegram_api::messageMediaEmpty::ID) {
LOG(ERROR) << "Receive without authorization " << to_string(media); LOG(ERROR) << "Receive without authorization " << to_string(media);
media = nullptr; media = nullptr;
} }

View File

@ -9121,6 +9121,48 @@ void MessagesManager::on_get_messages(vector<tl_object_ptr<telegram_api::Message
promise.set_value(Unit()); promise.set_value(Unit());
} }
bool MessagesManager::delete_newer_server_messages_at_the_end(Dialog *d, MessageId max_message_id) {
vector<MessageId> message_ids;
find_newer_messages(d->messages.get(), max_message_id, message_ids);
if (message_ids.empty()) {
return false;
}
bool need_update_dialog_pos = false;
vector<int64> deleted_message_ids;
for (auto message_id : message_ids) {
CHECK(message_id > max_message_id);
if (message_id.is_server()) {
auto message =
delete_message(d, message_id, true, &need_update_dialog_pos, "delete_newer_server_messages_at_the_end 1");
CHECK(message != nullptr);
deleted_message_ids.push_back(message->message_id.get());
}
}
if (need_update_dialog_pos) {
send_update_chat_last_message(d, "delete_newer_server_messages_at_the_end 2");
}
if (!deleted_message_ids.empty()) {
send_update_delete_messages(d->dialog_id, std::move(deleted_message_ids), true, false);
message_ids.clear();
find_newer_messages(d->messages.get(), max_message_id, message_ids);
}
// connect all messages with ID > max_message_id
for (size_t i = 0; i + 1 < message_ids.size(); i++) {
auto m = get_message(d, message_ids[i]);
CHECK(m != nullptr);
if (!m->have_next) {
m->have_next = true;
attach_message_to_next(d, message_ids[i], "delete_newer_server_messages_at_the_end 3");
}
}
return !message_ids.empty();
}
void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_id, MessageId old_last_new_message_id, void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_id, MessageId old_last_new_message_id,
int32 offset, int32 limit, bool from_the_end, int32 offset, int32 limit, bool from_the_end,
vector<tl_object_ptr<telegram_api::Message>> &&messages, Promise<Unit> &&promise) { vector<tl_object_ptr<telegram_api::Message>> &&messages, Promise<Unit> &&promise) {
@ -9219,45 +9261,10 @@ void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_
if (from_the_end) { if (from_the_end) {
// delete all server messages with ID > last_received_message_id // delete all server messages with ID > last_received_message_id
// there were no new messages received after the getHistory request was sent, so they are already deleted message // there were no new messages received after the getHistory request was sent, so they are already deleted message
vector<MessageId> message_ids; if (delete_newer_server_messages_at_the_end(d, last_received_message_id)) {
find_newer_messages(d->messages.get(), last_received_message_id, message_ids);
if (!message_ids.empty()) {
bool need_update_dialog_pos = false;
vector<int64> deleted_message_ids;
for (auto message_id : message_ids) {
CHECK(message_id > last_received_message_id);
if (message_id.is_server()) {
auto message = delete_message(d, message_id, true, &need_update_dialog_pos, "on_get_gistory 1");
CHECK(message != nullptr);
deleted_message_ids.push_back(message->message_id.get());
}
}
if (need_update_dialog_pos) {
send_update_chat_last_message(d, "on_get_gistory 2");
}
if (!deleted_message_ids.empty()) {
send_update_delete_messages(dialog_id, std::move(deleted_message_ids), true, false);
message_ids.clear();
find_newer_messages(d->messages.get(), last_received_message_id, message_ids);
}
// connect all messages with ID > last_received_message_id
for (size_t i = 0; i + 1 < message_ids.size(); i++) {
auto m = get_message(d, message_ids[i]);
CHECK(m != nullptr);
if (!m->have_next) {
m->have_next = true;
attach_message_to_next(d, message_ids[i], "on_get_history 3");
}
}
if (!message_ids.empty()) {
have_next = true; have_next = true;
} }
} }
}
for (auto &message : messages) { for (auto &message : messages) {
if (!have_next && from_the_end && get_message_id(message, false) < d->last_message_id) { if (!have_next && from_the_end && get_message_id(message, false) < d->last_message_id) {
@ -9299,6 +9306,11 @@ void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_
} }
} }
if (from_the_end && last_added_message_id.is_valid() && last_added_message_id != last_received_message_id) {
CHECK(last_added_message_id < last_received_message_id);
delete_newer_server_messages_at_the_end(d, last_added_message_id);
}
if (have_full_history) { if (have_full_history) {
d->have_full_history = true; d->have_full_history = true;
on_dialog_updated(dialog_id, "set have_full_history 2"); on_dialog_updated(dialog_id, "set have_full_history 2");
@ -9413,7 +9425,6 @@ void MessagesManager::on_get_history(DialogId dialog_id, MessageId from_message_
<< prev_have_full_history << " " << d->debug_last_new_message_id << " " << d->debug_first_database_message_id << prev_have_full_history << " " << d->debug_last_new_message_id << " " << d->debug_first_database_message_id
<< " " << d->debug_last_database_message_id << " " << from_message_id << " " << offset << " " << limit << " " << " " << d->debug_last_database_message_id << " " << from_message_id << " " << offset << " " << limit << " "
<< messages.size() << " " << last_received_message_id << " " << d->debug_set_dialog_last_database_message_id; << messages.size() << " " << last_received_message_id << " " << d->debug_set_dialog_last_database_message_id;
CHECK(d->last_database_message_id.is_valid()); CHECK(d->last_database_message_id.is_valid());
for (auto &first_message_id : d->first_database_message_id_by_index) { for (auto &first_message_id : d->first_database_message_id_by_index) {

View File

@ -2102,6 +2102,8 @@ class MessagesManager final : public Actor {
void on_update_dialog_online_member_count_timeout(DialogId dialog_id); void on_update_dialog_online_member_count_timeout(DialogId dialog_id);
bool delete_newer_server_messages_at_the_end(Dialog *d, MessageId max_message_id);
template <class T, class It> template <class T, class It>
vector<MessageId> get_message_history_slice(const T &begin, It it, const T &end, MessageId from_message_id, vector<MessageId> get_message_history_slice(const T &begin, It it, const T &end, MessageId from_message_id,
int32 offset, int32 limit); int32 offset, int32 limit);

View File

@ -1637,7 +1637,7 @@ class CliClient final : public Actor {
string args; string args;
std::tie(op, args) = split(cmd); std::tie(op, args) = split(cmd);
const int32 OP_BLOCK_COUNT = 5; const int32 OP_BLOCK_COUNT = 10;
int32 op_not_found_count = 0; int32 op_not_found_count = 0;
if (op == "gas") { if (op == "gas") {
@ -2212,6 +2212,9 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::setCustomLanguagePackString>(language_code, std::move(str))); send_request(td_api::make_object<td_api::setCustomLanguagePackString>(language_code, std::move(str)));
} else if (op == "dlp") { } else if (op == "dlp") {
send_request(td_api::make_object<td_api::deleteLanguagePack>(args)); send_request(td_api::make_object<td_api::deleteLanguagePack>(args));
} else if (op == "on" || op == "off") {
send_request(td_api::make_object<td_api::setOption>("online",
td_api::make_object<td_api::optionValueBoolean>(op == "on")));
} else if (op == "go") { } else if (op == "go") {
send_request(td_api::make_object<td_api::getOption>(args)); send_request(td_api::make_object<td_api::getOption>(args));
} else if (op == "sob") { } else if (op == "sob") {
@ -2285,7 +2288,11 @@ class CliClient final : public Actor {
send_get_background_url(get_freeform_gradient_background({0xFEDCBA, 0x222222})); send_get_background_url(get_freeform_gradient_background({0xFEDCBA, 0x222222}));
send_get_background_url(get_freeform_gradient_background({0xFEDCBA, 0x111111, 0x222222})); send_get_background_url(get_freeform_gradient_background({0xFEDCBA, 0x111111, 0x222222}));
send_get_background_url(get_freeform_gradient_background({0xABCDEF, 0xFEDCBA, 0x111111, 0x222222})); send_get_background_url(get_freeform_gradient_background({0xABCDEF, 0xFEDCBA, 0x111111, 0x222222}));
} else if (op == "sbg") { } else {
op_not_found_count++;
}
if (op == "sbg") {
send_request(td_api::make_object<td_api::searchBackground>(args)); send_request(td_api::make_object<td_api::searchBackground>(args));
} else if (op == "sbgd") { } else if (op == "sbgd") {
send_request(td_api::make_object<td_api::setBackground>(nullptr, nullptr, as_bool(args))); send_request(td_api::make_object<td_api::setBackground>(nullptr, nullptr, as_bool(args)));
@ -2545,17 +2552,17 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::getAnimatedEmoji>(args)); send_request(td_api::make_object<td_api::getAnimatedEmoji>(args));
} else if (op == "gesu") { } else if (op == "gesu") {
send_request(td_api::make_object<td_api::getEmojiSuggestionsUrl>(args)); send_request(td_api::make_object<td_api::getEmojiSuggestionsUrl>(args));
} else { } else if (op == "gsan") {
op_not_found_count++;
}
if (op == "gsan") {
send_request(td_api::make_object<td_api::getSavedAnimations>()); send_request(td_api::make_object<td_api::getSavedAnimations>());
} else if (op == "asan") { } else if (op == "asan") {
send_request(td_api::make_object<td_api::addSavedAnimation>(as_input_file_id(args))); send_request(td_api::make_object<td_api::addSavedAnimation>(as_input_file_id(args)));
} else if (op == "rsan") { } else if (op == "rsan") {
send_request(td_api::make_object<td_api::removeSavedAnimation>(as_input_file_id(args))); send_request(td_api::make_object<td_api::removeSavedAnimation>(as_input_file_id(args)));
} else if (op == "guf") { } else {
op_not_found_count++;
}
if (op == "guf") {
send_request(td_api::make_object<td_api::getUserFullInfo>(as_user_id(args))); send_request(td_api::make_object<td_api::getUserFullInfo>(as_user_id(args)));
} else if (op == "gbg") { } else if (op == "gbg") {
send_request(td_api::make_object<td_api::getBasicGroup>(as_basic_group_id(args))); send_request(td_api::make_object<td_api::getBasicGroup>(as_basic_group_id(args)));
@ -2773,7 +2780,11 @@ class CliClient final : public Actor {
send_request(td_api::make_object<td_api::sendChatScreenshotTakenNotification>(as_chat_id(args))); send_request(td_api::make_object<td_api::sendChatScreenshotTakenNotification>(as_chat_id(args)));
} else if (op == "closeSC" || op == "cancelSC") { } else if (op == "closeSC" || op == "cancelSC") {
send_request(td_api::make_object<td_api::closeSecretChat>(as_secret_chat_id(args))); send_request(td_api::make_object<td_api::closeSecretChat>(as_secret_chat_id(args)));
} else if (op == "cc" || op == "CreateCall") { } else {
op_not_found_count++;
}
if (op == "cc" || op == "CreateCall") {
send_request(td_api::make_object<td_api::createCall>( send_request(td_api::make_object<td_api::createCall>(
as_user_id(args), td_api::make_object<td_api::callProtocol>(true, true, 65, 65, vector<string>{"2.6", "3.0"}), as_user_id(args), td_api::make_object<td_api::callProtocol>(true, true, 65, 65, vector<string>{"2.6", "3.0"}),
rand_bool())); rand_bool()));
@ -3425,7 +3436,11 @@ 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::getCallbackQueryAnswer>( send_request(td_api::make_object<td_api::getCallbackQueryAnswer>(
as_chat_id(chat_id), as_message_id(message_id), td_api::make_object<td_api::callbackQueryPayloadGame>(""))); as_chat_id(chat_id), as_message_id(message_id), td_api::make_object<td_api::callbackQueryPayloadGame>("")));
} else if (op == "san") { } else {
op_not_found_count++;
}
if (op == "san") {
string chat_id; string chat_id;
string animation_path; string animation_path;
int32 width; int32 width;
@ -3721,7 +3736,11 @@ class CliClient final : public Actor {
send_message(chat_id, send_message(chat_id,
td_api::make_object<td_api::inputMessageVenue>(td_api::make_object<td_api::venue>( td_api::make_object<td_api::inputMessageVenue>(td_api::make_object<td_api::venue>(
as_location(latitude, longitude, accuracy), title, address, provider, venue_id, venue_type))); as_location(latitude, longitude, accuracy), title, address, provider, venue_id, venue_type)));
} else if (op == "test") { } else {
op_not_found_count++;
}
if (op == "test") {
send_request(td_api::make_object<td_api::testNetwork>()); send_request(td_api::make_object<td_api::testNetwork>());
} else if (op == "alarm") { } else if (op == "alarm") {
send_request(td_api::make_object<td_api::setAlarm>(to_double(args))); send_request(td_api::make_object<td_api::setAlarm>(to_double(args)));
@ -4261,7 +4280,11 @@ class CliClient final : public Actor {
bool is_dark; bool is_dark;
get_args(args, chat_id, is_dark); get_args(args, chat_id, is_dark);
send_request(td_api::make_object<td_api::getChatStatistics>(as_chat_id(chat_id), is_dark)); send_request(td_api::make_object<td_api::getChatStatistics>(as_chat_id(chat_id), is_dark));
} else if (op == "sgs") { } else {
op_not_found_count++;
}
if (op == "sgs") {
string chat_id; string chat_id;
string message_id; string message_id;
string user_id; string user_id;