Better notifications logging.
GitOrigin-RevId: 3580e5ed687e5a2435bda175e2b90ea97cb4fb3a
This commit is contained in:
parent
989b984455
commit
949874c953
@ -2221,8 +2221,8 @@ updateNotification notification_group_id:int32 notification:notification = Updat
|
|||||||
|
|
||||||
//@description A list of active notifications in a notification group has changed @notification_group_id Unique notification group identifier @chat_id Identifier of a chat to which all notifications in the group belong
|
//@description A list of active notifications in a notification group has changed @notification_group_id Unique notification group identifier @chat_id Identifier of a chat to which all notifications in the group belong
|
||||||
//@notification_settings_chat_id Chat identifier, which notification settings must be applied @is_silent True, if the notifications should be shown without sound
|
//@notification_settings_chat_id Chat identifier, which notification settings must be applied @is_silent True, if the notifications should be shown without sound
|
||||||
//@total_count Total number of active notifications in the group @new_notifications List of new group notifications @removed_notification_ids Identifiers of removed group notifications
|
//@total_count Total number of active notifications in the group @added_notifications List of added group notifications @removed_notification_ids Identifiers of removed group notifications
|
||||||
updateNotificationGroup notification_group_id:int32 chat_id:int53 notification_settings_chat_id:int53 is_silent:Bool total_count:int32 new_notifications:vector<notification> removed_notification_ids:vector<int32> = Update;
|
updateNotificationGroup notification_group_id:int32 chat_id:int53 notification_settings_chat_id:int53 is_silent:Bool total_count:int32 added_notifications:vector<notification> removed_notification_ids:vector<int32> = Update;
|
||||||
|
|
||||||
//@description Contains active notifications that was shown on previous application launches. This update is sent only if a message database is used. In that case it comes once before any updateNotification and updateNotificationGroup update @groups Lists of active notification groups
|
//@description Contains active notifications that was shown on previous application launches. This update is sent only if a message database is used. In that case it comes once before any updateNotification and updateNotificationGroup update @groups Lists of active notification groups
|
||||||
updateActiveNotifications groups:vector<notificationGroup> = Update;
|
updateActiveNotifications groups:vector<notificationGroup> = Update;
|
||||||
|
Binary file not shown.
@ -180,7 +180,7 @@ void NotificationManager::add_notification(NotificationGroupId group_id, DialogI
|
|||||||
CHECK(type != nullptr);
|
CHECK(type != nullptr);
|
||||||
VLOG(notifications) << "Add " << notification_id << " to " << group_id << " in " << dialog_id
|
VLOG(notifications) << "Add " << notification_id << " to " << group_id << " in " << dialog_id
|
||||||
<< " with settings from " << notification_settings_dialog_id
|
<< " with settings from " << notification_settings_dialog_id
|
||||||
<< (is_silent ? " silent" : " with sound") << ": " << *type;
|
<< (is_silent ? " silently" : " with sound") << ": " << *type;
|
||||||
|
|
||||||
auto group_it = get_group(group_id);
|
auto group_it = get_group(group_id);
|
||||||
if (group_it == groups_.end()) {
|
if (group_it == groups_.end()) {
|
||||||
@ -218,8 +218,45 @@ td_api::object_ptr<td_api::notification> NotificationManager::get_notification_o
|
|||||||
notification.type->get_notification_type_object(dialog_id));
|
notification.type->get_notification_type_object(dialog_id));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct NotificationUpdate {
|
||||||
|
const td_api::Update *update;
|
||||||
|
};
|
||||||
|
|
||||||
|
StringBuilder &operator<<(StringBuilder &string_builder, const NotificationUpdate &update) {
|
||||||
|
if (update.update == nullptr) {
|
||||||
|
return string_builder << "null";
|
||||||
|
}
|
||||||
|
switch (update.update->get_id()) {
|
||||||
|
case td_api::updateNotification::ID: {
|
||||||
|
auto p = static_cast<const td_api::updateNotification *>(update.update);
|
||||||
|
return string_builder << "update[" << NotificationId(p->notification_->id_) << " from "
|
||||||
|
<< NotificationGroupId(p->notification_group_id_) << ']';
|
||||||
|
}
|
||||||
|
case td_api::updateNotificationGroup::ID: {
|
||||||
|
auto p = static_cast<const td_api::updateNotificationGroup *>(update.update);
|
||||||
|
vector<int32> added_notification_ids;
|
||||||
|
for (auto ¬ification : p->added_notifications_) {
|
||||||
|
added_notification_ids.push_back(notification->id_);
|
||||||
|
}
|
||||||
|
|
||||||
|
return string_builder << "update[" << NotificationGroupId(p->notification_group_id_) << " from "
|
||||||
|
<< DialogId(p->chat_id_) << " with settings from "
|
||||||
|
<< DialogId(p->notification_settings_chat_id_)
|
||||||
|
<< (p->is_silent_ ? " silently" : " with sound") << "; total_count = " << p->total_count_
|
||||||
|
<< ", add " << added_notification_ids << ", remove " << p->removed_notification_ids_;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
UNREACHABLE();
|
||||||
|
return string_builder << "unknown";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
NotificationUpdate as_notification_update(const td_api::Update *update) {
|
||||||
|
return NotificationUpdate{update};
|
||||||
|
}
|
||||||
|
|
||||||
void NotificationManager::add_update(int32 group_id, td_api::object_ptr<td_api::Update> update) {
|
void NotificationManager::add_update(int32 group_id, td_api::object_ptr<td_api::Update> update) {
|
||||||
VLOG(notifications) << "Add " << to_string(update);
|
VLOG(notifications) << "Add " << as_notification_update(update.get());
|
||||||
pending_updates_[group_id].push_back(std::move(update));
|
pending_updates_[group_id].push_back(std::move(update));
|
||||||
if (!running_get_difference_ && running_get_chat_difference_.count(group_id) == 0) {
|
if (!running_get_difference_ && running_get_chat_difference_.count(group_id) == 0) {
|
||||||
flush_pending_updates_timeout_.add_timeout_in(group_id, MIN_UPDATE_DELAY_MS * 1e-3);
|
flush_pending_updates_timeout_.add_timeout_in(group_id, MIN_UPDATE_DELAY_MS * 1e-3);
|
||||||
@ -253,11 +290,11 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
VLOG(notifications) << "Send pending updates in " << NotificationGroupId(group_id);
|
|
||||||
|
|
||||||
auto updates = std::move(it->second);
|
auto updates = std::move(it->second);
|
||||||
pending_updates_.erase(it);
|
pending_updates_.erase(it);
|
||||||
|
|
||||||
|
VLOG(notifications) << "Send " << updates.size() << " pending updates in " << NotificationGroupId(group_id);
|
||||||
|
|
||||||
bool is_changed = true;
|
bool is_changed = true;
|
||||||
while (is_changed) {
|
while (is_changed) {
|
||||||
is_changed = false;
|
is_changed = false;
|
||||||
@ -267,10 +304,10 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
if (update->get_id() == td_api::updateNotificationGroup::ID) {
|
if (update->get_id() == td_api::updateNotificationGroup::ID) {
|
||||||
auto update_ptr = static_cast<td_api::updateNotificationGroup *>(update.get());
|
auto update_ptr = static_cast<td_api::updateNotificationGroup *>(update.get());
|
||||||
bool is_deletion = !update_ptr->removed_notification_ids_.empty() &&
|
bool is_deletion = !update_ptr->removed_notification_ids_.empty() &&
|
||||||
(update_ptr->new_notifications_.empty() ||
|
(update_ptr->added_notifications_.empty() ||
|
||||||
update_ptr->new_notifications_.back()->id_ < update_ptr->removed_notification_ids_[0]);
|
update_ptr->added_notifications_.back()->id_ < update_ptr->removed_notification_ids_[0]);
|
||||||
|
|
||||||
for (auto ¬ification : update_ptr->new_notifications_) {
|
for (auto ¬ification : update_ptr->added_notifications_) {
|
||||||
auto notification_id = notification->id_;
|
auto notification_id = notification->id_;
|
||||||
auto &pos = notification_pos[notification_id];
|
auto &pos = notification_pos[notification_id];
|
||||||
CHECK(pos < cur_pos);
|
CHECK(pos < cur_pos);
|
||||||
@ -293,16 +330,17 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
auto previous_update_ptr = static_cast<td_api::updateNotificationGroup *>(previous_update.get());
|
auto previous_update_ptr = static_cast<td_api::updateNotificationGroup *>(previous_update.get());
|
||||||
bool found = false;
|
bool found = false;
|
||||||
size_t i = 0;
|
size_t i = 0;
|
||||||
for (auto ¬ification : previous_update_ptr->new_notifications_) {
|
for (auto ¬ification : previous_update_ptr->added_notifications_) {
|
||||||
if (notification->id_ == notification_id) {
|
if (notification->id_ == notification_id) {
|
||||||
previous_update_ptr->new_notifications_.erase(previous_update_ptr->new_notifications_.begin() + i);
|
previous_update_ptr->added_notifications_.erase(previous_update_ptr->added_notifications_.begin() +
|
||||||
|
i);
|
||||||
found = true;
|
found = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
CHECK(found); // there should be no deletions without previous addition
|
CHECK(found); // there should be no deletions without previous addition
|
||||||
if (previous_update_ptr->new_notifications_.empty()) {
|
if (previous_update_ptr->added_notifications_.empty()) {
|
||||||
if (previous_update_ptr->removed_notification_ids_.empty()) {
|
if (previous_update_ptr->removed_notification_ids_.empty()) {
|
||||||
previous_update = nullptr;
|
previous_update = nullptr;
|
||||||
} else {
|
} else {
|
||||||
@ -325,7 +363,7 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
std::remove_if(update_ptr->removed_notification_ids_.begin(), update_ptr->removed_notification_ids_.end(),
|
std::remove_if(update_ptr->removed_notification_ids_.begin(), update_ptr->removed_notification_ids_.end(),
|
||||||
[](auto ¬ification_id) { return notification_id == 0; }),
|
[](auto ¬ification_id) { return notification_id == 0; }),
|
||||||
update_ptr->removed_notification_ids_.end());
|
update_ptr->removed_notification_ids_.end());
|
||||||
if (update_ptr->removed_notification_ids_.empty() && update_ptr->new_notifications_.empty()) {
|
if (update_ptr->removed_notification_ids_.empty() && update_ptr->added_notifications_.empty()) {
|
||||||
for (size_t i = cur_pos - 1; i > 0; i--) {
|
for (size_t i = cur_pos - 1; i > 0; i--) {
|
||||||
if (updates[i - 1] != nullptr && updates[i - 1]->get_id() == td_api::updateNotificationGroup::ID) {
|
if (updates[i - 1] != nullptr && updates[i - 1]->get_id() == td_api::updateNotificationGroup::ID) {
|
||||||
auto previous_update_ptr = static_cast<td_api::updateNotificationGroup *>(updates[i - 1].get());
|
auto previous_update_ptr = static_cast<td_api::updateNotificationGroup *>(updates[i - 1].get());
|
||||||
@ -354,7 +392,7 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
if (previous_update->get_id() == td_api::updateNotificationGroup::ID) {
|
if (previous_update->get_id() == td_api::updateNotificationGroup::ID) {
|
||||||
auto previous_update_ptr = static_cast<td_api::updateNotificationGroup *>(previous_update.get());
|
auto previous_update_ptr = static_cast<td_api::updateNotificationGroup *>(previous_update.get());
|
||||||
bool found = false;
|
bool found = false;
|
||||||
for (auto ¬ification : previous_update_ptr->new_notifications_) {
|
for (auto ¬ification : previous_update_ptr->added_notifications_) {
|
||||||
if (notification->id_ == notification_id) {
|
if (notification->id_ == notification_id) {
|
||||||
notification->type_ = std::move(type);
|
notification->type_ = std::move(type);
|
||||||
found = true;
|
found = true;
|
||||||
@ -378,6 +416,7 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
updates.erase(std::remove_if(updates.begin(), updates.end(), [](auto &update) { return update == nullptr; }),
|
updates.erase(std::remove_if(updates.begin(), updates.end(), [](auto &update) { return update == nullptr; }),
|
||||||
updates.end());
|
updates.end());
|
||||||
if (updates.empty()) {
|
if (updates.empty()) {
|
||||||
|
VLOG(notifications) << "There are no updates to send in " << NotificationGroupId(group_id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -389,14 +428,15 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
auto update_ptr = static_cast<td_api::updateNotificationGroup *>(updates[i].get());
|
auto update_ptr = static_cast<td_api::updateNotificationGroup *>(updates[i].get());
|
||||||
if (last_update_ptr->notification_settings_chat_id_ == update_ptr->notification_settings_chat_id_ &&
|
if (last_update_ptr->notification_settings_chat_id_ == update_ptr->notification_settings_chat_id_ &&
|
||||||
last_update_ptr->is_silent_ == update_ptr->is_silent_) {
|
last_update_ptr->is_silent_ == update_ptr->is_silent_) {
|
||||||
if ((last_update_ptr->new_notifications_.empty() && update_ptr->new_notifications_.empty()) ||
|
if ((last_update_ptr->added_notifications_.empty() && update_ptr->added_notifications_.empty()) ||
|
||||||
(last_update_ptr->removed_notification_ids_.empty() && update_ptr->removed_notification_ids_.empty())) {
|
(last_update_ptr->removed_notification_ids_.empty() && update_ptr->removed_notification_ids_.empty())) {
|
||||||
// combine updates
|
// combine updates
|
||||||
VLOG(notifications) << "Combine " << to_string(*last_update_ptr) << " and " << to_string(*update_ptr);
|
VLOG(notifications) << "Combine " << as_notification_update(last_update_ptr) << " and "
|
||||||
|
<< as_notification_update(update_ptr);
|
||||||
CHECK(last_update_ptr->notification_group_id_ == update_ptr->notification_group_id_);
|
CHECK(last_update_ptr->notification_group_id_ == update_ptr->notification_group_id_);
|
||||||
CHECK(last_update_ptr->chat_id_ == update_ptr->chat_id_);
|
CHECK(last_update_ptr->chat_id_ == update_ptr->chat_id_);
|
||||||
last_update_ptr->total_count_ = update_ptr->total_count_;
|
last_update_ptr->total_count_ = update_ptr->total_count_;
|
||||||
append(last_update_ptr->new_notifications_, std::move(update_ptr->new_notifications_));
|
append(last_update_ptr->added_notifications_, std::move(update_ptr->added_notifications_));
|
||||||
append(last_update_ptr->removed_notification_ids_, std::move(update_ptr->removed_notification_ids_));
|
append(last_update_ptr->removed_notification_ids_, std::move(update_ptr->removed_notification_ids_));
|
||||||
updates[i] = nullptr;
|
updates[i] = nullptr;
|
||||||
is_changed = true;
|
is_changed = true;
|
||||||
@ -413,7 +453,7 @@ void NotificationManager::flush_pending_updates(int32 group_id) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (auto &update : updates) {
|
for (auto &update : updates) {
|
||||||
VLOG(notifications) << "Send " << to_string(update);
|
VLOG(notifications) << "Send " << as_notification_update(update.get());
|
||||||
send_closure(G()->td(), &Td::send_update, std::move(update));
|
send_closure(G()->td(), &Td::send_update, std::move(update));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -932,13 +972,13 @@ void NotificationManager::after_get_difference() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void NotificationManager::before_get_chat_difference(NotificationGroupId group_id) {
|
void NotificationManager::before_get_chat_difference(NotificationGroupId group_id) {
|
||||||
VLOG(notifications) << "Before get chat diference in " << group_id;
|
VLOG(notifications) << "Before get chat difference in " << group_id;
|
||||||
bool is_inserted = running_get_chat_difference_.insert(group_id.get()).second;
|
bool is_inserted = running_get_chat_difference_.insert(group_id.get()).second;
|
||||||
CHECK(is_inserted);
|
CHECK(is_inserted);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationManager::after_get_chat_difference(NotificationGroupId group_id) {
|
void NotificationManager::after_get_chat_difference(NotificationGroupId group_id) {
|
||||||
VLOG(notifications) << "After get chat diference in " << group_id;
|
VLOG(notifications) << "After get chat difference in " << group_id;
|
||||||
auto erased_count = running_get_chat_difference_.erase(group_id.get());
|
auto erased_count = running_get_chat_difference_.erase(group_id.get());
|
||||||
if (erased_count == 1 && !running_get_difference_ && pending_updates_.count(group_id.get()) == 1) {
|
if (erased_count == 1 && !running_get_difference_ && pending_updates_.count(group_id.get()) == 1) {
|
||||||
flush_pending_updates_timeout_.cancel_timeout(group_id.get());
|
flush_pending_updates_timeout_.cancel_timeout(group_id.get());
|
||||||
|
Reference in New Issue
Block a user