From e5da6a5017f0b401160a38315ecccdc9207c634d Mon Sep 17 00:00:00 2001 From: levlam Date: Sun, 31 Mar 2019 17:13:29 +0300 Subject: [PATCH] Improve updateHavePendingNotifications. GitOrigin-RevId: b4f3701ca9e75a05367d945f1693f742d7f27eb6 --- td/generate/scheme/td_api.tl | 6 +- td/generate/scheme/td_api.tlo | Bin 146984 -> 147040 bytes td/telegram/NotificationManager.cpp | 91 +++++++++++++++++++--------- td/telegram/NotificationManager.h | 11 +++- 4 files changed, 74 insertions(+), 34 deletions(-) diff --git a/td/generate/scheme/td_api.tl b/td/generate/scheme/td_api.tl index 61e674a08..35fc49027 100644 --- a/td/generate/scheme/td_api.tl +++ b/td/generate/scheme/td_api.tl @@ -2416,8 +2416,10 @@ updateNotificationGroup notification_group_id:int32 type:NotificationGroupType c //@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 = Update; -//@description Describes, whether there are some pending notification updates. Can be used to prevent application from killing, while there are some pending notifications @have_pending_notifications True, if there are some pending notification updates, which will be sent soon -updateHavePendingNotifications have_pending_notifications:Bool = Update; +//@description Describes, whether there are some pending notification updates. Can be used to prevent application from killing, while there are some pending notifications +//@have_delayed_notifications True, if there are some delayed notification updates, which will be sent soon +//@have_unreceived_notifications True, if there can be some yet unreceived notifications, which are being fetched from the server +updateHavePendingNotifications have_delayed_notifications:Bool have_unreceived_notifications:Bool = Update; //@description Some messages were deleted @chat_id Chat identifier @message_ids Identifiers of the deleted messages //@is_permanent True, if the messages are permanently deleted by a user (as opposed to just becoming inaccessible) diff --git a/td/generate/scheme/td_api.tlo b/td/generate/scheme/td_api.tlo index 250bf0fc74c51b05694878f081973c8d80bfc7a6..6dc8056a931fe389ba60a8607d3e831cf2fbd1b3 100644 GIT binary patch delta 1724 zcmZ8hPe_wt821?(O9qVy8fB@tgTcZb7A-IxD7Ayo4jx3O+w}W%>gW8No6i69FCG>Q zUh$3aVBjIb;-dm3IxLV7^00$N(INv84@Dk4c<|8nz3=l*+v(Zw`906`d;YxN^HbyA zsZp!1DE#zd#69b-*l<^X)v5oZY70~|OKSnEZV~eXJA+JK;Fik^jSPF@1>413qHiBB zHyFsXfvZ$$1qVs{jErDyg-T|5T49Y@Cjv{ggN=IHpn*A7+jvo$+yW1^_`t&)iVq!n zM9K$l<}mre#;m-iC4uSWBR@1TN<#q3n571=l{JC6+Tk{7ondpKCGE(~;#|d2JNA-I z9AlZPJCNt^K;GMqb85|fP)N)*Wi%o1M(K=f8`UI~voB!@vy3GYGVt|ed$f`D8V5OY z^6@%4&z2&lS_ggKiMfAwVlq9@Rcp`hCEkT4b3VG)1rFAbC3wye3!+04j)cwNXJmKx z*$Q;E8)J9TvD^ckEA=2Z*@LZ_dQq#cBG`-ZE4^UN-xUogaCccju3h1oHoOWf0+Vvs zhi*#<>aXN(vVi|S-z@fi|MjYvsv#)5A+9y+y?*fX*0o?@NcKsx5*U#s`Z5F+B-vba zNk^lhu-qYc56KcynyvY4=Nj|Km z4GUnRX%+ZBGb)s@eoj@Kg?#{b+%$m8ND6FIU`GP8gpub7=Zo3sS{P@vD=hUjIH+?F z1JpsJtPVnuNijtba~(hlIr?iR+Efwki$EzOBqOL=i=gWLY>?PsA^o!rRn#4YaTc*1 z#gr#ea9aQ0){pd?N5xT93Pj|(fT9%S{Iqchb1w=@t1|G%X&%Omu3;3uK8%a_It*!6 zc|C>?HXXx-Sw}GT5DY3;D6o?ee1DEn%;z5kh4In?I~~QZl6wq!kum(XZH-}#<1tua zu}kB~OO0c1#{w&xz&;Waf)~$z7fl%~9-BNf@h5X?rK?7R z7{Lj@HoPe4qKgJz1m1K}5D}v>FWO)iV_wAYVi#UE=wj-3-lOEz>+?R(^FH5q-mh|@ z+P+W~ZH6mfRUe)&*bODS0gRUBKOzo8FRhBhU~E>BW`LuR+6i)Hb;2OU)}6q1HjI8A zU2`zfX5=~%M!+nUT`Ed2j(~|){0MB(>RiFZBj8DV6e$~{@=#)(0#@R7j6~}Ko~i^F zHXABQ^-U*n59KLpH?Wk|ingX;%_)@$FjI=d1A1DC9z4;Og6Z!v@<5#zc~&omSo31m zeJ>=bOYa!+++)bw9mBA79!vBVMo-*+)DHUE;y#fe0Xot= z-fl0c`^;o-96kSzqe=ZTSjpPQwLV970!KA^q;)CU05L3S!R1y}}}vHBX@ z+A!F<8>`qM|GwYua{lUnl_6pn^tW(Hq29gu=lA^^0Z+p368&LcFg!s%hruA#Eb=;a zPhsZz9`4dX=L**RqPz$;+E^ErZy^G2yqw^l>HR?0wCMB1{V!wwXh)+@%n>|sAcE@E z2wv~8g4Gnv6h$5%Mc%T46{9dj)2L&3AH6Y11E#Cfm$>trnM>gU( z=r|5KYFdqBT-`Lc2ZDi{W zTJ5C4L92^2y0aN5Q0ydwyz>m6lbuCuXco_Os9?2O*rVFw9Qsw}@SMBzsIAOHh4K!w z=v>$G#Gb=fbeKbOEeG3_TzD&+O65;lqRD}U=oa9ZHmeIL=w3um`=X3VwX9ak_Gn09 z5p2fGTl^&!%FA2KPYFVEi=~qv95uEq$(K}GUIMfirst.last_notification_date == 0); LOG_CHECK(group_it->second.total_count == 0) - << running_get_difference_ << " " << pending_notification_update_count_ << " " - << pending_updates_[group_id.get()].size() << " " << group_it->first << " " << group_it->second; + << running_get_difference_ << " " << delayed_notification_update_count_ << " " + << unreceived_notification_update_count_ << " " << pending_updates_[group_id.get()].size() << " " + << group_it->first << " " << group_it->second; CHECK(group_it->second.notifications.empty()); CHECK(group_it->second.pending_notifications.empty()); CHECK(!group_it->second.is_being_loaded_from_database); @@ -736,7 +737,7 @@ void NotificationManager::try_reuse_notification_group_id(NotificationGroupId gr flush_pending_notifications_timeout_.cancel_timeout(group_id.get()); flush_pending_updates_timeout_.cancel_timeout(group_id.get()); if (pending_updates_.erase(group_id.get()) == 1) { - on_pending_notification_update_count_changed(-1, group_id.get(), "try_reuse_notification_group_id"); + on_delayed_notification_update_count_changed(-1, group_id.get(), "try_reuse_notification_group_id"); } } @@ -858,7 +859,7 @@ void NotificationManager::add_notification(NotificationGroupId group_id, Notific flush_pending_notifications_timeout_.set_timeout_at(group_id.get(), group.pending_notifications_flush_time); } if (group.pending_notifications.empty()) { - on_pending_notification_update_count_changed(1, group_id.get(), "add_notification"); + on_delayed_notification_update_count_changed(1, group_id.get(), "add_notification"); } group.pending_notifications.push_back(std::move(notification)); } @@ -908,7 +909,7 @@ void NotificationManager::add_update(int32 group_id, td_api::object_ptrtd(), &Td::send_update, std::move(update)); } - on_pending_notification_update_count_changed(-1, group_id, "flush_pending_updates"); + on_delayed_notification_update_count_changed(-1, group_id, "flush_pending_updates"); } void NotificationManager::force_flush_pending_updates(NotificationGroupId group_id, const char *source) { @@ -1498,7 +1499,7 @@ void NotificationManager::flush_pending_notifications(NotificationGroupId group_ group.pending_notifications_flush_time = 0; group.pending_notifications.clear(); - on_pending_notification_update_count_changed(-1, group_id.get(), "flush_pending_notifications"); + on_delayed_notification_update_count_changed(-1, group_id.get(), "flush_pending_notifications"); // if we can delete a lot of notifications simultaneously if (group.notifications.size() > keep_notification_group_size_ + EXTRA_GROUP_SIZE && group.type != NotificationGroupType::Calls) { @@ -1742,7 +1743,7 @@ void NotificationManager::remove_notification(NotificationGroupId group_id, Noti if (group_it->second.pending_notifications.empty()) { group_it->second.pending_notifications_flush_time = 0; flush_pending_notifications_timeout_.cancel_timeout(group_id.get()); - on_pending_notification_update_count_changed(-1, group_id.get(), "remove_notification"); + on_delayed_notification_update_count_changed(-1, group_id.get(), "remove_notification"); } return promise.set_value(Unit()); } @@ -1854,7 +1855,7 @@ void NotificationManager::remove_notification_group(NotificationGroupId group_id if (group_it->second.pending_notifications.empty()) { group_it->second.pending_notifications_flush_time = 0; flush_pending_notifications_timeout_.cancel_timeout(group_id.get()); - on_pending_notification_update_count_changed(-1, group_id.get(), "remove_notification_group"); + on_delayed_notification_update_count_changed(-1, group_id.get(), "remove_notification_group"); } } if (new_total_count != -1) { @@ -1950,7 +1951,7 @@ void NotificationManager::remove_temporary_notifications(NotificationGroupId gro if (group.pending_notifications.empty()) { group.pending_notifications_flush_time = 0; flush_pending_notifications_timeout_.cancel_timeout(group_id.get()); - on_pending_notification_update_count_changed(-1, group_id.get(), "remove_temporary_notifications"); + on_delayed_notification_update_count_changed(-1, group_id.get(), "remove_temporary_notifications"); } } @@ -3251,7 +3252,7 @@ void NotificationManager::before_get_difference() { } running_get_difference_ = true; - on_pending_notification_update_count_changed(1, 0, "before_get_difference"); + on_unreceived_notification_update_count_changed(1, 0, "before_get_difference"); } void NotificationManager::after_get_difference() { @@ -3261,7 +3262,7 @@ void NotificationManager::after_get_difference() { CHECK(running_get_difference_); running_get_difference_ = false; - on_pending_notification_update_count_changed(-1, 0, "after_get_difference"); + on_unreceived_notification_update_count_changed(-1, 0, "after_get_difference"); flush_pending_notifications_timeout_.set_timeout_in(0, MIN_NOTIFICATION_DELAY_MS * 1e-3); } @@ -3297,7 +3298,7 @@ void NotificationManager::before_get_chat_difference(NotificationGroupId group_i VLOG(notifications) << "Before get chat difference in " << group_id; CHECK(group_id.is_valid()); running_get_chat_difference_.insert(group_id.get()); - on_pending_notification_update_count_changed(1, group_id.get(), "before_get_chat_difference"); + on_unreceived_notification_update_count_changed(1, group_id.get(), "before_get_chat_difference"); } void NotificationManager::after_get_chat_difference(NotificationGroupId group_id) { @@ -3310,7 +3311,7 @@ void NotificationManager::after_get_chat_difference(NotificationGroupId group_id auto erased_count = running_get_chat_difference_.erase(group_id.get()); if (erased_count == 1) { flush_pending_notifications_timeout_.set_timeout_in(-group_id.get(), MIN_NOTIFICATION_DELAY_MS * 1e-3); - on_pending_notification_update_count_changed(-1, group_id.get(), "after_get_chat_difference"); + on_unreceived_notification_update_count_changed(-1, group_id.get(), "after_get_chat_difference"); } } @@ -3333,9 +3334,7 @@ void NotificationManager::get_current_state(vector(true)); - } + updates.push_back(get_update_have_pending_notifications()); } void NotificationManager::flush_all_notifications() { @@ -3362,25 +3361,57 @@ void NotificationManager::destroy_all_notifications() { } flush_all_pending_updates(true, "destroy_all_notifications"); - if (pending_notification_update_count_ != 0) { - on_pending_notification_update_count_changed(-pending_notification_update_count_, 0, "destroy_all_notifications"); + if (delayed_notification_update_count_ != 0) { + on_delayed_notification_update_count_changed(-delayed_notification_update_count_, 0, "destroy_all_notifications"); + } + if (unreceived_notification_update_count_ != 0) { + on_unreceived_notification_update_count_changed(-unreceived_notification_update_count_, 0, + "destroy_all_notifications"); } is_destroyed_ = true; } -void NotificationManager::on_pending_notification_update_count_changed(int32 diff, int32 notification_group_id, +td_api::object_ptr NotificationManager::get_update_have_pending_notifications() + const { + return td_api::make_object(delayed_notification_update_count_ != 0, + unreceived_notification_update_count_ != 0); +} + +void NotificationManager::send_update_have_pending_notifications() const { + if (is_destroyed_) { + return; + } + + auto update = get_update_have_pending_notifications(); + VLOG(notifications) << "Send " << oneline(to_string(update)); + send_closure(G()->td(), &Td::send_update, std::move(update)); +} + +void NotificationManager::on_delayed_notification_update_count_changed(int32 diff, int32 notification_group_id, const char *source) { - bool had_pending = pending_notification_update_count_ != 0; - pending_notification_update_count_ += diff; - CHECK(pending_notification_update_count_ >= 0); - VLOG(notifications) << "Update pending notification count with diff " << diff << " to " - << pending_notification_update_count_ << " from group " << notification_group_id << " and " + bool had_delayed = delayed_notification_update_count_ != 0; + delayed_notification_update_count_ += diff; + CHECK(delayed_notification_update_count_ >= 0); + VLOG(notifications) << "Update delayed notification count with diff " << diff << " to " + << delayed_notification_update_count_ << " from group " << notification_group_id << " and " << source; - bool have_pending = pending_notification_update_count_ != 0; - if (had_pending != have_pending && !is_destroyed_) { - auto update = td_api::make_object(have_pending); - VLOG(notifications) << "Send " << oneline(to_string(update)); - send_closure(G()->td(), &Td::send_update, std::move(update)); + bool have_delayed = delayed_notification_update_count_ != 0; + if (had_delayed != have_delayed) { + send_update_have_pending_notifications(); + } +} + +void NotificationManager::on_unreceived_notification_update_count_changed(int32 diff, int32 notification_group_id, + const char *source) { + bool had_unreceived = unreceived_notification_update_count_ != 0; + unreceived_notification_update_count_ += diff; + CHECK(unreceived_notification_update_count_ >= 0); + VLOG(notifications) << "Update unreceived notification count with diff " << diff << " to " + << unreceived_notification_update_count_ << " from group " << notification_group_id << " and " + << source; + bool have_unreceived = unreceived_notification_update_count_ != 0; + if (had_unreceived != have_unreceived) { + send_update_have_pending_notifications(); } } diff --git a/td/telegram/NotificationManager.h b/td/telegram/NotificationManager.h index ed5bb3cc1..9a0c69a44 100644 --- a/td/telegram/NotificationManager.h +++ b/td/telegram/NotificationManager.h @@ -235,6 +235,10 @@ class NotificationManager : public Actor { void try_send_update_active_notifications() const; + void send_update_have_pending_notifications() const; + + td_api::object_ptr get_update_have_pending_notifications() const; + td_api::object_ptr get_update_active_notifications() const; td_api::object_ptr get_remove_group_update( @@ -289,7 +293,9 @@ class NotificationManager : public Actor { void after_get_chat_difference_impl(NotificationGroupId group_id); - void on_pending_notification_update_count_changed(int32 diff, int32 notification_group_id, const char *source); + void on_delayed_notification_update_count_changed(int32 diff, int32 notification_group_id, const char *source); + + void on_unreceived_notification_update_count_changed(int32 diff, int32 notification_group_id, const char *source); static string get_is_contact_registered_notifications_synchronized_key(); @@ -312,7 +318,8 @@ class NotificationManager : public Actor { int32 notification_cloud_delay_ms_ = DEFAULT_ONLINE_CLOUD_DELAY_MS; int32 notification_default_delay_ms_ = DEFAULT_DEFAULT_DELAY_MS; - int32 pending_notification_update_count_ = 0; + int32 delayed_notification_update_count_ = 0; + int32 unreceived_notification_update_count_ = 0; NotificationGroupKey last_loaded_notification_group_key_;