Support reading message history from pushes.
GitOrigin-RevId: 280eff17eec93b688eff6d5d3bad388670820728
This commit is contained in:
parent
afa4871028
commit
97d3485753
@ -312,6 +312,8 @@ class MessagesManager : public Actor {
|
|||||||
void on_user_dialog_action(DialogId dialog_id, UserId user_id, tl_object_ptr<td_api::ChatAction> &&action, int32 date,
|
void on_user_dialog_action(DialogId dialog_id, UserId user_id, tl_object_ptr<td_api::ChatAction> &&action, int32 date,
|
||||||
MessageContentType message_content_type = MessageContentType::None);
|
MessageContentType message_content_type = MessageContentType::None);
|
||||||
|
|
||||||
|
void read_history_inbox(DialogId dialog_id, MessageId max_message_id, int32 unread_count, const char *source);
|
||||||
|
|
||||||
void delete_messages(DialogId dialog_id, const vector<MessageId> &message_ids, bool revoke, Promise<Unit> &&promise);
|
void delete_messages(DialogId dialog_id, const vector<MessageId> &message_ids, bool revoke, Promise<Unit> &&promise);
|
||||||
|
|
||||||
void delete_dialog_history(DialogId dialog_id, bool remove_from_dialog_list, Promise<Unit> &&promise);
|
void delete_dialog_history(DialogId dialog_id, bool remove_from_dialog_list, Promise<Unit> &&promise);
|
||||||
@ -1450,8 +1452,6 @@ class MessagesManager : public Actor {
|
|||||||
|
|
||||||
void repair_channel_server_unread_count(Dialog *d);
|
void repair_channel_server_unread_count(Dialog *d);
|
||||||
|
|
||||||
void read_history_inbox(DialogId dialog_id, MessageId max_message_id, int32 unread_count, const char *source);
|
|
||||||
|
|
||||||
void read_history_outbox(DialogId dialog_id, MessageId max_message_id, int32 read_date = -1);
|
void read_history_outbox(DialogId dialog_id, MessageId max_message_id, int32 read_date = -1);
|
||||||
|
|
||||||
void read_history_on_server(Dialog *d, MessageId max_message_id);
|
void read_history_on_server(Dialog *d, MessageId max_message_id);
|
||||||
|
@ -2294,7 +2294,6 @@ Status NotificationManager::process_push_notification_payload(string payload) {
|
|||||||
string loc_key;
|
string loc_key;
|
||||||
JsonObject custom;
|
JsonObject custom;
|
||||||
string announcement_message_text;
|
string announcement_message_text;
|
||||||
int32 badge = 0;
|
|
||||||
vector<string> loc_args;
|
vector<string> loc_args;
|
||||||
for (auto &field_value : json_value.get_object()) {
|
for (auto &field_value : json_value.get_object()) {
|
||||||
if (field_value.first == "loc_key") {
|
if (field_value.first == "loc_key") {
|
||||||
@ -2318,18 +2317,6 @@ Status NotificationManager::process_push_notification_payload(string payload) {
|
|||||||
return Status::Error("Expected custom as an Object");
|
return Status::Error("Expected custom as an Object");
|
||||||
}
|
}
|
||||||
custom = std::move(field_value.second.get_object());
|
custom = std::move(field_value.second.get_object());
|
||||||
} else if (field_value.first == "badge") {
|
|
||||||
if (field_value.second.type() == JsonValue::Type::String) {
|
|
||||||
TRY_RESULT(badge_value, to_integer_safe<int32>(field_value.second.get_string()));
|
|
||||||
badge = badge_value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (field_value.second.type() == JsonValue::Type::Number) {
|
|
||||||
TRY_RESULT(badge_value, to_integer_safe<int32>(field_value.second.get_number()));
|
|
||||||
badge = badge_value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
return Status::Error("Expected badge as a Number");
|
|
||||||
} else if (field_value.first == "message") {
|
} else if (field_value.first == "message") {
|
||||||
if (field_value.second.type() != JsonValue::Type::String) {
|
if (field_value.second.type() != JsonValue::Type::String) {
|
||||||
return Status::Error("Expected announcement message text as a String");
|
return Status::Error("Expected announcement message text as a String");
|
||||||
@ -2337,9 +2324,6 @@ Status NotificationManager::process_push_notification_payload(string payload) {
|
|||||||
announcement_message_text = field_value.second.get_string().str();
|
announcement_message_text = field_value.second.get_string().str();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (badge < 0) {
|
|
||||||
return Status::Error("Expected badge to be non-negative");
|
|
||||||
}
|
|
||||||
if (!clean_input_string(loc_key)) {
|
if (!clean_input_string(loc_key)) {
|
||||||
return Status::Error(PSLICE() << "Receive invalid loc_key " << format::escaped(loc_key));
|
return Status::Error(PSLICE() << "Receive invalid loc_key " << format::escaped(loc_key));
|
||||||
}
|
}
|
||||||
@ -2382,6 +2366,60 @@ Status NotificationManager::process_push_notification_payload(string payload) {
|
|||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DialogId dialog_id;
|
||||||
|
if (has_json_object_field(custom, "from_id")) {
|
||||||
|
TRY_RESULT(user_id_int, get_json_object_int_field(custom, "from_id"));
|
||||||
|
UserId user_id(user_id_int);
|
||||||
|
if (!user_id.is_valid()) {
|
||||||
|
return Status::Error("Receive invalid user_id");
|
||||||
|
}
|
||||||
|
dialog_id = DialogId(user_id);
|
||||||
|
}
|
||||||
|
if (has_json_object_field(custom, "chat_id")) {
|
||||||
|
TRY_RESULT(chat_id_int, get_json_object_int_field(custom, "chat_id"));
|
||||||
|
ChatId chat_id(chat_id_int);
|
||||||
|
if (!chat_id.is_valid()) {
|
||||||
|
return Status::Error("Receive invalid chat_id");
|
||||||
|
}
|
||||||
|
dialog_id = DialogId(chat_id);
|
||||||
|
}
|
||||||
|
if (has_json_object_field(custom, "channel_id")) {
|
||||||
|
TRY_RESULT(channel_id_int, get_json_object_int_field(custom, "channel_id"));
|
||||||
|
ChannelId channel_id(channel_id_int);
|
||||||
|
if (!channel_id.is_valid()) {
|
||||||
|
return Status::Error("Receive invalid channel_id");
|
||||||
|
}
|
||||||
|
dialog_id = DialogId(channel_id);
|
||||||
|
}
|
||||||
|
if (has_json_object_field(custom, "encryption_id")) {
|
||||||
|
TRY_RESULT(secret_chat_id_int, get_json_object_int_field(custom, "encryption_id"));
|
||||||
|
SecretChatId secret_chat_id(secret_chat_id_int);
|
||||||
|
if (!secret_chat_id.is_valid()) {
|
||||||
|
return Status::Error("Receive invalid secret_chat_id");
|
||||||
|
}
|
||||||
|
dialog_id = DialogId(secret_chat_id);
|
||||||
|
}
|
||||||
|
if (!dialog_id.is_valid()) {
|
||||||
|
// TODO if (loc_key == "ENCRYPTED_MESSAGE") ?
|
||||||
|
return Status::Error("Can't find dialog_id");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (loc_key.empty()) {
|
||||||
|
if (dialog_id.get_type() == DialogType::SecretChat) {
|
||||||
|
return Status::Error("Receive read history in a secret chat");
|
||||||
|
}
|
||||||
|
|
||||||
|
TRY_RESULT(max_id, get_json_object_int_field(custom, "max_id"));
|
||||||
|
ServerMessageId max_server_message_id(max_id);
|
||||||
|
if (!max_server_message_id.is_valid()) {
|
||||||
|
return Status::Error("Receive invalid max_id");
|
||||||
|
}
|
||||||
|
|
||||||
|
send_closure(G()->messages_manager(), &MessagesManager::read_history_inbox, dialog_id,
|
||||||
|
MessageId(max_server_message_id), -1, "process_push_notification_payload");
|
||||||
|
return Status::OK();
|
||||||
|
}
|
||||||
|
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user