Add last_notification_date to database.
GitOrigin-RevId: 1ae7310f0ec89a832e8081255c6cbca864c3ecc2
This commit is contained in:
parent
4cb4ad949e
commit
d82e9b1b2c
@ -3801,6 +3801,7 @@ void MessagesManager::Dialog::store(StorerT &storer) const {
|
|||||||
bool has_last_clear_history_message_id = last_clear_history_message_id.is_valid();
|
bool has_last_clear_history_message_id = last_clear_history_message_id.is_valid();
|
||||||
bool has_last_database_message_id = !has_last_database_message && last_database_message_id.is_valid();
|
bool has_last_database_message_id = !has_last_database_message && last_database_message_id.is_valid();
|
||||||
bool has_message_notification_group_id = message_notification_group_id.is_valid();
|
bool has_message_notification_group_id = message_notification_group_id.is_valid();
|
||||||
|
bool has_last_notification_date = last_notification_date > 0;
|
||||||
BEGIN_STORE_FLAGS();
|
BEGIN_STORE_FLAGS();
|
||||||
STORE_FLAG(has_draft_message);
|
STORE_FLAG(has_draft_message);
|
||||||
STORE_FLAG(has_last_database_message);
|
STORE_FLAG(has_last_database_message);
|
||||||
@ -3825,7 +3826,8 @@ void MessagesManager::Dialog::store(StorerT &storer) const {
|
|||||||
STORE_FLAG(has_last_database_message_id);
|
STORE_FLAG(has_last_database_message_id);
|
||||||
STORE_FLAG(need_repair_server_unread_count);
|
STORE_FLAG(need_repair_server_unread_count);
|
||||||
STORE_FLAG(is_marked_as_unread);
|
STORE_FLAG(is_marked_as_unread);
|
||||||
STORE_FLAG(has_message_notification_group_id); // 23
|
STORE_FLAG(has_message_notification_group_id);
|
||||||
|
STORE_FLAG(has_last_notification_date); // 24
|
||||||
END_STORE_FLAGS();
|
END_STORE_FLAGS();
|
||||||
|
|
||||||
store(dialog_id, storer); // must be stored at offset 4
|
store(dialog_id, storer); // must be stored at offset 4
|
||||||
@ -3887,6 +3889,9 @@ void MessagesManager::Dialog::store(StorerT &storer) const {
|
|||||||
if (has_message_notification_group_id) {
|
if (has_message_notification_group_id) {
|
||||||
store(message_notification_group_id, storer);
|
store(message_notification_group_id, storer);
|
||||||
}
|
}
|
||||||
|
if (has_last_notification_date) {
|
||||||
|
store(last_notification_date, storer);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// do not forget to resolve dialog dependencies including dependencies of last_message
|
// do not forget to resolve dialog dependencies including dependencies of last_message
|
||||||
@ -3907,6 +3912,7 @@ void MessagesManager::Dialog::parse(ParserT &parser) {
|
|||||||
bool has_last_clear_history_message_id;
|
bool has_last_clear_history_message_id;
|
||||||
bool has_last_database_message_id;
|
bool has_last_database_message_id;
|
||||||
bool has_message_notification_group_id;
|
bool has_message_notification_group_id;
|
||||||
|
bool has_last_notification_date;
|
||||||
BEGIN_PARSE_FLAGS();
|
BEGIN_PARSE_FLAGS();
|
||||||
PARSE_FLAG(has_draft_message);
|
PARSE_FLAG(has_draft_message);
|
||||||
PARSE_FLAG(has_last_database_message);
|
PARSE_FLAG(has_last_database_message);
|
||||||
@ -3932,6 +3938,7 @@ void MessagesManager::Dialog::parse(ParserT &parser) {
|
|||||||
PARSE_FLAG(need_repair_server_unread_count);
|
PARSE_FLAG(need_repair_server_unread_count);
|
||||||
PARSE_FLAG(is_marked_as_unread);
|
PARSE_FLAG(is_marked_as_unread);
|
||||||
PARSE_FLAG(has_message_notification_group_id);
|
PARSE_FLAG(has_message_notification_group_id);
|
||||||
|
PARSE_FLAG(has_last_notification_date);
|
||||||
END_PARSE_FLAGS();
|
END_PARSE_FLAGS();
|
||||||
|
|
||||||
parse(dialog_id, parser); // must be stored at offset 4
|
parse(dialog_id, parser); // must be stored at offset 4
|
||||||
@ -4017,6 +4024,9 @@ void MessagesManager::Dialog::parse(ParserT &parser) {
|
|||||||
if (has_message_notification_group_id) {
|
if (has_message_notification_group_id) {
|
||||||
parse(message_notification_group_id, parser);
|
parse(message_notification_group_id, parser);
|
||||||
}
|
}
|
||||||
|
if (has_last_notification_date) {
|
||||||
|
parse(last_notification_date, parser);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
template <class StorerT>
|
template <class StorerT>
|
||||||
@ -4255,7 +4265,7 @@ void MessagesManager::save_dialog_to_database(DialogId dialog_id) {
|
|||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
LOG(INFO) << "Save " << dialog_id << " to database";
|
LOG(INFO) << "Save " << dialog_id << " to database";
|
||||||
G()->td_db()->get_dialog_db_async()->add_dialog(
|
G()->td_db()->get_dialog_db_async()->add_dialog(
|
||||||
dialog_id, d->order, 0 /*TODO: last_notification_date*/, get_dialog_database_value(d),
|
dialog_id, d->order, d->last_notification_date, get_dialog_database_value(d),
|
||||||
PromiseCreator::lambda([dialog_id](Result<> result) {
|
PromiseCreator::lambda([dialog_id](Result<> result) {
|
||||||
send_closure(G()->messages_manager(), &MessagesManager::on_save_dialog_to_database, dialog_id, result.is_ok());
|
send_closure(G()->messages_manager(), &MessagesManager::on_save_dialog_to_database, dialog_id, result.is_ok());
|
||||||
}));
|
}));
|
||||||
@ -9788,6 +9798,13 @@ void MessagesManager::try_restore_dialog_reply_markup(Dialog *d, const Message *
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MessagesManager::set_dialog_last_notification_date(Dialog *d, int32 last_notification_date) {
|
||||||
|
if (last_notification_date != d->last_notification_date) {
|
||||||
|
d->last_notification_date = last_notification_date;
|
||||||
|
on_dialog_updated(d->dialog_id, "set_dialog_last_notification_date");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void MessagesManager::on_update_sent_text_message(int64 random_id,
|
void MessagesManager::on_update_sent_text_message(int64 random_id,
|
||||||
tl_object_ptr<telegram_api::MessageMedia> message_media,
|
tl_object_ptr<telegram_api::MessageMedia> message_media,
|
||||||
vector<tl_object_ptr<telegram_api::MessageEntity>> &&entities) {
|
vector<tl_object_ptr<telegram_api::MessageEntity>> &&entities) {
|
||||||
@ -17442,6 +17459,7 @@ void MessagesManager::add_new_message_notification(Dialog *d, Message *m, bool f
|
|||||||
<< ", but forced to send notification about " << m->message_id << " in "
|
<< ", but forced to send notification about " << m->message_id << " in "
|
||||||
<< d->dialog_id;
|
<< d->dialog_id;
|
||||||
m->notification_id = td_->notification_manager_->get_next_notification_id();
|
m->notification_id = td_->notification_manager_->get_next_notification_id();
|
||||||
|
set_dialog_last_notification_date(d, m->date);
|
||||||
VLOG(notifications) << "Assign " << m->notification_id << " to " << m->message_id << " in " << d->dialog_id;
|
VLOG(notifications) << "Assign " << m->notification_id << " to " << m->message_id << " in " << d->dialog_id;
|
||||||
send_closure_later(G()->notification_manager(), &NotificationManager::add_notification,
|
send_closure_later(G()->notification_manager(), &NotificationManager::add_notification,
|
||||||
get_dialog_message_notification_group_id(d), d->dialog_id, settings_dialog_id,
|
get_dialog_message_notification_group_id(d), d->dialog_id, settings_dialog_id,
|
||||||
@ -20715,6 +20733,16 @@ void MessagesManager::update_message(Dialog *d, unique_ptr<Message> &old_message
|
|||||||
is_changed = true;
|
is_changed = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (old_message->notification_id != new_message->notification_id) {
|
||||||
|
if (old_message->notification_id.is_valid()) {
|
||||||
|
if (new_message->notification_id.is_valid()) {
|
||||||
|
LOG(ERROR) << "Notification id for " << message_id << " in " << dialog_id << " has tried to change from "
|
||||||
|
<< old_message->notification_id << " to " << new_message->notification_id;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
old_message->notification_id = new_message->notification_id;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (old_message->reply_to_message_id != new_message->reply_to_message_id) {
|
if (old_message->reply_to_message_id != new_message->reply_to_message_id) {
|
||||||
// Can't check "&& get_message_force(d, old_message->reply_to_message_id) == nullptr", because it
|
// Can't check "&& get_message_force(d, old_message->reply_to_message_id) == nullptr", because it
|
||||||
|
@ -867,6 +867,7 @@ class MessagesManager : public Actor {
|
|||||||
MessageId max_added_message_id;
|
MessageId max_added_message_id;
|
||||||
|
|
||||||
NotificationGroupId message_notification_group_id;
|
NotificationGroupId message_notification_group_id;
|
||||||
|
int32 last_notification_date = 0;
|
||||||
|
|
||||||
bool has_contact_registered_message = false;
|
bool has_contact_registered_message = false;
|
||||||
|
|
||||||
@ -1543,6 +1544,8 @@ class MessagesManager : public Actor {
|
|||||||
|
|
||||||
void try_restore_dialog_reply_markup(Dialog *d, const Message *m);
|
void try_restore_dialog_reply_markup(Dialog *d, const Message *m);
|
||||||
|
|
||||||
|
void set_dialog_last_notification_date(Dialog *d, int32 last_notification_date);
|
||||||
|
|
||||||
static string get_notification_settings_scope_database_key(NotificationSettingsScope scope);
|
static string get_notification_settings_scope_database_key(NotificationSettingsScope scope);
|
||||||
|
|
||||||
void save_scope_notification_settings(NotificationSettingsScope scope, const ScopeNotificationSettings &new_settings);
|
void save_scope_notification_settings(NotificationSettingsScope scope, const ScopeNotificationSettings &new_settings);
|
||||||
|
@ -36,6 +36,10 @@ class NotificationGroupId {
|
|||||||
return id == other.id;
|
return id == other.id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool operator!=(const NotificationGroupId &other) const {
|
||||||
|
return id != other.id;
|
||||||
|
}
|
||||||
|
|
||||||
template <class StorerT>
|
template <class StorerT>
|
||||||
void store(StorerT &storer) const {
|
void store(StorerT &storer) const {
|
||||||
storer.store_int(id);
|
storer.store_int(id);
|
||||||
|
@ -36,6 +36,10 @@ class NotificationId {
|
|||||||
return id == other.id;
|
return id == other.id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool operator!=(const NotificationId &other) const {
|
||||||
|
return id != other.id;
|
||||||
|
}
|
||||||
|
|
||||||
template <class StorerT>
|
template <class StorerT>
|
||||||
void store(StorerT &storer) const {
|
void store(StorerT &storer) const {
|
||||||
storer.store_int(id);
|
storer.store_int(id);
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
//
|
//
|
||||||
#include "td/telegram/NotificationManager.h"
|
#include "td/telegram/NotificationManager.h"
|
||||||
|
|
||||||
|
#include "td/telegram/AuthManager.h"
|
||||||
|
#include "td/telegram/ConfigShared.h"
|
||||||
#include "td/telegram/Global.h"
|
#include "td/telegram/Global.h"
|
||||||
#include "td/telegram/Td.h"
|
#include "td/telegram/Td.h"
|
||||||
#include "td/telegram/TdDb.h"
|
#include "td/telegram/TdDb.h"
|
||||||
@ -17,11 +19,27 @@ int VERBOSITY_NAME(notifications) = VERBOSITY_NAME(WARNING);
|
|||||||
NotificationManager::NotificationManager(Td *td, ActorShared<> parent) : td_(td), parent_(std::move(parent)) {
|
NotificationManager::NotificationManager(Td *td, ActorShared<> parent) : td_(td), parent_(std::move(parent)) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool NotificationManager::is_disabled() const {
|
||||||
|
LOG(ERROR) << "IS DISABLED";
|
||||||
|
return td_->auth_manager_->is_bot();
|
||||||
|
}
|
||||||
|
|
||||||
void NotificationManager::start_up() {
|
void NotificationManager::start_up() {
|
||||||
|
if (is_disabled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
current_notification_id_ =
|
current_notification_id_ =
|
||||||
NotificationId(to_integer<int32>(G()->td_db()->get_binlog_pmc()->get("notification_id_current")));
|
NotificationId(to_integer<int32>(G()->td_db()->get_binlog_pmc()->get("notification_id_current")));
|
||||||
current_notification_group_id_ =
|
current_notification_group_id_ =
|
||||||
NotificationGroupId(to_integer<int32>(G()->td_db()->get_binlog_pmc()->get("notification_group_id_current")));
|
NotificationGroupId(to_integer<int32>(G()->td_db()->get_binlog_pmc()->get("notification_group_id_current")));
|
||||||
|
|
||||||
|
max_notification_group_count_ =
|
||||||
|
G()->shared_config().get_option_integer("notification_group_count_max", DEFAULT_NOTIFICATION_GROUP_COUNT_MAX);
|
||||||
|
max_notification_group_size_ =
|
||||||
|
G()->shared_config().get_option_integer("notification_group_size_max", DEFAULT_NOTIFICATION_GROUP_SIZE_MAX);
|
||||||
|
|
||||||
|
// TODO load groups
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationManager::tear_down() {
|
void NotificationManager::tear_down() {
|
||||||
@ -29,12 +47,20 @@ void NotificationManager::tear_down() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
NotificationId NotificationManager::get_next_notification_id() {
|
NotificationId NotificationManager::get_next_notification_id() {
|
||||||
|
if (is_disabled()) {
|
||||||
|
return NotificationId();
|
||||||
|
}
|
||||||
|
|
||||||
current_notification_id_ = NotificationId(current_notification_id_.get() % 0x7FFFFFFF + 1);
|
current_notification_id_ = NotificationId(current_notification_id_.get() % 0x7FFFFFFF + 1);
|
||||||
G()->td_db()->get_binlog_pmc()->set("notification_id_current", to_string(current_notification_id_.get()));
|
G()->td_db()->get_binlog_pmc()->set("notification_id_current", to_string(current_notification_id_.get()));
|
||||||
return current_notification_id_;
|
return current_notification_id_;
|
||||||
}
|
}
|
||||||
|
|
||||||
NotificationGroupId NotificationManager::get_next_notification_group_id() {
|
NotificationGroupId NotificationManager::get_next_notification_group_id() {
|
||||||
|
if (is_disabled()) {
|
||||||
|
return NotificationGroupId();
|
||||||
|
}
|
||||||
|
|
||||||
current_notification_group_id_ = NotificationGroupId(current_notification_group_id_.get() % 0x7FFFFFFF + 1);
|
current_notification_group_id_ = NotificationGroupId(current_notification_group_id_.get() % 0x7FFFFFFF + 1);
|
||||||
G()->td_db()->get_binlog_pmc()->set("notification_group_id_current", to_string(current_notification_group_id_.get()));
|
G()->td_db()->get_binlog_pmc()->set("notification_group_id_current", to_string(current_notification_group_id_.get()));
|
||||||
return current_notification_group_id_;
|
return current_notification_group_id_;
|
||||||
@ -43,6 +69,10 @@ NotificationGroupId NotificationManager::get_next_notification_group_id() {
|
|||||||
void NotificationManager::add_notification(NotificationGroupId group_id, DialogId dialog_id,
|
void NotificationManager::add_notification(NotificationGroupId group_id, DialogId dialog_id,
|
||||||
DialogId notification_settings_dialog_id, bool silent,
|
DialogId notification_settings_dialog_id, bool silent,
|
||||||
NotificationId notification_id, unique_ptr<NotificationType> type) {
|
NotificationId notification_id, unique_ptr<NotificationType> type) {
|
||||||
|
if (is_disabled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
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
|
||||||
@ -51,10 +81,17 @@ void NotificationManager::add_notification(NotificationGroupId group_id, DialogI
|
|||||||
}
|
}
|
||||||
|
|
||||||
void NotificationManager::edit_notification(NotificationId notification_id, unique_ptr<NotificationType> type) {
|
void NotificationManager::edit_notification(NotificationId notification_id, unique_ptr<NotificationType> type) {
|
||||||
|
if (is_disabled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
VLOG(notifications) << "Edit " << notification_id << ": " << *type;
|
VLOG(notifications) << "Edit " << notification_id << ": " << *type;
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationManager::delete_notification(NotificationId notification_id) {
|
void NotificationManager::delete_notification(NotificationId notification_id) {
|
||||||
|
if (is_disabled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void NotificationManager::remove_notification(NotificationId notification_id, Promise<Unit> &&promise) {
|
void NotificationManager::remove_notification(NotificationId notification_id, Promise<Unit> &&promise) {
|
||||||
@ -62,6 +99,10 @@ void NotificationManager::remove_notification(NotificationId notification_id, Pr
|
|||||||
return promise.set_error(Status::Error(400, "Notification identifier is invalid"));
|
return promise.set_error(Status::Error(400, "Notification identifier is invalid"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (is_disabled()) {
|
||||||
|
return promise.set_value(Unit());
|
||||||
|
}
|
||||||
|
|
||||||
// TODO update total_count
|
// TODO update total_count
|
||||||
promise.set_value(Unit());
|
promise.set_value(Unit());
|
||||||
}
|
}
|
||||||
@ -75,6 +116,10 @@ void NotificationManager::remove_notification_group(NotificationGroupId group_id
|
|||||||
return promise.set_error(Status::Error(400, "Notification identifier is invalid"));
|
return promise.set_error(Status::Error(400, "Notification identifier is invalid"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (is_disabled()) {
|
||||||
|
return promise.set_value(Unit());
|
||||||
|
}
|
||||||
|
|
||||||
// TODO update total_count
|
// TODO update total_count
|
||||||
promise.set_value(Unit());
|
promise.set_value(Unit());
|
||||||
}
|
}
|
||||||
|
@ -43,12 +43,40 @@ class NotificationManager : public Actor {
|
|||||||
Promise<Unit> &&promise);
|
Promise<Unit> &&promise);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
struct Notification {
|
||||||
|
NotificationId notification_id;
|
||||||
|
unique_ptr<NotificationType> type;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct PendingNotification {
|
||||||
|
DialogId settings_dialog_id;
|
||||||
|
bool silent = false;
|
||||||
|
NotificationId notification_id;
|
||||||
|
unique_ptr<NotificationType> type;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct NotificationGroup {
|
||||||
|
DialogId dialog_id;
|
||||||
|
int32 total_count = 0;
|
||||||
|
|
||||||
|
vector<Notification> notifications;
|
||||||
|
vector<PendingNotification> pending_notifications;
|
||||||
|
};
|
||||||
|
|
||||||
|
bool is_disabled() const;
|
||||||
|
|
||||||
void start_up() override;
|
void start_up() override;
|
||||||
void tear_down() override;
|
void tear_down() override;
|
||||||
|
|
||||||
NotificationId current_notification_id_;
|
NotificationId current_notification_id_;
|
||||||
NotificationGroupId current_notification_group_id_;
|
NotificationGroupId current_notification_group_id_;
|
||||||
|
|
||||||
|
static constexpr int32 DEFAULT_NOTIFICATION_GROUP_COUNT_MAX = 10;
|
||||||
|
static constexpr int32 DEFAULT_NOTIFICATION_GROUP_SIZE_MAX = 10;
|
||||||
|
|
||||||
|
int32 max_notification_group_count_;
|
||||||
|
int32 max_notification_group_size_;
|
||||||
|
|
||||||
Td *td_;
|
Td *td_;
|
||||||
ActorShared<> parent_;
|
ActorShared<> parent_;
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user