Support reading history from push notifications.

GitOrigin-RevId: 6f901b7927e272b345d25d3ba4b54e0dec5074cf
This commit is contained in:
levlam 2019-03-31 00:30:07 +03:00
parent 17dfff9297
commit ae8310907a
2 changed files with 23 additions and 4 deletions

View File

@ -8298,8 +8298,8 @@ void MessagesManager::read_history_inbox(DialogId dialog_id, MessageId max_messa
} }
LOG_IF(INFO, d->last_new_message_id.is_valid() && max_message_id.get() > d->last_new_message_id.get() && LOG_IF(INFO, d->last_new_message_id.is_valid() && max_message_id.get() > d->last_new_message_id.get() &&
max_message_id.is_server() && dialog_id.get_type() != DialogType::Channel && max_message_id.get() > d->max_notification_message_id.get() && max_message_id.is_server() &&
!running_get_difference_) dialog_id.get_type() != DialogType::Channel && !running_get_difference_)
<< "Receive read inbox update up to unknown " << max_message_id << " in " << dialog_id << " from " << source << "Receive read inbox update up to unknown " << max_message_id << " in " << dialog_id << " from " << source
<< ". Last new is " << d->last_new_message_id << ", unread_count = " << unread_count << ". Last new is " << d->last_new_message_id << ", unread_count = " << unread_count
<< ". Possible only for deleted incoming message. " << td_->updates_manager_->get_state(); << ". Possible only for deleted incoming message. " << td_->updates_manager_->get_state();
@ -12884,6 +12884,9 @@ Status MessagesManager::view_messages(DialogId dialog_id, const vector<MessageId
on_message_changed(d, message, true, "view_messages"); on_message_changed(d, message, true, "view_messages");
} }
} }
} else if (!message_id.is_yet_unsent() && message_id.get() > max_message_id.get() &&
message_id.get() <= d->max_notification_message_id.get()) {
max_message_id = message_id;
} }
} }
if (!d->pending_viewed_message_ids.empty()) { if (!d->pending_viewed_message_ids.empty()) {
@ -18214,9 +18217,20 @@ Result<MessagesManager::MessagePushNotificationInfo> MessagesManager::get_messag
if (d == nullptr) { if (d == nullptr) {
return Status::Error("Ignore notification in unknown chat"); return Status::Error("Ignore notification in unknown chat");
} }
if (message_id.is_valid() && message_id.get() <= d->last_new_message_id.get()) { if (message_id.is_valid()) {
if (message_id.get() <= d->last_new_message_id.get()) {
return Status::Error("Ignore notification about known message"); return Status::Error("Ignore notification about known message");
} }
if (message_id.get() == d->max_notification_message_id.get()) {
return Status::Error("Ignore previously added message push notification");
}
if (message_id.get() < d->max_notification_message_id.get()) {
return Status::Error("Ignore out of order message push notification");
}
if (message_id.get() <= d->last_read_inbox_message_id.get()) {
return Status::Error("Ignore notification about read message");
}
}
if (random_id != 0) { if (random_id != 0) {
CHECK(dialog_id.get_type() == DialogType::SecretChat); CHECK(dialog_id.get_type() == DialogType::SecretChat);
if (get_message_id_by_random_id(d, random_id, "need_message_push_notification").is_valid()) { if (get_message_id_by_random_id(d, random_id, "need_message_push_notification").is_valid()) {
@ -18254,6 +18268,10 @@ Result<MessagesManager::MessagePushNotificationInfo> MessagesManager::get_messag
return Status::Error("Can't assign notification group ID"); return Status::Error("Can't assign notification group ID");
} }
if (message_id.is_valid() && message_id.get() > d->max_notification_message_id.get()) {
d->max_notification_message_id = message_id;
}
MessagePushNotificationInfo result; MessagePushNotificationInfo result;
result.group_id = group_id; result.group_id = group_id;
result.group_type = contains_mention ? NotificationGroupType::Mentions : NotificationGroupType::Messages; result.group_type = contains_mention ? NotificationGroupType::Mentions : NotificationGroupType::Messages;

View File

@ -958,6 +958,7 @@ class MessagesManager : public Actor {
MessageId deleted_last_message_id; MessageId deleted_last_message_id;
int32 pending_last_message_date = 0; int32 pending_last_message_date = 0;
MessageId pending_last_message_id; MessageId pending_last_message_id;
MessageId max_notification_message_id;
MessageId max_added_message_id; MessageId max_added_message_id;
MessageId being_added_message_id; MessageId being_added_message_id;