Add sender_name to notificationTypeNewPushMessage.
GitOrigin-RevId: 6fd18136c30e23787e4c7e60ad8c8e81c12eebb3
This commit is contained in:
parent
9183772611
commit
c2526c67c8
@ -2301,8 +2301,10 @@ notificationTypeNewCall call_id:int32 = NotificationType;
|
|||||||
|
|
||||||
//@description New message was received through a push notification
|
//@description New message was received through a push notification
|
||||||
//@message_id The message identifier. The message will not be available in the chat history, but the ID can be used in viewMessages and as reply_to_message_id
|
//@message_id The message identifier. The message will not be available in the chat history, but the ID can be used in viewMessages and as reply_to_message_id
|
||||||
//@sender_user_id Sender of the message. Corresponding user may be inaccessible @content Push message content
|
//@sender_user_id Sender of the message; 0 if unknown. Corresponding user may be inaccessible
|
||||||
notificationTypeNewPushMessage message_id:int53 sender_user_id:int32 content:PushMessageContent = NotificationType;
|
//@sender_name Name of the sender; can be different from the name of the sender user
|
||||||
|
//@content Push message content
|
||||||
|
notificationTypeNewPushMessage message_id:int53 sender_user_id:int32 sender_name:string content:PushMessageContent = NotificationType;
|
||||||
|
|
||||||
|
|
||||||
//@class NotificationGroupType @description Describes the type of notifications in a notification group
|
//@class NotificationGroupType @description Describes the type of notifications in a notification group
|
||||||
|
Binary file not shown.
@ -3247,10 +3247,11 @@ Status NotificationManager::process_push_notification_payload(string payload, bo
|
|||||||
if (sender_photo != nullptr) {
|
if (sender_photo != nullptr) {
|
||||||
flags |= telegram_api::user::PHOTO_MASK;
|
flags |= telegram_api::user::PHOTO_MASK;
|
||||||
}
|
}
|
||||||
|
auto user_name = sender_user_id.get() == 136817688 ? "Channel" : sender_name;
|
||||||
auto user = telegram_api::make_object<telegram_api::user>(
|
auto user = telegram_api::make_object<telegram_api::user>(
|
||||||
flags, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
flags, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
||||||
false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
||||||
false /*ignored*/, false /*ignored*/, false /*ignored*/, sender_user_id.get(), sender_access_hash, sender_name,
|
false /*ignored*/, false /*ignored*/, false /*ignored*/, sender_user_id.get(), sender_access_hash, user_name,
|
||||||
string(), string(), string(), std::move(sender_photo), nullptr, 0, Auto(), string(), string());
|
string(), string(), string(), std::move(sender_photo), nullptr, 0, Auto(), string(), string());
|
||||||
td_->contacts_manager_->on_get_user(std::move(user), "process_push_notification_payload");
|
td_->contacts_manager_->on_get_user(std::move(user), "process_push_notification_payload");
|
||||||
}
|
}
|
||||||
@ -3570,11 +3571,12 @@ void NotificationManager::add_message_push_notification(
|
|||||||
|
|
||||||
if (sender_user_id.is_valid() && !td_->contacts_manager_->have_user_force(sender_user_id)) {
|
if (sender_user_id.is_valid() && !td_->contacts_manager_->have_user_force(sender_user_id)) {
|
||||||
int32 flags = telegram_api::user::FIRST_NAME_MASK | telegram_api::user::MIN_MASK;
|
int32 flags = telegram_api::user::FIRST_NAME_MASK | telegram_api::user::MIN_MASK;
|
||||||
|
auto user_name = sender_user_id.get() == 136817688 ? "Channel" : sender_name;
|
||||||
auto user = telegram_api::make_object<telegram_api::user>(
|
auto user = telegram_api::make_object<telegram_api::user>(
|
||||||
flags, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
flags, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
||||||
false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/, false /*ignored*/,
|
||||||
false /*ignored*/, false /*ignored*/, false /*ignored*/, sender_user_id.get(), 0, sender_name, string(),
|
false /*ignored*/, false /*ignored*/, false /*ignored*/, sender_user_id.get(), 0, user_name, string(), string(),
|
||||||
string(), string(), nullptr, nullptr, 0, Auto(), string(), string());
|
string(), nullptr, nullptr, 0, Auto(), string(), string());
|
||||||
td_->contacts_manager_->on_get_user(std::move(user), "add_message_push_notification");
|
td_->contacts_manager_->on_get_user(std::move(user), "add_message_push_notification");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3593,7 +3595,8 @@ void NotificationManager::add_message_push_notification(
|
|||||||
if (logevent_id != 0) {
|
if (logevent_id != 0) {
|
||||||
VLOG(notifications) << "Register temporary " << notification_id << " with logevent " << logevent_id;
|
VLOG(notifications) << "Register temporary " << notification_id << " with logevent " << logevent_id;
|
||||||
temporary_notification_logevent_ids_[notification_id] = logevent_id;
|
temporary_notification_logevent_ids_[notification_id] = logevent_id;
|
||||||
temporary_notifications_[FullMessageId(dialog_id, message_id)] = {group_id, notification_id, sender_user_id};
|
temporary_notifications_[FullMessageId(dialog_id, message_id)] = {group_id, notification_id, sender_user_id,
|
||||||
|
sender_name};
|
||||||
temporary_notification_message_ids_[notification_id] = FullMessageId(dialog_id, message_id);
|
temporary_notification_message_ids_[notification_id] = FullMessageId(dialog_id, message_id);
|
||||||
}
|
}
|
||||||
push_notification_promises_[notification_id].push_back(std::move(promise));
|
push_notification_promises_[notification_id].push_back(std::move(promise));
|
||||||
@ -3601,14 +3604,15 @@ void NotificationManager::add_message_push_notification(
|
|||||||
auto group_type = info.group_type;
|
auto group_type = info.group_type;
|
||||||
auto settings_dialog_id = info.settings_dialog_id;
|
auto settings_dialog_id = info.settings_dialog_id;
|
||||||
VLOG(notifications) << "Add message push " << notification_id << " of type " << loc_key << " for " << message_id
|
VLOG(notifications) << "Add message push " << notification_id << " of type " << loc_key << " for " << message_id
|
||||||
<< "/" << random_id << " in " << dialog_id << ", sent by " << sender_user_id << " at " << date
|
<< "/" << random_id << " in " << dialog_id << ", sent by " << sender_user_id << "/\""
|
||||||
<< " with arg " << arg << ", photo " << photo << " and document " << document << " to "
|
<< sender_name << "\" at " << date << " with arg " << arg << ", photo " << photo
|
||||||
<< group_id << " of type " << group_type << " with settings from " << settings_dialog_id;
|
<< " and document " << document << " to " << group_id << " of type " << group_type
|
||||||
|
<< " with settings from " << settings_dialog_id;
|
||||||
|
|
||||||
add_notification(group_id, group_type, dialog_id, date, settings_dialog_id, initial_is_silent, is_silent, 0,
|
add_notification(group_id, group_type, dialog_id, date, settings_dialog_id, initial_is_silent, is_silent, 0,
|
||||||
notification_id,
|
notification_id,
|
||||||
create_new_push_message_notification(sender_user_id, message_id, std::move(loc_key), std::move(arg),
|
create_new_push_message_notification(sender_user_id, sender_name, message_id, std::move(loc_key),
|
||||||
std::move(photo), std::move(document)),
|
std::move(arg), std::move(photo), std::move(document)),
|
||||||
"add_message_push_notification");
|
"add_message_push_notification");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3701,6 +3705,7 @@ void NotificationManager::edit_message_push_notification(DialogId dialog_id, Mes
|
|||||||
auto group_id = it->second.group_id;
|
auto group_id = it->second.group_id;
|
||||||
auto notification_id = it->second.notification_id;
|
auto notification_id = it->second.notification_id;
|
||||||
auto sender_user_id = it->second.sender_user_id;
|
auto sender_user_id = it->second.sender_user_id;
|
||||||
|
auto sender_name = it->second.sender_name;
|
||||||
CHECK(group_id.is_valid());
|
CHECK(group_id.is_valid());
|
||||||
CHECK(notification_id.is_valid());
|
CHECK(notification_id.is_valid());
|
||||||
|
|
||||||
@ -3725,9 +3730,10 @@ void NotificationManager::edit_message_push_notification(DialogId dialog_id, Mes
|
|||||||
|
|
||||||
push_notification_promises_[notification_id].push_back(std::move(promise));
|
push_notification_promises_[notification_id].push_back(std::move(promise));
|
||||||
|
|
||||||
edit_notification(group_id, notification_id,
|
edit_notification(
|
||||||
create_new_push_message_notification(sender_user_id, message_id, std::move(loc_key), std::move(arg),
|
group_id, notification_id,
|
||||||
std::move(photo), std::move(document)));
|
create_new_push_message_notification(sender_user_id, std::move(sender_name), message_id, std::move(loc_key),
|
||||||
|
std::move(arg), std::move(photo), std::move(document)));
|
||||||
}
|
}
|
||||||
|
|
||||||
Result<int64> NotificationManager::get_push_receiver_id(string payload) {
|
Result<int64> NotificationManager::get_push_receiver_id(string payload) {
|
||||||
|
@ -388,6 +388,7 @@ class NotificationManager : public Actor {
|
|||||||
NotificationGroupId group_id;
|
NotificationGroupId group_id;
|
||||||
NotificationId notification_id;
|
NotificationId notification_id;
|
||||||
UserId sender_user_id;
|
UserId sender_user_id;
|
||||||
|
string sender_name;
|
||||||
};
|
};
|
||||||
std::unordered_map<FullMessageId, TemporaryNotification, FullMessageIdHash> temporary_notifications_;
|
std::unordered_map<FullMessageId, TemporaryNotification, FullMessageIdHash> temporary_notifications_;
|
||||||
std::unordered_map<NotificationId, FullMessageId, NotificationIdHash> temporary_notification_message_ids_;
|
std::unordered_map<NotificationId, FullMessageId, NotificationIdHash> temporary_notification_message_ids_;
|
||||||
|
@ -321,25 +321,28 @@ class NotificationTypePushMessage : public NotificationType {
|
|||||||
auto sender_user_id = G()->td().get_actor_unsafe()->contacts_manager_->get_user_id_object(
|
auto sender_user_id = G()->td().get_actor_unsafe()->contacts_manager_->get_user_id_object(
|
||||||
sender_user_id_, "get_notification_type_object");
|
sender_user_id_, "get_notification_type_object");
|
||||||
return td_api::make_object<td_api::notificationTypeNewPushMessage>(
|
return td_api::make_object<td_api::notificationTypeNewPushMessage>(
|
||||||
message_id_.get(), sender_user_id, get_push_message_content_object(key_, arg_, photo_, document_));
|
message_id_.get(), sender_user_id, sender_name_,
|
||||||
|
get_push_message_content_object(key_, arg_, photo_, document_));
|
||||||
}
|
}
|
||||||
|
|
||||||
StringBuilder &to_string_builder(StringBuilder &string_builder) const override {
|
StringBuilder &to_string_builder(StringBuilder &string_builder) const override {
|
||||||
return string_builder << "NewPushMessageNotification[" << sender_user_id_ << ", " << message_id_ << ", " << key_
|
return string_builder << "NewPushMessageNotification[" << sender_user_id_ << "/\"" << sender_name_ << "\", "
|
||||||
<< ", " << arg_ << ", " << photo_ << ", " << document_ << ']';
|
<< message_id_ << ", " << key_ << ", " << arg_ << ", " << photo_ << ", " << document_ << ']';
|
||||||
}
|
}
|
||||||
|
|
||||||
UserId sender_user_id_;
|
UserId sender_user_id_;
|
||||||
MessageId message_id_;
|
MessageId message_id_;
|
||||||
|
string sender_name_;
|
||||||
string key_;
|
string key_;
|
||||||
string arg_;
|
string arg_;
|
||||||
Photo photo_;
|
Photo photo_;
|
||||||
Document document_;
|
Document document_;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
NotificationTypePushMessage(UserId sender_user_id, MessageId message_id, string key, string arg, Photo photo,
|
NotificationTypePushMessage(UserId sender_user_id, string sender_name, MessageId message_id, string key, string arg,
|
||||||
Document document)
|
Photo photo, Document document)
|
||||||
: sender_user_id_(std::move(sender_user_id))
|
: sender_user_id_(std::move(sender_user_id))
|
||||||
|
, sender_name_(std::move(sender_name))
|
||||||
, message_id_(message_id)
|
, message_id_(message_id)
|
||||||
, key_(std::move(key))
|
, key_(std::move(key))
|
||||||
, arg_(std::move(arg))
|
, arg_(std::move(arg))
|
||||||
@ -360,11 +363,12 @@ unique_ptr<NotificationType> create_new_call_notification(CallId call_id) {
|
|||||||
return make_unique<NotificationTypeCall>(call_id);
|
return make_unique<NotificationTypeCall>(call_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
unique_ptr<NotificationType> create_new_push_message_notification(UserId sender_user_id, MessageId message_id,
|
unique_ptr<NotificationType> create_new_push_message_notification(UserId sender_user_id, string sender_name,
|
||||||
string key, string arg, Photo photo,
|
MessageId message_id, string key, string arg,
|
||||||
Document document) {
|
Photo photo, Document document) {
|
||||||
return td::make_unique<NotificationTypePushMessage>(sender_user_id, message_id, std::move(key), std::move(arg),
|
return td::make_unique<NotificationTypePushMessage>(sender_user_id, std::move(sender_name), message_id,
|
||||||
std::move(photo), std::move(document));
|
std::move(key), std::move(arg), std::move(photo),
|
||||||
|
std::move(document));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace td
|
} // namespace td
|
||||||
|
@ -59,8 +59,8 @@ unique_ptr<NotificationType> create_new_secret_chat_notification();
|
|||||||
|
|
||||||
unique_ptr<NotificationType> create_new_call_notification(CallId call_id);
|
unique_ptr<NotificationType> create_new_call_notification(CallId call_id);
|
||||||
|
|
||||||
unique_ptr<NotificationType> create_new_push_message_notification(UserId sender_user_id, MessageId message_id,
|
unique_ptr<NotificationType> create_new_push_message_notification(UserId sender_user_id, string sender_name,
|
||||||
string key, string arg, Photo photo,
|
MessageId message_id, string key, string arg,
|
||||||
Document document);
|
Photo photo, Document document);
|
||||||
|
|
||||||
} // namespace td
|
} // namespace td
|
||||||
|
Loading…
x
Reference in New Issue
Block a user