Move pending message views out of Dialog.

This commit is contained in:
levlam 2023-03-15 23:45:30 +03:00
parent 1b23cf0478
commit 365c639c22
2 changed files with 27 additions and 19 deletions

View File

@ -7041,37 +7041,43 @@ void MessagesManager::on_pending_message_views_timeout(DialogId dialog_id) {
return; return;
} }
auto it = pending_message_views_.find(dialog_id);
if (it == pending_message_views_.end()) {
return;
}
auto &pending_viewed_message_ids = it->second.message_ids_;
bool increment_view_counter = it->second.increment_view_counter_;
auto d = get_dialog(dialog_id); auto d = get_dialog(dialog_id);
CHECK(d != nullptr); CHECK(d != nullptr);
const size_t MAX_MESSAGE_VIEWS = 100; // server side limit const size_t MAX_MESSAGE_VIEWS = 100; // server side limit
vector<MessageId> message_ids; vector<MessageId> message_ids;
message_ids.reserve(min(d->pending_viewed_message_ids.size(), MAX_MESSAGE_VIEWS)); message_ids.reserve(min(pending_viewed_message_ids.size(), MAX_MESSAGE_VIEWS));
for (auto message_id : d->pending_viewed_message_ids) { for (auto message_id : pending_viewed_message_ids) {
auto *m = get_message(d, message_id); auto *m = get_message(d, message_id);
if (m == nullptr) { if (m == nullptr) {
continue; continue;
} }
if (m->has_get_message_views_query) { if (m->has_get_message_views_query) {
if (!d->increment_view_counter || m->need_view_counter_increment) { if (!increment_view_counter || m->need_view_counter_increment) {
continue; continue;
} }
m->need_view_counter_increment = true; m->need_view_counter_increment = true;
} else { } else {
m->has_get_message_views_query = true; m->has_get_message_views_query = true;
m->need_view_counter_increment = d->increment_view_counter; m->need_view_counter_increment = increment_view_counter;
} }
message_ids.push_back(message_id); message_ids.push_back(message_id);
if (message_ids.size() >= MAX_MESSAGE_VIEWS) { if (message_ids.size() >= MAX_MESSAGE_VIEWS) {
td_->create_handler<GetMessagesViewsQuery>()->send(dialog_id, std::move(message_ids), d->increment_view_counter); td_->create_handler<GetMessagesViewsQuery>()->send(dialog_id, std::move(message_ids), increment_view_counter);
message_ids.clear(); message_ids.clear();
} }
} }
if (!message_ids.empty()) { if (!message_ids.empty()) {
td_->create_handler<GetMessagesViewsQuery>()->send(dialog_id, std::move(message_ids), d->increment_view_counter); td_->create_handler<GetMessagesViewsQuery>()->send(dialog_id, std::move(message_ids), increment_view_counter);
} }
d->pending_viewed_message_ids.clear(); pending_message_views_.erase(it);
d->increment_view_counter = false;
} }
void MessagesManager::update_message_interaction_info(FullMessageId full_message_id, int32 view_count, void MessagesManager::update_message_interaction_info(FullMessageId full_message_id, int32 view_count,
@ -21432,7 +21438,7 @@ Status MessagesManager::view_messages(DialogId dialog_id, vector<MessageId> mess
auto *m = get_message_force(d, message_id, "view_messages 4"); auto *m = get_message_force(d, message_id, "view_messages 4");
if (m != nullptr) { if (m != nullptr) {
if (m->message_id.is_server() && m->view_count > 0 && need_update_view_count) { if (m->message_id.is_server() && m->view_count > 0 && need_update_view_count) {
d->pending_viewed_message_ids.insert(m->message_id); pending_message_views_[dialog_id].message_ids_.insert(m->message_id);
} }
if (!m->message_id.is_yet_unsent() && m->message_id > max_message_id) { if (!m->message_id.is_yet_unsent() && m->message_id > max_message_id) {
@ -21494,9 +21500,11 @@ Status MessagesManager::view_messages(DialogId dialog_id, vector<MessageId> mess
} }
} }
} }
if (!d->pending_viewed_message_ids.empty()) { if (pending_message_views_.count(dialog_id) != 0) {
pending_message_views_timeout_.add_timeout_in(dialog_id.get(), MAX_MESSAGE_VIEW_DELAY); pending_message_views_timeout_.add_timeout_in(dialog_id.get(), MAX_MESSAGE_VIEW_DELAY);
d->increment_view_counter |= is_dialog_history; if (is_dialog_history) {
pending_message_views_[dialog_id].increment_view_counter_ = true;
}
} }
if (!read_content_message_ids.empty()) { if (!read_content_message_ids.empty()) {
read_message_contents_on_server(dialog_id, std::move(read_content_message_ids), 0, Auto()); read_message_contents_on_server(dialog_id, std::move(read_content_message_ids), 0, Auto());
@ -21900,9 +21908,7 @@ void MessagesManager::close_dialog(Dialog *d) {
} }
} else { } else {
pending_message_views_timeout_.cancel_timeout(dialog_id.get()); pending_message_views_timeout_.cancel_timeout(dialog_id.get());
d->pending_viewed_message_ids.clear(); pending_message_views_.erase(dialog_id);
d->increment_view_counter = false;
pending_read_history_timeout_.cancel_timeout(dialog_id.get()); pending_read_history_timeout_.cancel_timeout(dialog_id.get());
} }
@ -40179,8 +40185,7 @@ void MessagesManager::update_forward_count(DialogId dialog_id, MessageId message
send_update_message_interaction_info(dialog_id, m); send_update_message_interaction_info(dialog_id, m);
on_message_changed(d, m, true, "update_forward_count"); on_message_changed(d, m, true, "update_forward_count");
} }
if (pending_message_views_[dialog_id].message_ids_.insert(m->message_id).second) {
if (d->pending_viewed_message_ids.insert(m->message_id).second) {
pending_message_views_timeout_.add_timeout_in(dialog_id.get(), 0.0); pending_message_views_timeout_.add_timeout_in(dialog_id.get(), 0.0);
} }
} }

View File

@ -1398,8 +1398,6 @@ class MessagesManager final : public Actor {
bool need_repair_unread_mention_count = false; bool need_repair_unread_mention_count = false;
bool is_translatable = false; bool is_translatable = false;
bool increment_view_counter = false;
bool is_update_new_chat_sent = false; bool is_update_new_chat_sent = false;
bool is_update_new_chat_being_sent = false; bool is_update_new_chat_being_sent = false;
bool has_unload_timeout = false; bool has_unload_timeout = false;
@ -1440,7 +1438,6 @@ class MessagesManager final : public Actor {
std::vector<std::pair<Promise<Unit>, std::function<bool(const Message *)>>> suffix_load_queries_; std::vector<std::pair<Promise<Unit>, std::function<bool(const Message *)>>> suffix_load_queries_;
FlatHashMap<MessageId, int64, MessageIdHash> pending_viewed_live_locations; // message_id -> task_id FlatHashMap<MessageId, int64, MessageIdHash> pending_viewed_live_locations; // message_id -> task_id
FlatHashSet<MessageId, MessageIdHash> pending_viewed_message_ids;
unique_ptr<Message> messages; unique_ptr<Message> messages;
unique_ptr<Message> scheduled_messages; unique_ptr<Message> scheduled_messages;
@ -3755,6 +3752,12 @@ class MessagesManager final : public Actor {
FlatHashMap<FullMessageId, std::set<MessageId>, FullMessageIdHash> FlatHashMap<FullMessageId, std::set<MessageId>, FullMessageIdHash>
yet_unsent_thread_message_ids_; // {dialog_id, top_thread_message_id} -> yet unsent message IDs yet_unsent_thread_message_ids_; // {dialog_id, top_thread_message_id} -> yet unsent message IDs
struct PendingMessageView {
FlatHashSet<MessageId, MessageIdHash> message_ids_;
bool increment_view_counter_ = false;
};
FlatHashMap<DialogId, PendingMessageView, DialogIdHash> pending_message_views_;
struct PendingReaction { struct PendingReaction {
int32 query_count = 0; int32 query_count = 0;
bool was_updated = false; bool was_updated = false;