Improve names of NotificationGroupInfo fields.
This commit is contained in:
parent
6c4545fb3f
commit
05b1bec6a9
@ -8094,7 +8094,7 @@ bool MessagesManager::update_dialog_notification_settings(DialogId dialog_id,
|
|||||||
remove_all_dialog_notifications(d, false, "update_dialog_notification_settings 2");
|
remove_all_dialog_notifications(d, false, "update_dialog_notification_settings 2");
|
||||||
}
|
}
|
||||||
if (is_dialog_pinned_message_notifications_disabled(d) && d->notification_info != nullptr &&
|
if (is_dialog_pinned_message_notifications_disabled(d) && d->notification_info != nullptr &&
|
||||||
d->notification_info->mention_notification_group_.group_id.is_valid() &&
|
d->notification_info->mention_notification_group_.group_id_.is_valid() &&
|
||||||
d->notification_info->pinned_message_notification_message_id_.is_valid()) {
|
d->notification_info->pinned_message_notification_message_id_.is_valid()) {
|
||||||
remove_dialog_pinned_message_notification(d, "update_dialog_notification_settings 3");
|
remove_dialog_pinned_message_notification(d, "update_dialog_notification_settings 3");
|
||||||
}
|
}
|
||||||
@ -11970,12 +11970,14 @@ void MessagesManager::delete_all_dialog_messages(Dialog *d, bool remove_from_dia
|
|||||||
delete_all_dialog_messages_from_database(d, MessageId::max(), "delete_all_dialog_messages 3");
|
delete_all_dialog_messages_from_database(d, MessageId::max(), "delete_all_dialog_messages 3");
|
||||||
|
|
||||||
if (d->notification_info != nullptr) {
|
if (d->notification_info != nullptr) {
|
||||||
d->notification_info->message_notification_group_.max_removed_notification_id =
|
d->notification_info->message_notification_group_.max_removed_notification_id_ =
|
||||||
NotificationId(); // it is not needed anymore
|
NotificationId(); // it is not needed anymore
|
||||||
d->notification_info->message_notification_group_.max_removed_message_id = MessageId(); // it is not needed anymore
|
d->notification_info->message_notification_group_.max_removed_message_id_ =
|
||||||
d->notification_info->mention_notification_group_.max_removed_notification_id =
|
MessageId(); // it is not needed anymore
|
||||||
NotificationId(); // it is not needed anymore
|
d->notification_info->mention_notification_group_.max_removed_notification_id_ =
|
||||||
d->notification_info->mention_notification_group_.max_removed_message_id = MessageId(); // it is not needed anymore
|
NotificationId(); // it is not needed anymore
|
||||||
|
d->notification_info->mention_notification_group_.max_removed_message_id_ =
|
||||||
|
MessageId(); // it is not needed anymore
|
||||||
d->notification_info->notification_id_to_message_id_.clear();
|
d->notification_info->notification_id_to_message_id_.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -12898,7 +12900,7 @@ void MessagesManager::set_dialog_last_read_inbox_message_id(Dialog *d, MessageId
|
|||||||
<< " after updating last read inbox message to " << message_id
|
<< " after updating last read inbox message to " << message_id
|
||||||
<< " and unread message count to " << server_unread_count << " + " << local_unread_count
|
<< " and unread message count to " << server_unread_count << " + " << local_unread_count
|
||||||
<< " from " << source;
|
<< " from " << source;
|
||||||
if (d->notification_info != nullptr && d->notification_info->message_notification_group_.group_id.is_valid()) {
|
if (d->notification_info != nullptr && d->notification_info->message_notification_group_.group_id_.is_valid()) {
|
||||||
auto total_count = get_dialog_pending_notification_count(d, false);
|
auto total_count = get_dialog_pending_notification_count(d, false);
|
||||||
if (total_count == 0) {
|
if (total_count == 0) {
|
||||||
set_dialog_last_notification(d->dialog_id, d->notification_info->message_notification_group_, 0,
|
set_dialog_last_notification(d->dialog_id, d->notification_info->message_notification_group_, 0,
|
||||||
@ -12921,12 +12923,12 @@ void MessagesManager::set_dialog_last_read_inbox_message_id(Dialog *d, MessageId
|
|||||||
total_count = 0;
|
total_count = 0;
|
||||||
}
|
}
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification_group,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification_group,
|
||||||
d->notification_info->message_notification_group_.group_id, NotificationId(),
|
d->notification_info->message_notification_group_.group_id_, NotificationId(),
|
||||||
d->last_read_inbox_message_id, total_count, Slice(source) == Slice("view_messages"),
|
d->last_read_inbox_message_id, total_count, Slice(source) == Slice("view_messages"),
|
||||||
Promise<Unit>());
|
Promise<Unit>());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (d->notification_info != nullptr && d->notification_info->mention_notification_group_.group_id.is_valid() &&
|
if (d->notification_info != nullptr && d->notification_info->mention_notification_group_.group_id_.is_valid() &&
|
||||||
d->notification_info->pinned_message_notification_message_id_.is_valid() &&
|
d->notification_info->pinned_message_notification_message_id_.is_valid() &&
|
||||||
d->notification_info->pinned_message_notification_message_id_ <= d->last_read_inbox_message_id) {
|
d->notification_info->pinned_message_notification_message_id_ <= d->last_read_inbox_message_id) {
|
||||||
// remove pinned message notification when it is read
|
// remove pinned message notification when it is read
|
||||||
@ -14028,13 +14030,13 @@ void MessagesManager::on_update_secret_chat_state(SecretChatId secret_chat_id, S
|
|||||||
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
||||||
remove_new_secret_chat_notification(d, true);
|
remove_new_secret_chat_notification(d, true);
|
||||||
}
|
}
|
||||||
if (d->notification_info->message_notification_group_.group_id.is_valid() &&
|
if (d->notification_info->message_notification_group_.group_id_.is_valid() &&
|
||||||
get_dialog_pending_notification_count(d, false) == 0 &&
|
get_dialog_pending_notification_count(d, false) == 0 &&
|
||||||
!d->notification_info->message_notification_group_.last_notification_id.is_valid()) {
|
!d->notification_info->message_notification_group_.last_notification_id_.is_valid()) {
|
||||||
d->notification_info->message_notification_group_.try_reuse();
|
d->notification_info->message_notification_group_.try_reuse();
|
||||||
on_dialog_updated(d->dialog_id, "on_update_secret_chat_state");
|
on_dialog_updated(d->dialog_id, "on_update_secret_chat_state");
|
||||||
}
|
}
|
||||||
CHECK(!d->notification_info->mention_notification_group_.group_id
|
CHECK(!d->notification_info->mention_notification_group_.group_id_
|
||||||
.is_valid()); // there can't be unread mentions in secret chats
|
.is_valid()); // there can't be unread mentions in secret chats
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -15323,7 +15325,7 @@ void MessagesManager::set_dialog_pinned_message_notification(Dialog *d, MessageI
|
|||||||
on_message_changed(d, m, false, source);
|
on_message_changed(d, m, false, source);
|
||||||
} else {
|
} else {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
||||||
notification_info->mention_notification_group_.group_id, old_message_id, false, source);
|
notification_info->mention_notification_group_.group_id_, old_message_id, false, source);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
notification_info->pinned_message_notification_message_id_ = message_id;
|
notification_info->pinned_message_notification_message_id_ = message_id;
|
||||||
@ -15339,7 +15341,7 @@ void MessagesManager::remove_scope_pinned_message_notifications(NotificationSett
|
|||||||
dialogs_.foreach([&](const DialogId &dialog_id, unique_ptr<Dialog> &dialog) {
|
dialogs_.foreach([&](const DialogId &dialog_id, unique_ptr<Dialog> &dialog) {
|
||||||
Dialog *d = dialog.get();
|
Dialog *d = dialog.get();
|
||||||
if (d->notification_settings.use_default_disable_pinned_message_notifications && d->notification_info != nullptr &&
|
if (d->notification_settings.use_default_disable_pinned_message_notifications && d->notification_info != nullptr &&
|
||||||
d->notification_info->mention_notification_group_.group_id.is_valid() &&
|
d->notification_info->mention_notification_group_.group_id_.is_valid() &&
|
||||||
d->notification_info->pinned_message_notification_message_id_.is_valid() &&
|
d->notification_info->pinned_message_notification_message_id_.is_valid() &&
|
||||||
get_dialog_notification_setting_scope(dialog_id) == scope) {
|
get_dialog_notification_setting_scope(dialog_id) == scope) {
|
||||||
remove_dialog_pinned_message_notification(d, "remove_scope_pinned_message_notifications");
|
remove_dialog_pinned_message_notification(d, "remove_scope_pinned_message_notifications");
|
||||||
@ -15367,7 +15369,7 @@ void MessagesManager::remove_dialog_mention_notifications(Dialog *d) {
|
|||||||
if (d->notification_info == nullptr) {
|
if (d->notification_info == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto notification_group_id = d->notification_info->mention_notification_group_.group_id;
|
auto notification_group_id = d->notification_info->mention_notification_group_.group_id_;
|
||||||
if (!notification_group_id.is_valid()) {
|
if (!notification_group_id.is_valid()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -15418,13 +15420,13 @@ void MessagesManager::remove_dialog_mention_notifications(Dialog *d) {
|
|||||||
bool MessagesManager::set_dialog_last_notification(DialogId dialog_id, NotificationGroupInfo &group_info,
|
bool MessagesManager::set_dialog_last_notification(DialogId dialog_id, NotificationGroupInfo &group_info,
|
||||||
int32 last_notification_date, NotificationId last_notification_id,
|
int32 last_notification_date, NotificationId last_notification_id,
|
||||||
const char *source) {
|
const char *source) {
|
||||||
if (group_info.last_notification_date != last_notification_date ||
|
if (group_info.last_notification_date_ != last_notification_date ||
|
||||||
group_info.last_notification_id != last_notification_id) {
|
group_info.last_notification_id_ != last_notification_id) {
|
||||||
VLOG(notifications) << "Set " << group_info.group_id << '/' << dialog_id << " last notification to "
|
VLOG(notifications) << "Set " << group_info.group_id_ << '/' << dialog_id << " last notification to "
|
||||||
<< last_notification_id << " sent at " << last_notification_date << " from " << source;
|
<< last_notification_id << " sent at " << last_notification_date << " from " << source;
|
||||||
group_info.last_notification_date = last_notification_date;
|
group_info.last_notification_date_ = last_notification_date;
|
||||||
group_info.last_notification_id = last_notification_id;
|
group_info.last_notification_id_ = last_notification_id;
|
||||||
group_info.is_changed = true;
|
group_info.is_changed_ = true;
|
||||||
on_dialog_updated(dialog_id, "set_dialog_last_notification");
|
on_dialog_updated(dialog_id, "set_dialog_last_notification");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -16105,14 +16107,14 @@ void MessagesManager::remove_message_notification_id(Dialog *d, Message *m, bool
|
|||||||
|
|
||||||
auto from_mentions = is_from_mention_notification_group(m);
|
auto from_mentions = is_from_mention_notification_group(m);
|
||||||
auto &group_info = get_notification_group_info(d, m);
|
auto &group_info = get_notification_group_info(d, m);
|
||||||
if (!group_info.group_id.is_valid()) {
|
if (!group_info.group_id_.is_valid()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool had_active_notification = is_message_notification_active(d, m);
|
bool had_active_notification = is_message_notification_active(d, m);
|
||||||
|
|
||||||
auto notification_id = m->notification_id;
|
auto notification_id = m->notification_id;
|
||||||
VLOG(notifications) << "Remove " << notification_id << " from " << m->message_id << " in " << group_info.group_id
|
VLOG(notifications) << "Remove " << notification_id << " from " << m->message_id << " in " << group_info.group_id_
|
||||||
<< '/' << d->dialog_id << " from database, was_active = " << had_active_notification
|
<< '/' << d->dialog_id << " from database, was_active = " << had_active_notification
|
||||||
<< ", is_permanent = " << is_permanent;
|
<< ", is_permanent = " << is_permanent;
|
||||||
delete_notification_id_to_message_id_correspondence(d->notification_info.get(), notification_id, m->message_id);
|
delete_notification_id_to_message_id_correspondence(d->notification_info.get(), notification_id, m->message_id);
|
||||||
@ -16123,14 +16125,14 @@ void MessagesManager::remove_message_notification_id(Dialog *d, Message *m, bool
|
|||||||
remove_dialog_pinned_message_notification(
|
remove_dialog_pinned_message_notification(
|
||||||
d, "remove_message_notification_id"); // must be called after notification_id is removed
|
d, "remove_message_notification_id"); // must be called after notification_id is removed
|
||||||
}
|
}
|
||||||
if (group_info.last_notification_id == notification_id) {
|
if (group_info.last_notification_id_ == notification_id) {
|
||||||
// last notification is deleted, need to find new last notification
|
// last notification is deleted, need to find new last notification
|
||||||
fix_dialog_last_notification_id(d, from_mentions, m->message_id);
|
fix_dialog_last_notification_id(d, from_mentions, m->message_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_permanent) {
|
if (is_permanent) {
|
||||||
if (had_active_notification) {
|
if (had_active_notification) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification, group_info.group_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification, group_info.group_id_,
|
||||||
notification_id, is_permanent, force_update, Promise<Unit>(),
|
notification_id, is_permanent, force_update, Promise<Unit>(),
|
||||||
"remove_message_notification_id");
|
"remove_message_notification_id");
|
||||||
}
|
}
|
||||||
@ -16148,15 +16150,15 @@ void MessagesManager::remove_new_secret_chat_notification(Dialog *d, bool is_per
|
|||||||
auto notification_id = d->notification_info->new_secret_chat_notification_id_;
|
auto notification_id = d->notification_info->new_secret_chat_notification_id_;
|
||||||
CHECK(notification_id.is_valid());
|
CHECK(notification_id.is_valid());
|
||||||
VLOG(notifications) << "Remove " << notification_id << " about new secret " << d->dialog_id << " from "
|
VLOG(notifications) << "Remove " << notification_id << " about new secret " << d->dialog_id << " from "
|
||||||
<< d->notification_info->message_notification_group_.group_id;
|
<< d->notification_info->message_notification_group_.group_id_;
|
||||||
d->notification_info->new_secret_chat_notification_id_ = NotificationId();
|
d->notification_info->new_secret_chat_notification_id_ = NotificationId();
|
||||||
bool is_fixed = set_dialog_last_notification(d->dialog_id, d->notification_info->message_notification_group_, 0,
|
bool is_fixed = set_dialog_last_notification(d->dialog_id, d->notification_info->message_notification_group_, 0,
|
||||||
NotificationId(), "remove_new_secret_chat_notification");
|
NotificationId(), "remove_new_secret_chat_notification");
|
||||||
CHECK(is_fixed);
|
CHECK(is_fixed);
|
||||||
if (is_permanent) {
|
if (is_permanent) {
|
||||||
CHECK(d->notification_info->message_notification_group_.group_id.is_valid());
|
CHECK(d->notification_info->message_notification_group_.group_id_.is_valid());
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification,
|
||||||
d->notification_info->message_notification_group_.group_id, notification_id, true, true,
|
d->notification_info->message_notification_group_.group_id_, notification_id, true, true,
|
||||||
Promise<Unit>(), "remove_new_secret_chat_notification");
|
Promise<Unit>(), "remove_new_secret_chat_notification");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -16170,8 +16172,8 @@ void MessagesManager::fix_dialog_last_notification_id(Dialog *d, bool from_menti
|
|||||||
CHECK(!td_->auth_manager_->is_bot());
|
CHECK(!td_->auth_manager_->is_bot());
|
||||||
auto it = d->ordered_messages.get_const_iterator(message_id);
|
auto it = d->ordered_messages.get_const_iterator(message_id);
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
VLOG(notifications) << "Trying to fix last notification identifier in " << group_info.group_id << " from "
|
VLOG(notifications) << "Trying to fix last notification identifier in " << group_info.group_id_ << " from "
|
||||||
<< d->dialog_id << " from " << message_id << "/" << group_info.last_notification_id;
|
<< d->dialog_id << " from " << message_id << "/" << group_info.last_notification_id_;
|
||||||
if (*it != nullptr && ((*it)->get_message_id() == message_id || (*it)->have_next())) {
|
if (*it != nullptr && ((*it)->get_message_id() == message_id || (*it)->have_next())) {
|
||||||
while (*it != nullptr) {
|
while (*it != nullptr) {
|
||||||
const Message *m = get_message(d, (*it)->get_message_id());
|
const Message *m = get_message(d, (*it)->get_message_id());
|
||||||
@ -16187,10 +16189,10 @@ void MessagesManager::fix_dialog_last_notification_id(Dialog *d, bool from_menti
|
|||||||
}
|
}
|
||||||
if (G()->use_message_database()) {
|
if (G()->use_message_database()) {
|
||||||
get_message_notifications_from_database(
|
get_message_notifications_from_database(
|
||||||
d->dialog_id, group_info.group_id, group_info.last_notification_id, message_id, 1,
|
d->dialog_id, group_info.group_id_, group_info.last_notification_id_, message_id, 1,
|
||||||
PromiseCreator::lambda(
|
PromiseCreator::lambda(
|
||||||
[actor_id = actor_id(this), dialog_id = d->dialog_id, from_mentions,
|
[actor_id = actor_id(this), dialog_id = d->dialog_id, from_mentions,
|
||||||
prev_last_notification_id = group_info.last_notification_id](Result<vector<Notification>> result) {
|
prev_last_notification_id = group_info.last_notification_id_](Result<vector<Notification>> result) {
|
||||||
send_closure(actor_id, &MessagesManager::do_fix_dialog_last_notification_id, dialog_id, from_mentions,
|
send_closure(actor_id, &MessagesManager::do_fix_dialog_last_notification_id, dialog_id, from_mentions,
|
||||||
prev_last_notification_id, std::move(result));
|
prev_last_notification_id, std::move(result));
|
||||||
}));
|
}));
|
||||||
@ -16210,9 +16212,9 @@ void MessagesManager::do_fix_dialog_last_notification_id(DialogId dialog_id, boo
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
VLOG(notifications) << "Receive " << result.ok().size() << " message notifications in " << group_info.group_id << '/'
|
VLOG(notifications) << "Receive " << result.ok().size() << " message notifications in " << group_info.group_id_ << '/'
|
||||||
<< dialog_id << " from " << prev_last_notification_id;
|
<< dialog_id << " from " << prev_last_notification_id;
|
||||||
if (group_info.last_notification_id != prev_last_notification_id) {
|
if (group_info.last_notification_id_ != prev_last_notification_id) {
|
||||||
// last_notification_id was changed
|
// last_notification_id was changed
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -28886,7 +28888,7 @@ NotificationGroupId MessagesManager::get_dialog_notification_group_id(DialogId d
|
|||||||
// just in case
|
// just in case
|
||||||
return NotificationGroupId();
|
return NotificationGroupId();
|
||||||
}
|
}
|
||||||
if (!group_info.group_id.is_valid()) {
|
if (!group_info.group_id_.is_valid()) {
|
||||||
NotificationGroupId next_notification_group_id;
|
NotificationGroupId next_notification_group_id;
|
||||||
do {
|
do {
|
||||||
next_notification_group_id = td_->notification_manager_->get_next_notification_group_id();
|
next_notification_group_id = td_->notification_manager_->get_next_notification_group_id();
|
||||||
@ -28894,8 +28896,8 @@ NotificationGroupId MessagesManager::get_dialog_notification_group_id(DialogId d
|
|||||||
return NotificationGroupId();
|
return NotificationGroupId();
|
||||||
}
|
}
|
||||||
} while (get_message_notification_group_force(next_notification_group_id).dialog_id.is_valid());
|
} while (get_message_notification_group_force(next_notification_group_id).dialog_id.is_valid());
|
||||||
group_info.group_id = next_notification_group_id;
|
group_info.group_id_ = next_notification_group_id;
|
||||||
group_info.is_changed = true;
|
group_info.is_changed_ = true;
|
||||||
VLOG(notifications) << "Assign " << next_notification_group_id << " to " << dialog_id;
|
VLOG(notifications) << "Assign " << next_notification_group_id << " to " << dialog_id;
|
||||||
on_dialog_updated(dialog_id, "get_dialog_notification_group_id");
|
on_dialog_updated(dialog_id, "get_dialog_notification_group_id");
|
||||||
|
|
||||||
@ -28907,13 +28909,13 @@ NotificationGroupId MessagesManager::get_dialog_notification_group_id(DialogId d
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(group_info.group_id.is_valid());
|
CHECK(group_info.group_id_.is_valid());
|
||||||
|
|
||||||
// notification group must be preloaded to guarantee that there is no race between
|
// notification group must be preloaded to guarantee that there is no race between
|
||||||
// get_message_notifications_from_database_force and new notifications added right now
|
// get_message_notifications_from_database_force and new notifications added right now
|
||||||
td_->notification_manager_->load_group_force(group_info.group_id);
|
td_->notification_manager_->load_group_force(group_info.group_id_);
|
||||||
|
|
||||||
return group_info.group_id;
|
return group_info.group_id_;
|
||||||
}
|
}
|
||||||
|
|
||||||
Result<MessagesManager::MessagePushNotificationInfo> MessagesManager::get_message_push_notification_info(
|
Result<MessagesManager::MessagePushNotificationInfo> MessagesManager::get_message_push_notification_info(
|
||||||
@ -29048,11 +29050,11 @@ NotificationId MessagesManager::get_next_notification_id(NotificationInfo *notif
|
|||||||
}
|
}
|
||||||
} while (notification_info->notification_id_to_message_id_.count(notification_id) != 0 ||
|
} while (notification_info->notification_id_to_message_id_.count(notification_id) != 0 ||
|
||||||
notification_info->new_secret_chat_notification_id_ == notification_id ||
|
notification_info->new_secret_chat_notification_id_ == notification_id ||
|
||||||
notification_id.get() <= notification_info->message_notification_group_.last_notification_id.get() ||
|
notification_id.get() <= notification_info->message_notification_group_.last_notification_id_.get() ||
|
||||||
notification_id.get() <= notification_info->message_notification_group_.max_removed_notification_id.get() ||
|
notification_id.get() <= notification_info->message_notification_group_.max_removed_notification_id_.get() ||
|
||||||
notification_id.get() <= notification_info->mention_notification_group_.last_notification_id.get() ||
|
notification_id.get() <= notification_info->mention_notification_group_.last_notification_id_.get() ||
|
||||||
notification_id.get() <=
|
notification_id.get() <=
|
||||||
notification_info->mention_notification_group_.max_removed_notification_id.get()); // just in case
|
notification_info->mention_notification_group_.max_removed_notification_id_.get()); // just in case
|
||||||
if (message_id.is_valid()) {
|
if (message_id.is_valid()) {
|
||||||
add_notification_id_to_message_id_correspondence(notification_info, notification_id, message_id);
|
add_notification_id_to_message_id_correspondence(notification_info, notification_id, message_id);
|
||||||
}
|
}
|
||||||
@ -29085,28 +29087,28 @@ MessagesManager::MessageNotificationGroup MessagesManager::get_message_notificat
|
|||||||
if (d == nullptr || d->notification_info == nullptr) {
|
if (d == nullptr || d->notification_info == nullptr) {
|
||||||
return MessageNotificationGroup();
|
return MessageNotificationGroup();
|
||||||
}
|
}
|
||||||
if (d->notification_info->message_notification_group_.group_id != group_id &&
|
if (d->notification_info->message_notification_group_.group_id_ != group_id &&
|
||||||
d->notification_info->mention_notification_group_.group_id != group_id) {
|
d->notification_info->mention_notification_group_.group_id_ != group_id) {
|
||||||
if (d->dialog_id.get_type() == DialogType::SecretChat &&
|
if (d->dialog_id.get_type() == DialogType::SecretChat &&
|
||||||
!d->notification_info->message_notification_group_.group_id.is_valid() &&
|
!d->notification_info->message_notification_group_.group_id_.is_valid() &&
|
||||||
!d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
!d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
// the group was reused, but wasn't deleted from the database, trying to resave it
|
// the group was reused, but wasn't deleted from the database, trying to resave it
|
||||||
auto &group_info = d->notification_info->message_notification_group_;
|
auto &group_info = d->notification_info->message_notification_group_;
|
||||||
group_info.group_id = group_id;
|
group_info.group_id_ = group_id;
|
||||||
group_info.try_reuse();
|
group_info.try_reuse();
|
||||||
save_dialog_to_database(d->dialog_id);
|
save_dialog_to_database(d->dialog_id);
|
||||||
group_info = NotificationGroupInfo();
|
group_info = NotificationGroupInfo();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_CHECK(d->notification_info->message_notification_group_.group_id == group_id ||
|
LOG_CHECK(d->notification_info->message_notification_group_.group_id_ == group_id ||
|
||||||
d->notification_info->mention_notification_group_.group_id == group_id);
|
d->notification_info->mention_notification_group_.group_id_ == group_id);
|
||||||
|
|
||||||
bool from_mentions = d->notification_info->mention_notification_group_.group_id == group_id;
|
bool from_mentions = d->notification_info->mention_notification_group_.group_id_ == group_id;
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
|
|
||||||
MessageNotificationGroup result;
|
MessageNotificationGroup result;
|
||||||
VLOG(notifications) << "Found " << (from_mentions ? "Mentions " : "Messages ") << group_info.group_id << '/'
|
VLOG(notifications) << "Found " << (from_mentions ? "Mentions " : "Messages ") << group_info.group_id_ << '/'
|
||||||
<< d->dialog_id << " by " << group_id << " with " << d->unread_mention_count
|
<< d->dialog_id << " by " << group_id << " with " << d->unread_mention_count
|
||||||
<< " unread mentions, " << d->unread_reaction_count << " unread reactions, pinned "
|
<< " unread mentions, " << d->unread_reaction_count << " unread reactions, pinned "
|
||||||
<< d->notification_info->pinned_message_notification_message_id_ << ", new secret chat "
|
<< d->notification_info->pinned_message_notification_message_id_ << ", new secret chat "
|
||||||
@ -29140,12 +29142,12 @@ MessagesManager::MessageNotificationGroup MessagesManager::get_message_notificat
|
|||||||
last_notification_date = result.notifications[0].date;
|
last_notification_date = result.notifications[0].date;
|
||||||
last_notification_id = result.notifications[0].notification_id;
|
last_notification_id = result.notifications[0].notification_id;
|
||||||
}
|
}
|
||||||
if (last_notification_date != group_info.last_notification_date ||
|
if (last_notification_date != group_info.last_notification_date_ ||
|
||||||
last_notification_id != group_info.last_notification_id) {
|
last_notification_id != group_info.last_notification_id_) {
|
||||||
LOG(ERROR) << "Fix last notification date in " << d->dialog_id << " from " << group_info.last_notification_date
|
LOG(ERROR) << "Fix last notification date in " << d->dialog_id << " from " << group_info.last_notification_date_
|
||||||
<< " to " << last_notification_date << " and last notification identifier from "
|
<< " to " << last_notification_date << " and last notification identifier from "
|
||||||
<< group_info.last_notification_id << " to " << last_notification_id << " in " << group_id << " of type "
|
<< group_info.last_notification_id_ << " to " << last_notification_id << " in " << group_id
|
||||||
<< result.type;
|
<< " of type " << result.type;
|
||||||
set_dialog_last_notification(d->dialog_id, group_info, last_notification_date, last_notification_id,
|
set_dialog_last_notification(d->dialog_id, group_info, last_notification_date, last_notification_id,
|
||||||
"get_message_notification_group_force");
|
"get_message_notification_group_force");
|
||||||
}
|
}
|
||||||
@ -29201,14 +29203,14 @@ bool MessagesManager::is_message_notification_active(const Dialog *d, const Mess
|
|||||||
}
|
}
|
||||||
if (is_from_mention_notification_group(m)) {
|
if (is_from_mention_notification_group(m)) {
|
||||||
return m->notification_id.get() >
|
return m->notification_id.get() >
|
||||||
d->notification_info->mention_notification_group_.max_removed_notification_id.get() &&
|
d->notification_info->mention_notification_group_.max_removed_notification_id_.get() &&
|
||||||
m->message_id > d->notification_info->mention_notification_group_.max_removed_message_id &&
|
m->message_id > d->notification_info->mention_notification_group_.max_removed_message_id_ &&
|
||||||
(m->contains_unread_mention ||
|
(m->contains_unread_mention ||
|
||||||
m->message_id == d->notification_info->pinned_message_notification_message_id_);
|
m->message_id == d->notification_info->pinned_message_notification_message_id_);
|
||||||
} else {
|
} else {
|
||||||
return m->notification_id.get() >
|
return m->notification_id.get() >
|
||||||
d->notification_info->message_notification_group_.max_removed_notification_id.get() &&
|
d->notification_info->message_notification_group_.max_removed_notification_id_.get() &&
|
||||||
m->message_id > d->notification_info->message_notification_group_.max_removed_message_id &&
|
m->message_id > d->notification_info->message_notification_group_.max_removed_message_id_ &&
|
||||||
m->message_id > d->last_read_inbox_message_id;
|
m->message_id > d->last_read_inbox_message_id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -29227,8 +29229,8 @@ void MessagesManager::try_add_pinned_message_notification(Dialog *d, vector<Noti
|
|||||||
|
|
||||||
auto m = get_message_force(d, message_id, "try_add_pinned_message_notification");
|
auto m = get_message_force(d, message_id, "try_add_pinned_message_notification");
|
||||||
if (m != nullptr &&
|
if (m != nullptr &&
|
||||||
m->notification_id.get() > d->notification_info->mention_notification_group_.max_removed_notification_id.get() &&
|
m->notification_id.get() > d->notification_info->mention_notification_group_.max_removed_notification_id_.get() &&
|
||||||
m->message_id > d->notification_info->mention_notification_group_.max_removed_message_id &&
|
m->message_id > d->notification_info->mention_notification_group_.max_removed_message_id_ &&
|
||||||
m->message_id > d->last_read_inbox_message_id && !is_dialog_pinned_message_notifications_disabled(d)) {
|
m->message_id > d->last_read_inbox_message_id && !is_dialog_pinned_message_notifications_disabled(d)) {
|
||||||
if (m->notification_id.get() < max_notification_id.get()) {
|
if (m->notification_id.get() < max_notification_id.get()) {
|
||||||
VLOG(notifications) << "Add " << m->notification_id << " about pinned " << message_id << " in " << d->dialog_id;
|
VLOG(notifications) << "Add " << m->notification_id << " about pinned " << message_id << " in " << d->dialog_id;
|
||||||
@ -29280,7 +29282,7 @@ vector<Notification> MessagesManager::get_message_notifications_from_database_fo
|
|||||||
|
|
||||||
bool is_found = false;
|
bool is_found = false;
|
||||||
VLOG(notifications) << "Loaded " << messages.size() << (from_mentions ? " mention" : "")
|
VLOG(notifications) << "Loaded " << messages.size() << (from_mentions ? " mention" : "")
|
||||||
<< " messages with notifications from database in " << group_info.group_id << '/'
|
<< " messages with notifications from database in " << group_info.group_id_ << '/'
|
||||||
<< d->dialog_id;
|
<< d->dialog_id;
|
||||||
for (auto &message : messages) {
|
for (auto &message : messages) {
|
||||||
auto m = on_get_message_from_database(d, message, false, "get_message_notifications_from_database_force");
|
auto m = on_get_message_from_database(d, message, false, "get_message_notifications_from_database_force");
|
||||||
@ -29321,8 +29323,8 @@ vector<Notification> MessagesManager::get_message_notifications_from_database_fo
|
|||||||
is_found = true;
|
is_found = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (notification_id.get() <= group_info.max_removed_notification_id.get() ||
|
if (notification_id.get() <= group_info.max_removed_notification_id_.get() ||
|
||||||
m->message_id <= group_info.max_removed_message_id ||
|
m->message_id <= group_info.max_removed_message_id_ ||
|
||||||
(!from_mentions && m->message_id <= d->last_read_inbox_message_id)) {
|
(!from_mentions && m->message_id <= d->last_read_inbox_message_id)) {
|
||||||
// if message still has notification_id, but it was removed via max_removed_notification_id,
|
// if message still has notification_id, but it was removed via max_removed_notification_id,
|
||||||
// or max_removed_message_id, or last_read_inbox_message_id,
|
// or max_removed_message_id, or last_read_inbox_message_id,
|
||||||
@ -29415,8 +29417,8 @@ vector<NotificationGroupKey> MessagesManager::get_message_notification_group_key
|
|||||||
CHECK(group_key.dialog_id.is_valid());
|
CHECK(group_key.dialog_id.is_valid());
|
||||||
const Dialog *d = get_dialog_force(group_key.dialog_id, "get_message_notification_group_keys_from_database");
|
const Dialog *d = get_dialog_force(group_key.dialog_id, "get_message_notification_group_keys_from_database");
|
||||||
if (d == nullptr || d->notification_info == nullptr ||
|
if (d == nullptr || d->notification_info == nullptr ||
|
||||||
(d->notification_info->message_notification_group_.group_id != group_key.group_id &&
|
(d->notification_info->message_notification_group_.group_id_ != group_key.group_id &&
|
||||||
d->notification_info->mention_notification_group_.group_id != group_key.group_id)) {
|
d->notification_info->mention_notification_group_.group_id_ != group_key.group_id)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29448,14 +29450,14 @@ void MessagesManager::get_message_notifications_from_database(DialogId dialog_id
|
|||||||
|
|
||||||
auto d = get_dialog(dialog_id);
|
auto d = get_dialog(dialog_id);
|
||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
if (d->notification_info == nullptr || (d->notification_info->message_notification_group_.group_id != group_id &&
|
if (d->notification_info == nullptr || (d->notification_info->message_notification_group_.group_id_ != group_id &&
|
||||||
d->notification_info->mention_notification_group_.group_id != group_id)) {
|
d->notification_info->mention_notification_group_.group_id_ != group_id)) {
|
||||||
return promise.set_value(vector<Notification>());
|
return promise.set_value(vector<Notification>());
|
||||||
}
|
}
|
||||||
|
|
||||||
VLOG(notifications) << "Get " << limit << " message notifications from database in " << group_id << " from "
|
VLOG(notifications) << "Get " << limit << " message notifications from database in " << group_id << " from "
|
||||||
<< dialog_id << " from " << from_notification_id << "/" << from_message_id;
|
<< dialog_id << " from " << from_notification_id << "/" << from_message_id;
|
||||||
bool from_mentions = d->notification_info->mention_notification_group_.group_id == group_id;
|
bool from_mentions = d->notification_info->mention_notification_group_.group_id_ == group_id;
|
||||||
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
||||||
CHECK(dialog_id.get_type() == DialogType::SecretChat);
|
CHECK(dialog_id.get_type() == DialogType::SecretChat);
|
||||||
vector<Notification> notifications;
|
vector<Notification> notifications;
|
||||||
@ -29484,8 +29486,8 @@ void MessagesManager::do_get_message_notifications_from_database(Dialog *d, bool
|
|||||||
CHECK(!from_message_id.is_scheduled());
|
CHECK(!from_message_id.is_scheduled());
|
||||||
|
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
if (from_notification_id.get() <= group_info.max_removed_notification_id.get() ||
|
if (from_notification_id.get() <= group_info.max_removed_notification_id_.get() ||
|
||||||
from_message_id <= group_info.max_removed_message_id ||
|
from_message_id <= group_info.max_removed_message_id_ ||
|
||||||
(!from_mentions && from_message_id <= d->last_read_inbox_message_id)) {
|
(!from_mentions && from_message_id <= d->last_read_inbox_message_id)) {
|
||||||
return promise.set_value(vector<Notification>());
|
return promise.set_value(vector<Notification>());
|
||||||
}
|
}
|
||||||
@ -29500,11 +29502,11 @@ void MessagesManager::do_get_message_notifications_from_database(Dialog *d, bool
|
|||||||
|
|
||||||
auto *db = G()->td_db()->get_message_db_async();
|
auto *db = G()->td_db()->get_message_db_async();
|
||||||
if (!from_mentions) {
|
if (!from_mentions) {
|
||||||
VLOG(notifications) << "Trying to load " << limit << " messages with notifications in " << group_info.group_id
|
VLOG(notifications) << "Trying to load " << limit << " messages with notifications in " << group_info.group_id_
|
||||||
<< '/' << dialog_id << " from " << from_notification_id;
|
<< '/' << dialog_id << " from " << from_notification_id;
|
||||||
return db->get_messages_from_notification_id(d->dialog_id, from_notification_id, limit, std::move(new_promise));
|
return db->get_messages_from_notification_id(d->dialog_id, from_notification_id, limit, std::move(new_promise));
|
||||||
} else {
|
} else {
|
||||||
VLOG(notifications) << "Trying to load " << limit << " messages with unread mentions in " << group_info.group_id
|
VLOG(notifications) << "Trying to load " << limit << " messages with unread mentions in " << group_info.group_id_
|
||||||
<< '/' << dialog_id << " from " << from_message_id;
|
<< '/' << dialog_id << " from " << from_message_id;
|
||||||
|
|
||||||
// ignore first_db_message_id, notifications can be nonconsecutive
|
// ignore first_db_message_id, notifications can be nonconsecutive
|
||||||
@ -29532,7 +29534,7 @@ void MessagesManager::on_get_message_notifications_from_database(DialogId dialog
|
|||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
|
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
if (!group_info.group_id.is_valid()) {
|
if (!group_info.group_id_.is_valid()) {
|
||||||
return promise.set_error(Status::Error("Notification group was deleted"));
|
return promise.set_error(Status::Error("Notification group was deleted"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29541,7 +29543,7 @@ void MessagesManager::on_get_message_notifications_from_database(DialogId dialog
|
|||||||
res.reserve(messages.size());
|
res.reserve(messages.size());
|
||||||
NotificationId from_notification_id;
|
NotificationId from_notification_id;
|
||||||
MessageId from_message_id;
|
MessageId from_message_id;
|
||||||
VLOG(notifications) << "Loaded " << messages.size() << " messages with notifications in " << group_info.group_id
|
VLOG(notifications) << "Loaded " << messages.size() << " messages with notifications in " << group_info.group_id_
|
||||||
<< '/' << dialog_id << " from database";
|
<< '/' << dialog_id << " from database";
|
||||||
for (auto &message : messages) {
|
for (auto &message : messages) {
|
||||||
auto m = on_get_message_from_database(d, message, false, "on_get_message_notifications_from_database");
|
auto m = on_get_message_from_database(d, message, false, "on_get_message_notifications_from_database");
|
||||||
@ -29579,8 +29581,8 @@ void MessagesManager::on_get_message_notifications_from_database(DialogId dialog
|
|||||||
from_message_id = m->message_id;
|
from_message_id = m->message_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (notification_id.get() <= group_info.max_removed_notification_id.get() ||
|
if (notification_id.get() <= group_info.max_removed_notification_id_.get() ||
|
||||||
m->message_id <= group_info.max_removed_message_id ||
|
m->message_id <= group_info.max_removed_message_id_ ||
|
||||||
(!from_mentions && m->message_id <= d->last_read_inbox_message_id)) {
|
(!from_mentions && m->message_id <= d->last_read_inbox_message_id)) {
|
||||||
// if message still has notification_id, but it was removed via max_removed_notification_id,
|
// if message still has notification_id, but it was removed via max_removed_notification_id,
|
||||||
// or max_removed_message_id, or last_read_inbox_message_id,
|
// or max_removed_message_id, or last_read_inbox_message_id,
|
||||||
@ -29640,8 +29642,8 @@ void MessagesManager::remove_message_notification(DialogId dialog_id, Notificati
|
|||||||
LOG(ERROR) << "Can't find " << dialog_id;
|
LOG(ERROR) << "Can't find " << dialog_id;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (d->notification_info == nullptr || (d->notification_info->message_notification_group_.group_id != group_id &&
|
if (d->notification_info == nullptr || (d->notification_info->message_notification_group_.group_id_ != group_id &&
|
||||||
d->notification_info->mention_notification_group_.group_id != group_id)) {
|
d->notification_info->mention_notification_group_.group_id_ != group_id)) {
|
||||||
LOG(ERROR) << "There is no " << group_id << " in " << dialog_id;
|
LOG(ERROR) << "There is no " << group_id << " in " << dialog_id;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -29649,7 +29651,7 @@ void MessagesManager::remove_message_notification(DialogId dialog_id, Notificati
|
|||||||
return; // there can be no notification with this ID
|
return; // there can be no notification with this ID
|
||||||
}
|
}
|
||||||
|
|
||||||
bool from_mentions = d->notification_info->mention_notification_group_.group_id == group_id;
|
bool from_mentions = d->notification_info->mention_notification_group_.group_id_ == group_id;
|
||||||
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
||||||
if (!from_mentions && d->notification_info->new_secret_chat_notification_id_ == notification_id) {
|
if (!from_mentions && d->notification_info->new_secret_chat_notification_id_ == notification_id) {
|
||||||
return remove_new_secret_chat_notification(d, false);
|
return remove_new_secret_chat_notification(d, false);
|
||||||
@ -29700,10 +29702,10 @@ void MessagesManager::remove_message_notifications_by_message_ids(DialogId dialo
|
|||||||
LOG(INFO) << "Can't delete " << message_id << " because it is not found";
|
LOG(INFO) << "Can't delete " << message_id << " because it is not found";
|
||||||
// call synchronously to remove them before ProcessPush returns
|
// call synchronously to remove them before ProcessPush returns
|
||||||
td_->notification_manager_->remove_temporary_notification_by_message_id(
|
td_->notification_manager_->remove_temporary_notification_by_message_id(
|
||||||
d->notification_info->message_notification_group_.group_id, message_id, true,
|
d->notification_info->message_notification_group_.group_id_, message_id, true,
|
||||||
"remove_message_notifications_by_message_ids");
|
"remove_message_notifications_by_message_ids");
|
||||||
td_->notification_manager_->remove_temporary_notification_by_message_id(
|
td_->notification_manager_->remove_temporary_notification_by_message_id(
|
||||||
d->notification_info->mention_notification_group_.group_id, message_id, true,
|
d->notification_info->mention_notification_group_.group_id_, message_id, true,
|
||||||
"remove_message_notifications_by_message_ids");
|
"remove_message_notifications_by_message_ids");
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -29741,8 +29743,8 @@ void MessagesManager::remove_message_notifications(DialogId dialog_id, Notificat
|
|||||||
LOG(ERROR) << "Can't find " << dialog_id;
|
LOG(ERROR) << "Can't find " << dialog_id;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (d->notification_info == nullptr || (d->notification_info->message_notification_group_.group_id != group_id &&
|
if (d->notification_info == nullptr || (d->notification_info->message_notification_group_.group_id_ != group_id &&
|
||||||
d->notification_info->mention_notification_group_.group_id != group_id)) {
|
d->notification_info->mention_notification_group_.group_id_ != group_id)) {
|
||||||
LOG(ERROR) << "There is no " << group_id << " in " << dialog_id;
|
LOG(ERROR) << "There is no " << group_id << " in " << dialog_id;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -29751,7 +29753,7 @@ void MessagesManager::remove_message_notifications(DialogId dialog_id, Notificat
|
|||||||
}
|
}
|
||||||
CHECK(!max_message_id.is_scheduled());
|
CHECK(!max_message_id.is_scheduled());
|
||||||
|
|
||||||
bool from_mentions = d->notification_info->mention_notification_group_.group_id == group_id;
|
bool from_mentions = d->notification_info->mention_notification_group_.group_id_ == group_id;
|
||||||
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
if (d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
||||||
if (!from_mentions && d->notification_info->new_secret_chat_notification_id_.get() <= max_notification_id.get()) {
|
if (!from_mentions && d->notification_info->new_secret_chat_notification_id_.get() <= max_notification_id.get()) {
|
||||||
return remove_new_secret_chat_notification(d, false);
|
return remove_new_secret_chat_notification(d, false);
|
||||||
@ -29759,22 +29761,22 @@ void MessagesManager::remove_message_notifications(DialogId dialog_id, Notificat
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
if (max_notification_id.get() <= group_info.max_removed_notification_id.get()) {
|
if (max_notification_id.get() <= group_info.max_removed_notification_id_.get()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (max_message_id > group_info.max_removed_message_id) {
|
if (max_message_id > group_info.max_removed_message_id_) {
|
||||||
VLOG(notifications) << "Set max_removed_message_id in " << group_info.group_id << '/' << dialog_id << " to "
|
VLOG(notifications) << "Set max_removed_message_id in " << group_info.group_id_ << '/' << dialog_id << " to "
|
||||||
<< max_message_id;
|
<< max_message_id;
|
||||||
group_info.max_removed_message_id = max_message_id.get_prev_server_message_id();
|
group_info.max_removed_message_id_ = max_message_id.get_prev_server_message_id();
|
||||||
}
|
}
|
||||||
|
|
||||||
VLOG(notifications) << "Set max_removed_notification_id in " << group_info.group_id << '/' << dialog_id << " to "
|
VLOG(notifications) << "Set max_removed_notification_id in " << group_info.group_id_ << '/' << dialog_id << " to "
|
||||||
<< max_notification_id;
|
<< max_notification_id;
|
||||||
group_info.max_removed_notification_id = max_notification_id;
|
group_info.max_removed_notification_id_ = max_notification_id;
|
||||||
on_dialog_updated(dialog_id, "remove_message_notifications");
|
on_dialog_updated(dialog_id, "remove_message_notifications");
|
||||||
|
|
||||||
if (group_info.last_notification_id.is_valid() &&
|
if (group_info.last_notification_id_.is_valid() &&
|
||||||
max_notification_id.get() >= group_info.last_notification_id.get()) {
|
max_notification_id.get() >= group_info.last_notification_id_.get()) {
|
||||||
bool is_changed =
|
bool is_changed =
|
||||||
set_dialog_last_notification(dialog_id, group_info, 0, NotificationId(), "remove_message_notifications");
|
set_dialog_last_notification(dialog_id, group_info, 0, NotificationId(), "remove_message_notifications");
|
||||||
CHECK(is_changed);
|
CHECK(is_changed);
|
||||||
@ -29805,7 +29807,7 @@ int32 MessagesManager::get_dialog_pending_notification_count(const Dialog *d, bo
|
|||||||
void MessagesManager::update_dialog_mention_notification_count(const Dialog *d) {
|
void MessagesManager::update_dialog_mention_notification_count(const Dialog *d) {
|
||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
if (td_->auth_manager_->is_bot() || d->notification_info == nullptr ||
|
if (td_->auth_manager_->is_bot() || d->notification_info == nullptr ||
|
||||||
!d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
!d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
auto total_count = get_dialog_pending_notification_count(d, true) -
|
auto total_count = get_dialog_pending_notification_count(d, true) -
|
||||||
@ -29816,7 +29818,7 @@ void MessagesManager::update_dialog_mention_notification_count(const Dialog *d)
|
|||||||
total_count = 0;
|
total_count = 0;
|
||||||
}
|
}
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::set_notification_total_count,
|
send_closure_later(G()->notification_manager(), &NotificationManager::set_notification_total_count,
|
||||||
d->notification_info->mention_notification_group_.group_id, total_count);
|
d->notification_info->mention_notification_group_.group_id_, total_count);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MessagesManager::is_message_notification_disabled(const Dialog *d, const Message *m) const {
|
bool MessagesManager::is_message_notification_disabled(const Dialog *d, const Message *m) const {
|
||||||
@ -29915,13 +29917,13 @@ bool MessagesManager::add_new_message_notification(Dialog *d, Message *m, bool f
|
|||||||
CHECK(m->message_id.is_valid());
|
CHECK(m->message_id.is_valid());
|
||||||
|
|
||||||
if (!force && d->notification_info != nullptr) {
|
if (!force && d->notification_info != nullptr) {
|
||||||
if (d->notification_info->message_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->message_notification_group_.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notifications,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notifications,
|
||||||
d->notification_info->message_notification_group_.group_id, "add_new_message_notification 1");
|
d->notification_info->message_notification_group_.group_id_, "add_new_message_notification 1");
|
||||||
}
|
}
|
||||||
if (d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notifications,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notifications,
|
||||||
d->notification_info->mention_notification_group_.group_id, "add_new_message_notification 2");
|
d->notification_info->mention_notification_group_.group_id_, "add_new_message_notification 2");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29936,7 +29938,7 @@ bool MessagesManager::add_new_message_notification(Dialog *d, Message *m, bool f
|
|||||||
from_mentions ? m->contains_unread_mention || is_pinned : m->message_id > d->last_read_inbox_message_id;
|
from_mentions ? m->contains_unread_mention || is_pinned : m->message_id > d->last_read_inbox_message_id;
|
||||||
if (is_active) {
|
if (is_active) {
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
if (group_info.max_removed_message_id >= m->message_id) {
|
if (group_info.max_removed_message_id_ >= m->message_id) {
|
||||||
is_active = false;
|
is_active = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -30060,7 +30062,7 @@ bool MessagesManager::add_new_message_notification(Dialog *d, Message *m, bool f
|
|||||||
// protection from accidental notification_id removal in set_dialog_pinned_message_notification
|
// protection from accidental notification_id removal in set_dialog_pinned_message_notification
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
VLOG(notifications) << "Create " << m->notification_id << " with " << m->message_id << " in " << group_info.group_id
|
VLOG(notifications) << "Create " << m->notification_id << " with " << m->message_id << " in " << group_info.group_id_
|
||||||
<< '/' << d->dialog_id;
|
<< '/' << d->dialog_id;
|
||||||
int32 min_delay_ms = 0;
|
int32 min_delay_ms = 0;
|
||||||
if (need_delay_message_content_notification(m->content.get(), td_->contacts_manager_->get_my_id())) {
|
if (need_delay_message_content_notification(m->content.get(), td_->contacts_manager_->get_my_id())) {
|
||||||
@ -30120,19 +30122,19 @@ void MessagesManager::flush_pending_new_message_notifications(DialogId dialog_id
|
|||||||
}
|
}
|
||||||
|
|
||||||
void MessagesManager::remove_all_dialog_notifications(Dialog *d, bool from_mentions, const char *source) {
|
void MessagesManager::remove_all_dialog_notifications(Dialog *d, bool from_mentions, const char *source) {
|
||||||
// removes up to group_info.last_notification_id
|
// removes up to group_info.last_notification_id_
|
||||||
CHECK(!td_->auth_manager_->is_bot());
|
CHECK(!td_->auth_manager_->is_bot());
|
||||||
if (d->notification_info == nullptr) {
|
if (d->notification_info == nullptr) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NotificationGroupInfo &group_info = get_notification_group_info(d, from_mentions);
|
NotificationGroupInfo &group_info = get_notification_group_info(d, from_mentions);
|
||||||
if (group_info.group_id.is_valid() && group_info.last_notification_id.is_valid() &&
|
if (group_info.group_id_.is_valid() && group_info.last_notification_id_.is_valid() &&
|
||||||
group_info.max_removed_notification_id != group_info.last_notification_id) {
|
group_info.max_removed_notification_id_ != group_info.last_notification_id_) {
|
||||||
VLOG(notifications) << "Set max_removed_notification_id in " << group_info.group_id << '/' << d->dialog_id << " to "
|
VLOG(notifications) << "Set max_removed_notification_id in " << group_info.group_id_ << '/' << d->dialog_id
|
||||||
<< group_info.last_notification_id << " from " << source;
|
<< " to " << group_info.last_notification_id_ << " from " << source;
|
||||||
group_info.max_removed_notification_id = group_info.last_notification_id;
|
group_info.max_removed_notification_id_ = group_info.last_notification_id_;
|
||||||
if (d->notification_info->max_notification_message_id_ > group_info.max_removed_message_id) {
|
if (d->notification_info->max_notification_message_id_ > group_info.max_removed_message_id_) {
|
||||||
group_info.max_removed_message_id =
|
group_info.max_removed_message_id_ =
|
||||||
d->notification_info->max_notification_message_id_.get_prev_server_message_id();
|
d->notification_info->max_notification_message_id_.get_prev_server_message_id();
|
||||||
}
|
}
|
||||||
if (!d->notification_info->pending_new_message_notifications_.empty()) {
|
if (!d->notification_info->pending_new_message_notifications_.empty()) {
|
||||||
@ -30143,7 +30145,7 @@ void MessagesManager::remove_all_dialog_notifications(Dialog *d, bool from_menti
|
|||||||
}
|
}
|
||||||
// remove_message_notifications will be called by NotificationManager
|
// remove_message_notifications will be called by NotificationManager
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification_group,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification_group,
|
||||||
group_info.group_id, group_info.last_notification_id, MessageId(), 0, true, Promise<Unit>());
|
group_info.group_id_, group_info.last_notification_id_, MessageId(), 0, true, Promise<Unit>());
|
||||||
if (d->notification_info->new_secret_chat_notification_id_.is_valid() &&
|
if (d->notification_info->new_secret_chat_notification_id_.is_valid() &&
|
||||||
&group_info == &d->notification_info->message_notification_group_) {
|
&group_info == &d->notification_info->message_notification_group_) {
|
||||||
remove_new_secret_chat_notification(d, false);
|
remove_new_secret_chat_notification(d, false);
|
||||||
@ -30163,11 +30165,11 @@ void MessagesManager::remove_message_dialog_notifications(Dialog *d, MessageId m
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NotificationGroupInfo &group_info = get_notification_group_info(d, from_mentions);
|
NotificationGroupInfo &group_info = get_notification_group_info(d, from_mentions);
|
||||||
if (!group_info.group_id.is_valid()) {
|
if (!group_info.group_id_.is_valid()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
VLOG(notifications) << "Remove message dialog notifications in " << group_info.group_id << '/' << d->dialog_id
|
VLOG(notifications) << "Remove message dialog notifications in " << group_info.group_id_ << '/' << d->dialog_id
|
||||||
<< " up to " << max_message_id << " from " << source;
|
<< " up to " << max_message_id << " from " << source;
|
||||||
|
|
||||||
if (!d->notification_info->pending_new_message_notifications_.empty()) {
|
if (!d->notification_info->pending_new_message_notifications_.empty()) {
|
||||||
@ -30192,7 +30194,7 @@ void MessagesManager::remove_message_dialog_notifications(Dialog *d, MessageId m
|
|||||||
LOG(FATAL) << "TODO support notification deletion up to " << max_message_id << " if it would be ever needed";
|
LOG(FATAL) << "TODO support notification deletion up to " << max_message_id << " if it would be ever needed";
|
||||||
}
|
}
|
||||||
|
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification_group, group_info.group_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification_group, group_info.group_id_,
|
||||||
NotificationId(), max_notification_message_id, 0, true, Promise<Unit>());
|
NotificationId(), max_notification_message_id, 0, true, Promise<Unit>());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34901,13 +34903,13 @@ MessagesManager::Message *MessagesManager::add_message_to_dialog(Dialog *d, uniq
|
|||||||
auto notification_id = message->notification_id;
|
auto notification_id = message->notification_id;
|
||||||
VLOG(notifications) << "Remove mention " << notification_id << " in " << message_id << " in " << dialog_id;
|
VLOG(notifications) << "Remove mention " << notification_id << " in " << message_id << " in " << dialog_id;
|
||||||
message->notification_id = NotificationId();
|
message->notification_id = NotificationId();
|
||||||
if (d->notification_info->mention_notification_group_.last_notification_id == notification_id) {
|
if (d->notification_info->mention_notification_group_.last_notification_id_ == notification_id) {
|
||||||
// last notification is deleted, need to find new last notification
|
// last notification is deleted, need to find new last notification
|
||||||
fix_dialog_last_notification_id(d, true, message_id);
|
fix_dialog_last_notification_id(d, true, message_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification,
|
||||||
d->notification_info->mention_notification_group_.group_id, notification_id, false, false,
|
d->notification_info->mention_notification_group_.group_id_, notification_id, false, false,
|
||||||
Promise<Unit>(), "remove disabled mention notification");
|
Promise<Unit>(), "remove disabled mention notification");
|
||||||
|
|
||||||
on_message_changed(d, message.get(), false, "remove_mention_notification");
|
on_message_changed(d, message.get(), false, "remove_mention_notification");
|
||||||
@ -35277,8 +35279,8 @@ void MessagesManager::on_message_notification_changed(Dialog *d, const Message *
|
|||||||
CHECK(m != nullptr);
|
CHECK(m != nullptr);
|
||||||
if (m->notification_id.is_valid() && is_message_notification_active(d, m)) {
|
if (m->notification_id.is_valid() && is_message_notification_active(d, m)) {
|
||||||
auto &group_info = get_notification_group_info(d, m);
|
auto &group_info = get_notification_group_info(d, m);
|
||||||
if (group_info.group_id.is_valid()) {
|
if (group_info.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::edit_notification, group_info.group_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::edit_notification, group_info.group_id_,
|
||||||
m->notification_id,
|
m->notification_id,
|
||||||
create_new_message_notification(
|
create_new_message_notification(
|
||||||
m->message_id, is_message_preview_enabled(d, m, is_from_mention_notification_group(m))));
|
m->message_id, is_message_preview_enabled(d, m, is_from_mention_notification_group(m))));
|
||||||
@ -35286,7 +35288,7 @@ void MessagesManager::on_message_notification_changed(Dialog *d, const Message *
|
|||||||
}
|
}
|
||||||
if (m->is_pinned && d->notification_info != nullptr &&
|
if (m->is_pinned && d->notification_info != nullptr &&
|
||||||
d->notification_info->pinned_message_notification_message_id_.is_valid() &&
|
d->notification_info->pinned_message_notification_message_id_.is_valid() &&
|
||||||
d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
auto pinned_message =
|
auto pinned_message =
|
||||||
get_message_force(d, d->notification_info->pinned_message_notification_message_id_, "after update_message");
|
get_message_force(d, d->notification_info->pinned_message_notification_message_id_, "after update_message");
|
||||||
if (pinned_message != nullptr && pinned_message->notification_id.is_valid() &&
|
if (pinned_message != nullptr && pinned_message->notification_id.is_valid() &&
|
||||||
@ -35294,7 +35296,7 @@ void MessagesManager::on_message_notification_changed(Dialog *d, const Message *
|
|||||||
get_message_content_pinned_message_id(pinned_message->content.get()) == m->message_id) {
|
get_message_content_pinned_message_id(pinned_message->content.get()) == m->message_id) {
|
||||||
send_closure_later(
|
send_closure_later(
|
||||||
G()->notification_manager(), &NotificationManager::edit_notification,
|
G()->notification_manager(), &NotificationManager::edit_notification,
|
||||||
d->notification_info->mention_notification_group_.group_id, pinned_message->notification_id,
|
d->notification_info->mention_notification_group_.group_id_, pinned_message->notification_id,
|
||||||
create_new_message_notification(pinned_message->message_id, is_message_preview_enabled(d, m, true)));
|
create_new_message_notification(pinned_message->message_id, is_message_preview_enabled(d, m, true)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -35551,22 +35553,22 @@ void MessagesManager::delete_message_from_database(Dialog *d, MessageId message_
|
|||||||
auto from_mentions = is_from_mention_notification_group(m);
|
auto from_mentions = is_from_mention_notification_group(m);
|
||||||
auto &group_info = get_notification_group_info(d, from_mentions);
|
auto &group_info = get_notification_group_info(d, from_mentions);
|
||||||
|
|
||||||
if (group_info.group_id.is_valid()) {
|
if (group_info.group_id_.is_valid()) {
|
||||||
if (group_info.last_notification_id == m->notification_id) {
|
if (group_info.last_notification_id_ == m->notification_id) {
|
||||||
// last notification is deleted, need to find new last notification
|
// last notification is deleted, need to find new last notification
|
||||||
fix_dialog_last_notification_id(d, from_mentions, m->message_id);
|
fix_dialog_last_notification_id(d, from_mentions, m->message_id);
|
||||||
}
|
}
|
||||||
if (is_message_notification_active(d, m)) {
|
if (is_message_notification_active(d, m)) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification, group_info.group_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_notification, group_info.group_id_,
|
||||||
m->notification_id, true, false, Promise<Unit>(), "delete_message_from_database");
|
m->notification_id, true, false, Promise<Unit>(), "delete_message_from_database");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (!message_id.is_scheduled() && message_id > d->last_new_message_id && d->notification_info != nullptr) {
|
} else if (!message_id.is_scheduled() && message_id > d->last_new_message_id && d->notification_info != nullptr) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
||||||
d->notification_info->message_notification_group_.group_id, message_id, false,
|
d->notification_info->message_notification_group_.group_id_, message_id, false,
|
||||||
"delete_message_from_database");
|
"delete_message_from_database");
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
||||||
d->notification_info->mention_notification_group_.group_id, message_id, false,
|
d->notification_info->mention_notification_group_.group_id_, message_id, false,
|
||||||
"delete_message_from_database");
|
"delete_message_from_database");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -36578,12 +36580,12 @@ MessagesManager::Dialog *MessagesManager::add_new_dialog(unique_ptr<Dialog> &&di
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (d->notification_info != nullptr) {
|
if (d->notification_info != nullptr) {
|
||||||
if (d->notification_info->message_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->message_notification_group_.group_id_.is_valid()) {
|
||||||
notification_group_id_to_dialog_id_.emplace(d->notification_info->message_notification_group_.group_id,
|
notification_group_id_to_dialog_id_.emplace(d->notification_info->message_notification_group_.group_id_,
|
||||||
dialog_id);
|
dialog_id);
|
||||||
}
|
}
|
||||||
if (d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
notification_group_id_to_dialog_id_.emplace(d->notification_info->mention_notification_group_.group_id,
|
notification_group_id_to_dialog_id_.emplace(d->notification_info->mention_notification_group_.group_id_,
|
||||||
dialog_id);
|
dialog_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -36725,18 +36727,18 @@ void MessagesManager::fix_new_dialog(Dialog *d, unique_ptr<Message> &&last_datab
|
|||||||
}
|
}
|
||||||
if (d->notification_info != nullptr && d->notification_info->pinned_message_notification_message_id_.is_valid()) {
|
if (d->notification_info != nullptr && d->notification_info->pinned_message_notification_message_id_.is_valid()) {
|
||||||
auto pinned_message_id = d->notification_info->pinned_message_notification_message_id_;
|
auto pinned_message_id = d->notification_info->pinned_message_notification_message_id_;
|
||||||
if (!d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
if (!d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
LOG(ERROR) << "Have pinned message notification in " << pinned_message_id << " in " << dialog_id
|
LOG(ERROR) << "Have pinned message notification in " << pinned_message_id << " in " << dialog_id
|
||||||
<< ", but there is no mention notification group";
|
<< ", but there is no mention notification group";
|
||||||
d->notification_info->pinned_message_notification_message_id_ = MessageId();
|
d->notification_info->pinned_message_notification_message_id_ = MessageId();
|
||||||
on_dialog_updated(dialog_id, "fix pinned message notification");
|
on_dialog_updated(dialog_id, "fix pinned message notification");
|
||||||
} else if (is_dialog_pinned_message_notifications_disabled(d) ||
|
} else if (is_dialog_pinned_message_notifications_disabled(d) ||
|
||||||
pinned_message_id <= d->last_read_inbox_message_id ||
|
pinned_message_id <= d->last_read_inbox_message_id ||
|
||||||
pinned_message_id <= d->notification_info->mention_notification_group_.max_removed_message_id) {
|
pinned_message_id <= d->notification_info->mention_notification_group_.max_removed_message_id_) {
|
||||||
VLOG(notifications) << "Remove disabled pinned message notification in " << pinned_message_id << " in "
|
VLOG(notifications) << "Remove disabled pinned message notification in " << pinned_message_id << " in "
|
||||||
<< dialog_id;
|
<< dialog_id;
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
send_closure_later(G()->notification_manager(), &NotificationManager::remove_temporary_notification_by_message_id,
|
||||||
d->notification_info->mention_notification_group_.group_id, pinned_message_id, true,
|
d->notification_info->mention_notification_group_.group_id_, pinned_message_id, true,
|
||||||
"fix pinned message notification");
|
"fix pinned message notification");
|
||||||
d->notification_info->pinned_message_notification_message_id_ = MessageId();
|
d->notification_info->pinned_message_notification_message_id_ = MessageId();
|
||||||
on_dialog_updated(dialog_id, "fix pinned message notification 2");
|
on_dialog_updated(dialog_id, "fix pinned message notification 2");
|
||||||
@ -36744,8 +36746,8 @@ void MessagesManager::fix_new_dialog(Dialog *d, unique_ptr<Message> &&last_datab
|
|||||||
}
|
}
|
||||||
if (d->notification_info != nullptr && d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
if (d->notification_info != nullptr && d->notification_info->new_secret_chat_notification_id_.is_valid()) {
|
||||||
auto &group_info = d->notification_info->message_notification_group_;
|
auto &group_info = d->notification_info->message_notification_group_;
|
||||||
if (d->notification_info->new_secret_chat_notification_id_.get() <= group_info.max_removed_notification_id.get() ||
|
if (d->notification_info->new_secret_chat_notification_id_.get() <= group_info.max_removed_notification_id_.get() ||
|
||||||
(group_info.last_notification_date == 0 && group_info.max_removed_notification_id.get() == 0)) {
|
(group_info.last_notification_date_ == 0 && group_info.max_removed_notification_id_.get() == 0)) {
|
||||||
VLOG(notifications) << "Fix removing new secret chat " << d->notification_info->new_secret_chat_notification_id_
|
VLOG(notifications) << "Fix removing new secret chat " << d->notification_info->new_secret_chat_notification_id_
|
||||||
<< " in " << dialog_id;
|
<< " in " << dialog_id;
|
||||||
d->notification_info->new_secret_chat_notification_id_ = NotificationId();
|
d->notification_info->new_secret_chat_notification_id_ = NotificationId();
|
||||||
@ -38194,13 +38196,13 @@ void MessagesManager::do_get_channel_difference(DialogId dialog_id, int32 pts, b
|
|||||||
// can be called multiple times before after_get_channel_difference
|
// can be called multiple times before after_get_channel_difference
|
||||||
const Dialog *d = get_dialog(dialog_id);
|
const Dialog *d = get_dialog(dialog_id);
|
||||||
if (d != nullptr && d->notification_info != nullptr) {
|
if (d != nullptr && d->notification_info != nullptr) {
|
||||||
if (d->notification_info->message_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->message_notification_group_.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::before_get_chat_difference,
|
send_closure_later(G()->notification_manager(), &NotificationManager::before_get_chat_difference,
|
||||||
d->notification_info->message_notification_group_.group_id);
|
d->notification_info->message_notification_group_.group_id_);
|
||||||
}
|
}
|
||||||
if (d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::before_get_chat_difference,
|
send_closure_later(G()->notification_manager(), &NotificationManager::before_get_chat_difference,
|
||||||
d->notification_info->mention_notification_group_.group_id);
|
d->notification_info->mention_notification_group_.group_id_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -38851,13 +38853,13 @@ void MessagesManager::after_get_channel_difference(DialogId dialog_id, bool succ
|
|||||||
d->is_channel_difference_finished = true;
|
d->is_channel_difference_finished = true;
|
||||||
|
|
||||||
if (d->notification_info != nullptr) {
|
if (d->notification_info != nullptr) {
|
||||||
if (d->notification_info->message_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->message_notification_group_.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::after_get_chat_difference,
|
send_closure_later(G()->notification_manager(), &NotificationManager::after_get_chat_difference,
|
||||||
d->notification_info->message_notification_group_.group_id);
|
d->notification_info->message_notification_group_.group_id_);
|
||||||
}
|
}
|
||||||
if (d->notification_info->mention_notification_group_.group_id.is_valid()) {
|
if (d->notification_info->mention_notification_group_.group_id_.is_valid()) {
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::after_get_chat_difference,
|
send_closure_later(G()->notification_manager(), &NotificationManager::after_get_chat_difference,
|
||||||
d->notification_info->mention_notification_group_.group_id);
|
d->notification_info->mention_notification_group_.group_id_);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -11,49 +11,49 @@
|
|||||||
namespace td {
|
namespace td {
|
||||||
|
|
||||||
void NotificationGroupInfo::try_reuse() {
|
void NotificationGroupInfo::try_reuse() {
|
||||||
CHECK(group_id.is_valid());
|
CHECK(group_id_.is_valid());
|
||||||
CHECK(last_notification_date == 0);
|
CHECK(last_notification_date_ == 0);
|
||||||
if (!try_reuse_) {
|
if (!try_reuse_) {
|
||||||
try_reuse_ = true;
|
try_reuse_ = true;
|
||||||
is_changed = true;
|
is_changed_ = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationGroupInfo::add_group_key_if_changed(vector<NotificationGroupKey> &group_keys, DialogId dialog_id) {
|
void NotificationGroupInfo::add_group_key_if_changed(vector<NotificationGroupKey> &group_keys, DialogId dialog_id) {
|
||||||
if (!is_changed) {
|
if (!is_changed_) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
is_changed = false;
|
is_changed_ = false;
|
||||||
|
|
||||||
group_keys.emplace_back(group_id, try_reuse_ ? DialogId() : dialog_id, last_notification_date);
|
group_keys.emplace_back(group_id_, try_reuse_ ? DialogId() : dialog_id, last_notification_date_);
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationGroupId NotificationGroupInfo::get_reused_group_id() {
|
NotificationGroupId NotificationGroupInfo::get_reused_group_id() {
|
||||||
if (!try_reuse_) {
|
if (!try_reuse_) {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
if (is_changed) {
|
if (is_changed_) {
|
||||||
LOG(ERROR) << "Failed to reuse changed " << group_id;
|
LOG(ERROR) << "Failed to reuse changed " << group_id_;
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
try_reuse_ = false;
|
try_reuse_ = false;
|
||||||
if (!group_id.is_valid()) {
|
if (!group_id_.is_valid()) {
|
||||||
LOG(ERROR) << "Failed to reuse invalid " << group_id;
|
LOG(ERROR) << "Failed to reuse invalid " << group_id_;
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
CHECK(last_notification_id == NotificationId());
|
CHECK(last_notification_id_ == NotificationId());
|
||||||
CHECK(last_notification_date == 0);
|
CHECK(last_notification_date_ == 0);
|
||||||
auto result = group_id;
|
auto result = group_id_;
|
||||||
group_id = NotificationGroupId();
|
group_id_ = NotificationGroupId();
|
||||||
max_removed_notification_id = NotificationId();
|
max_removed_notification_id_ = NotificationId();
|
||||||
max_removed_message_id = MessageId();
|
max_removed_message_id_ = MessageId();
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
StringBuilder &operator<<(StringBuilder &string_builder, const NotificationGroupInfo &group_info) {
|
StringBuilder &operator<<(StringBuilder &string_builder, const NotificationGroupInfo &group_info) {
|
||||||
return string_builder << group_info.group_id << " with last " << group_info.last_notification_id << " sent at "
|
return string_builder << group_info.group_id_ << " with last " << group_info.last_notification_id_ << " sent at "
|
||||||
<< group_info.last_notification_date << ", max removed "
|
<< group_info.last_notification_date_ << ", max removed "
|
||||||
<< group_info.max_removed_notification_id << '/' << group_info.max_removed_message_id;
|
<< group_info.max_removed_notification_id_ << '/' << group_info.max_removed_message_id_;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace td
|
} // namespace td
|
||||||
|
@ -18,15 +18,15 @@ class NotificationGroupInfo {
|
|||||||
bool try_reuse_ = false; // true, if the group needs to be deleted from database and tried to be reused
|
bool try_reuse_ = false; // true, if the group needs to be deleted from database and tried to be reused
|
||||||
|
|
||||||
public:
|
public:
|
||||||
NotificationGroupId group_id;
|
NotificationGroupId group_id_;
|
||||||
int32 last_notification_date = 0; // date of last notification in the group
|
int32 last_notification_date_ = 0; // date of last notification in the group
|
||||||
NotificationId last_notification_id; // identifier of last notification in the group
|
NotificationId last_notification_id_; // identifier of last notification in the group
|
||||||
NotificationId max_removed_notification_id; // notification identifier, up to which all notifications are removed
|
NotificationId max_removed_notification_id_; // notification identifier, up to which all notifications are removed
|
||||||
MessageId max_removed_message_id; // message identifier, up to which all notifications are removed
|
MessageId max_removed_message_id_; // message identifier, up to which all notifications are removed
|
||||||
bool is_changed = false; // true, if the group needs to be saved to database
|
bool is_changed_ = false; // true, if the group needs to be saved to database
|
||||||
|
|
||||||
bool is_active() const {
|
bool is_active() const {
|
||||||
return group_id.is_valid() && !try_reuse_;
|
return group_id_.is_valid() && !try_reuse_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void try_reuse();
|
void try_reuse();
|
||||||
|
@ -16,22 +16,22 @@ namespace td {
|
|||||||
template <class StorerT>
|
template <class StorerT>
|
||||||
void NotificationGroupInfo::store(StorerT &storer) const {
|
void NotificationGroupInfo::store(StorerT &storer) const {
|
||||||
using td::store;
|
using td::store;
|
||||||
store(group_id, storer);
|
store(group_id_, storer);
|
||||||
store(last_notification_date, storer);
|
store(last_notification_date_, storer);
|
||||||
store(last_notification_id, storer);
|
store(last_notification_id_, storer);
|
||||||
store(max_removed_notification_id, storer);
|
store(max_removed_notification_id_, storer);
|
||||||
store(max_removed_message_id, storer);
|
store(max_removed_message_id_, storer);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class ParserT>
|
template <class ParserT>
|
||||||
void NotificationGroupInfo::parse(ParserT &parser) {
|
void NotificationGroupInfo::parse(ParserT &parser) {
|
||||||
using td::parse;
|
using td::parse;
|
||||||
parse(group_id, parser);
|
parse(group_id_, parser);
|
||||||
parse(last_notification_date, parser);
|
parse(last_notification_date_, parser);
|
||||||
parse(last_notification_id, parser);
|
parse(last_notification_id_, parser);
|
||||||
parse(max_removed_notification_id, parser);
|
parse(max_removed_notification_id_, parser);
|
||||||
if (parser.version() >= static_cast<int32>(Version::AddNotificationGroupInfoMaxRemovedMessageId)) {
|
if (parser.version() >= static_cast<int32>(Version::AddNotificationGroupInfoMaxRemovedMessageId)) {
|
||||||
parse(max_removed_message_id, parser);
|
parse(max_removed_message_id_, parser);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user