Add need_message_push_notification.
GitOrigin-RevId: 05ea09c326cc779b3eb57e574f6bdb8771bbb239
This commit is contained in:
parent
6888403d61
commit
29e7c2b690
@ -18174,6 +18174,41 @@ NotificationGroupId MessagesManager::get_dialog_notification_group_id(DialogId d
|
|||||||
return group_info.group_id;
|
return group_info.group_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool MessagesManager::need_message_push_notification(DialogId dialog_id, MessageId message_id, int64 random_id,
|
||||||
|
bool &contains_mention, bool is_pinned) {
|
||||||
|
init();
|
||||||
|
|
||||||
|
Dialog *d = get_dialog_force(dialog_id);
|
||||||
|
if (d == nullptr) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (message_id.is_valid() && message_id.get() <= d->last_new_message_id.get()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (random_id != 0) {
|
||||||
|
CHECK(dialog_id.get_type() == DialogType::SecretChat);
|
||||||
|
if (get_message_id_by_random_id(d, random_id, "need_message_push_notification").is_valid()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (dialog_id == get_my_dialog_id() || td_->auth_manager_->is_bot()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_dialog_message_notification_disabled(dialog_id, G()->unix_time())) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_pinned && is_dialog_pinned_message_notifications_disabled(d)) {
|
||||||
|
contains_mention = false;
|
||||||
|
}
|
||||||
|
if (contains_mention && is_dialog_mention_notifications_disabled(d)) {
|
||||||
|
contains_mention = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
NotificationId MessagesManager::get_next_notification_id(Dialog *d, NotificationGroupId notification_group_id,
|
NotificationId MessagesManager::get_next_notification_id(Dialog *d, NotificationGroupId notification_group_id,
|
||||||
MessageId message_id) {
|
MessageId message_id) {
|
||||||
NotificationId notification_id;
|
NotificationId notification_id;
|
||||||
@ -18789,22 +18824,26 @@ bool MessagesManager::is_message_notification_disabled(const Dialog *d, const Me
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (d->dialog_id.get_type()) {
|
return is_dialog_message_notification_disabled(d->dialog_id, m->date);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool MessagesManager::is_dialog_message_notification_disabled(DialogId dialog_id, int32 message_date) const {
|
||||||
|
switch (dialog_id.get_type()) {
|
||||||
case DialogType::User:
|
case DialogType::User:
|
||||||
break;
|
break;
|
||||||
case DialogType::Chat:
|
case DialogType::Chat:
|
||||||
if (!td_->contacts_manager_->get_chat_is_active(d->dialog_id.get_chat_id())) {
|
if (!td_->contacts_manager_->get_chat_is_active(dialog_id.get_chat_id())) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case DialogType::Channel:
|
case DialogType::Channel:
|
||||||
if (!td_->contacts_manager_->get_channel_status(d->dialog_id.get_channel_id()).is_member() ||
|
if (!td_->contacts_manager_->get_channel_status(dialog_id.get_channel_id()).is_member() ||
|
||||||
m->date < td_->contacts_manager_->get_channel_date(d->dialog_id.get_channel_id())) {
|
message_date < td_->contacts_manager_->get_channel_date(dialog_id.get_channel_id())) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case DialogType::SecretChat:
|
case DialogType::SecretChat:
|
||||||
if (td_->contacts_manager_->get_secret_chat_state(d->dialog_id.get_secret_chat_id()) == SecretChatState::Closed) {
|
if (td_->contacts_manager_->get_secret_chat_state(dialog_id.get_secret_chat_id()) == SecretChatState::Closed) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -691,6 +691,9 @@ class MessagesManager : public Actor {
|
|||||||
|
|
||||||
FileSourceId get_message_file_source_id(FullMessageId full_message_id);
|
FileSourceId get_message_file_source_id(FullMessageId full_message_id);
|
||||||
|
|
||||||
|
bool need_message_push_notification(DialogId dialog_id, MessageId message_id, int64 random_id, bool &contains_mention,
|
||||||
|
bool is_pinned);
|
||||||
|
|
||||||
struct MessageNotificationGroup {
|
struct MessageNotificationGroup {
|
||||||
DialogId dialog_id;
|
DialogId dialog_id;
|
||||||
NotificationGroupType type = NotificationGroupType::Calls;
|
NotificationGroupType type = NotificationGroupType::Calls;
|
||||||
@ -1611,6 +1614,8 @@ class MessagesManager : public Actor {
|
|||||||
|
|
||||||
bool is_message_notification_disabled(const Dialog *d, const Message *m) const;
|
bool is_message_notification_disabled(const Dialog *d, const Message *m) const;
|
||||||
|
|
||||||
|
bool is_dialog_message_notification_disabled(DialogId dialog_id, int32 message_date) const;
|
||||||
|
|
||||||
bool may_need_message_notification(const Dialog *d, const Message *m) const;
|
bool may_need_message_notification(const Dialog *d, const Message *m) const;
|
||||||
|
|
||||||
bool add_new_message_notification(Dialog *d, Message *m, bool force);
|
bool add_new_message_notification(Dialog *d, Message *m, bool force);
|
||||||
|
@ -2357,6 +2357,15 @@ Status NotificationManager::process_push_notification_payload(string payload) {
|
|||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (loc_key == "LOCKED_MESSAGE") {
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (loc_key == "AUTH_REGION" || loc_key == "AUTH_UNKNOWN") {
|
||||||
|
// TODO
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
|
||||||
DialogId dialog_id;
|
DialogId dialog_id;
|
||||||
if (has_json_object_field(custom, "from_id")) {
|
if (has_json_object_field(custom, "from_id")) {
|
||||||
TRY_RESULT(user_id_int, get_json_object_int_field(custom, "from_id"));
|
TRY_RESULT(user_id_int, get_json_object_int_field(custom, "from_id"));
|
||||||
@ -2461,6 +2470,16 @@ Status NotificationManager::process_push_notification_payload(string payload) {
|
|||||||
return Status::Error("Receive message ID in secret chat push");
|
return Status::Error("Receive message ID in secret chat push");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (begins_with(loc_key, "ENCRYPTION_")) {
|
||||||
|
// TODO new secret chat notification
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (begins_with(loc_key, "PHONE_CALL_")) {
|
||||||
|
// TODO phone call request/missed notification
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
|
||||||
return process_message_push_notification(dialog_id, sender_user_id, MessageId(server_message_id), random_id,
|
return process_message_push_notification(dialog_id, sender_user_id, MessageId(server_message_id), random_id,
|
||||||
contains_mention, std::move(loc_key), std::move(loc_args));
|
contains_mention, std::move(loc_key), std::move(loc_args));
|
||||||
}
|
}
|
||||||
@ -2469,6 +2488,19 @@ Status NotificationManager::process_message_push_notification(DialogId dialog_id
|
|||||||
MessageId message_id, int64 random_id,
|
MessageId message_id, int64 random_id,
|
||||||
bool contains_mention, string loc_key,
|
bool contains_mention, string loc_key,
|
||||||
vector<string> loc_args) {
|
vector<string> loc_args) {
|
||||||
|
auto is_pinned = begins_with(loc_key, "PINNED_");
|
||||||
|
if (is_pinned) {
|
||||||
|
contains_mention = true;
|
||||||
|
}
|
||||||
|
if (!td_->messages_manager_->need_message_push_notification(dialog_id, message_id, random_id, contains_mention,
|
||||||
|
is_pinned)) {
|
||||||
|
VLOG(notifications) << "Don't need message push notification for " << message_id << "/" << random_id << " from "
|
||||||
|
<< dialog_id;
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
|
||||||
|
VLOG(notifications) << "Process message push notification " << loc_key << " for " << message_id << "/" << random_id
|
||||||
|
<< " from " << dialog_id << ", sent by " << sender_user_id << " with args " << loc_args;
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user