Allow to find messages in a thread in a different dialog.
GitOrigin-RevId: 1e874b2bd46408eda12a6d2b8ffe59000c4fe5a5
This commit is contained in:
parent
7cde6f0adb
commit
efb100cc9d
@ -9186,6 +9186,8 @@ void MessagesManager::on_get_dialog_messages_search_result(DialogId dialog_id, c
|
|||||||
// anyway pretend that there is no more messages
|
// anyway pretend that there is no more messages
|
||||||
first_added_message_id = MessageId::min();
|
first_added_message_id = MessageId::min();
|
||||||
}
|
}
|
||||||
|
bool can_be_in_different_dialog = top_thread_message_id.is_valid() && is_broadcast_channel(dialog_id);
|
||||||
|
DialogId real_dialog_id;
|
||||||
Dialog *d = get_dialog(dialog_id);
|
Dialog *d = get_dialog(dialog_id);
|
||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
for (auto &message : messages) {
|
for (auto &message : messages) {
|
||||||
@ -9197,13 +9199,26 @@ void MessagesManager::on_get_dialog_messages_search_result(DialogId dialog_id, c
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (new_full_message_id.get_dialog_id() != dialog_id) {
|
if (new_full_message_id.get_dialog_id() != dialog_id) {
|
||||||
LOG(ERROR) << "Receive " << new_full_message_id << " instead of a message in " << dialog_id;
|
if (!can_be_in_different_dialog) {
|
||||||
total_count--;
|
LOG(ERROR) << "Receive " << new_full_message_id << " instead of a message in " << dialog_id;
|
||||||
continue;
|
total_count--;
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
if (!real_dialog_id.is_valid()) {
|
||||||
|
real_dialog_id = new_full_message_id.get_dialog_id();
|
||||||
|
found_dialog_messages_dialog_id_[random_id] = real_dialog_id;
|
||||||
|
} else if (new_full_message_id.get_dialog_id() != real_dialog_id) {
|
||||||
|
LOG(ERROR) << "Receive " << new_full_message_id << " instead of a message in " << real_dialog_id << " or "
|
||||||
|
<< dialog_id;
|
||||||
|
total_count--;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
auto message_id = new_full_message_id.get_message_id();
|
auto message_id = new_full_message_id.get_message_id();
|
||||||
if (filter == MessageSearchFilter::UnreadMention && message_id <= d->last_read_all_mentions_message_id) {
|
if (filter == MessageSearchFilter::UnreadMention && message_id <= d->last_read_all_mentions_message_id &&
|
||||||
|
!real_dialog_id.is_valid()) {
|
||||||
total_count--;
|
total_count--;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -19691,6 +19706,7 @@ std::pair<int32, vector<MessageId>> MessagesManager::search_dialog_messages(
|
|||||||
// request has already been sent before
|
// request has already been sent before
|
||||||
auto it = found_dialog_messages_.find(random_id);
|
auto it = found_dialog_messages_.find(random_id);
|
||||||
if (it != found_dialog_messages_.end()) {
|
if (it != found_dialog_messages_.end()) {
|
||||||
|
CHECK(found_dialog_messages_dialog_id_.count(random_id) == 0);
|
||||||
auto result = std::move(it->second);
|
auto result = std::move(it->second);
|
||||||
found_dialog_messages_.erase(it);
|
found_dialog_messages_.erase(it);
|
||||||
promise.set_value(Unit());
|
promise.set_value(Unit());
|
||||||
@ -20313,7 +20329,7 @@ void MessagesManager::on_search_dialog_messages_db_result(int64 random_id, Dialo
|
|||||||
return promise.set_error(Status::Error(500, "Request aborted"));
|
return promise.set_error(Status::Error(500, "Request aborted"));
|
||||||
}
|
}
|
||||||
if (r_messages.is_error()) {
|
if (r_messages.is_error()) {
|
||||||
LOG(ERROR) << r_messages.error();
|
LOG(ERROR) << "Failed to get messages from the database: " << r_messages.error();
|
||||||
if (first_db_message_id != MessageId::min() && dialog_id.get_type() != DialogType::SecretChat &&
|
if (first_db_message_id != MessageId::min() && dialog_id.get_type() != DialogType::SecretChat &&
|
||||||
filter != MessageSearchFilter::FailedToSend) {
|
filter != MessageSearchFilter::FailedToSend) {
|
||||||
found_dialog_messages_.erase(random_id);
|
found_dialog_messages_.erase(random_id);
|
||||||
@ -20749,6 +20765,7 @@ int32 MessagesManager::get_dialog_message_count(DialogId dialog_id, MessageSearc
|
|||||||
CHECK(it != found_dialog_messages_.end());
|
CHECK(it != found_dialog_messages_.end());
|
||||||
auto result = std::move(it->second);
|
auto result = std::move(it->second);
|
||||||
found_dialog_messages_.erase(it);
|
found_dialog_messages_.erase(it);
|
||||||
|
CHECK(found_dialog_messages_dialog_id_.count(random_id) == 0);
|
||||||
promise.set_value(Unit());
|
promise.set_value(Unit());
|
||||||
return result.first;
|
return result.first;
|
||||||
}
|
}
|
||||||
|
@ -3056,7 +3056,8 @@ class MessagesManager : public Actor {
|
|||||||
std::unordered_map<int64, FullMessageId> get_dialog_message_by_date_results_;
|
std::unordered_map<int64, FullMessageId> get_dialog_message_by_date_results_;
|
||||||
|
|
||||||
std::unordered_map<int64, std::pair<int32, vector<MessageId>>>
|
std::unordered_map<int64, std::pair<int32, vector<MessageId>>>
|
||||||
found_dialog_messages_; // random_id -> [total_count, [message_id]...]
|
found_dialog_messages_; // random_id -> [total_count, [message_id]...]
|
||||||
|
std::unordered_map<int64, DialogId> found_dialog_messages_dialog_id_; // random_id -> dialog_id
|
||||||
std::unordered_map<int64, std::pair<int32, vector<FullMessageId>>>
|
std::unordered_map<int64, std::pair<int32, vector<FullMessageId>>>
|
||||||
found_messages_; // random_id -> [total_count, [full_message_id]...]
|
found_messages_; // random_id -> [total_count, [full_message_id]...]
|
||||||
std::unordered_map<int64, std::pair<int32, vector<FullMessageId>>>
|
std::unordered_map<int64, std::pair<int32, vector<FullMessageId>>>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user