Support more story chat notification settings.

This commit is contained in:
levlam 2023-06-27 19:09:43 +03:00
parent b36ea8934b
commit 34161cd627
6 changed files with 88 additions and 27 deletions

View File

@ -1307,16 +1307,20 @@ notificationSettingsScopeChannelChats = NotificationSettingsScope;
//@use_default_mute_for If true, mute_for is ignored and the value for the relevant type of chat or the forum chat is used instead
//@mute_for Time left before notifications will be unmuted, in seconds
//@use_default_sound If true, the value for the relevant type of chat or the forum chat is used instead of sound_id
//@sound_id Identifier of the notification sound to be played; 0 if sound is disabled
//@sound_id Identifier of the notification sound to be played for messages; 0 if sound is disabled
//@use_default_show_preview If true, show_preview is ignored and the value for the relevant type of chat or the forum chat is used instead
//@show_preview True, if message content must be displayed in notifications
//@use_default_mute_stories If true, mute_stories is ignored and the value for the relevant type of chat is used instead
//@mute_stories True, if story notifications are received without sound
//@use_default_story_sound If true, the value for the relevant type of chat is used instead of story_sound_id
//@story_sound_id Identifier of the notification sound to be played for stories; 0 if sound is disabled
//@use_default_show_story_sender If true, show_story_sender is ignored and the value for the relevant type of chat is used instead
//@show_story_sender True, if the sender of stories must be displayed in notifications
//@use_default_disable_pinned_message_notifications If true, disable_pinned_message_notifications is ignored and the value for the relevant type of chat or the forum chat is used instead
//@disable_pinned_message_notifications If true, notifications for incoming pinned messages will be created as for an ordinary unread message
//@use_default_disable_mention_notifications If true, disable_mention_notifications is ignored and the value for the relevant type of chat or the forum chat is used instead
//@disable_mention_notifications If true, notifications for messages with mentions will be created as for an ordinary unread message
chatNotificationSettings use_default_mute_for:Bool mute_for:int32 use_default_sound:Bool sound_id:int64 use_default_show_preview:Bool show_preview:Bool use_default_mute_stories:Bool mute_stories:Bool use_default_disable_pinned_message_notifications:Bool disable_pinned_message_notifications:Bool use_default_disable_mention_notifications:Bool disable_mention_notifications:Bool = ChatNotificationSettings;
chatNotificationSettings use_default_mute_for:Bool mute_for:int32 use_default_sound:Bool sound_id:int64 use_default_show_preview:Bool show_preview:Bool use_default_mute_stories:Bool mute_stories:Bool use_default_story_sound:Bool story_sound_id:int64 use_default_show_story_sender:Bool show_story_sender:Bool use_default_disable_pinned_message_notifications:Bool disable_pinned_message_notifications:Bool use_default_disable_mention_notifications:Bool disable_mention_notifications:Bool = ChatNotificationSettings;
//@description Contains information about notification settings for several chats
//@mute_for Time left before notifications will be unmuted, in seconds
@ -1324,7 +1328,7 @@ chatNotificationSettings use_default_mute_for:Bool mute_for:int32 use_default_so
//@show_preview True, if message content must be displayed in notifications
//@mute_stories True, if story notifications are received without sound
//@story_sound_id Identifier of the notification sound to be played for stories; 0 if sound is disabled
//@show_story_sender True, if the sender of the story must be displayed in notifications
//@show_story_sender True, if the sender of stories must be displayed in notifications
//@disable_pinned_message_notifications True, if notifications for incoming pinned messages will be created as for an ordinary unread message
//@disable_mention_notifications True, if notifications for messages with mentions will be created as for an ordinary unread message
scopeNotificationSettings mute_for:int32 sound_id:int64 show_preview:Bool mute_stories:Bool story_sound_id:int64 show_story_sender:Bool disable_pinned_message_notifications:Bool disable_mention_notifications:Bool = ScopeNotificationSettings;

View File

@ -27,23 +27,31 @@ DialogNotificationSettings::get_input_peer_notify_settings() const {
if (!use_default_mute_stories) {
flags |= telegram_api::inputPeerNotifySettings::STORIES_MUTED_MASK;
}
if (story_sound != nullptr) {
flags |= telegram_api::inputPeerNotifySettings::STORIES_SOUND_MASK;
}
if (!use_default_hide_story_sender) {
flags |= telegram_api::inputPeerNotifySettings::STORIES_HIDE_SENDER_MASK;
}
if (silent_send_message) {
flags |= telegram_api::inputPeerNotifySettings::SILENT_MASK;
}
return telegram_api::make_object<telegram_api::inputPeerNotifySettings>(
flags, show_preview, silent_send_message, mute_until, get_input_notification_sound(sound), mute_stories, false,
nullptr);
flags, show_preview, silent_send_message, mute_until, get_input_notification_sound(sound), mute_stories,
hide_story_sender, get_input_notification_sound(story_sound));
}
StringBuilder &operator<<(StringBuilder &string_builder, const DialogNotificationSettings &notification_settings) {
return string_builder << "[" << notification_settings.mute_until << ", " << notification_settings.sound << ", "
<< notification_settings.show_preview << ", " << notification_settings.mute_stories << ", "
<< notification_settings.story_sound << ", " << notification_settings.hide_story_sender << ", "
<< notification_settings.silent_send_message << ", "
<< notification_settings.disable_pinned_message_notifications << ", "
<< notification_settings.disable_mention_notifications << ", "
<< notification_settings.use_default_mute_until << ", "
<< notification_settings.use_default_show_preview << ", "
<< notification_settings.use_default_mute_stories << ", "
<< notification_settings.use_default_hide_story_sender << ", "
<< notification_settings.use_default_disable_pinned_message_notifications << ", "
<< notification_settings.use_default_disable_mention_notifications << ", "
<< notification_settings.is_synchronized << "]";
@ -57,7 +65,10 @@ td_api::object_ptr<td_api::chatNotificationSettings> get_chat_notification_setti
is_notification_sound_default(notification_settings->sound),
get_notification_sound_ringtone_id(notification_settings->sound), notification_settings->use_default_show_preview,
notification_settings->show_preview, notification_settings->use_default_mute_stories,
notification_settings->mute_stories, notification_settings->use_default_disable_pinned_message_notifications,
notification_settings->mute_stories, is_notification_sound_default(notification_settings->story_sound),
get_notification_sound_ringtone_id(notification_settings->story_sound),
notification_settings->use_default_hide_story_sender, !notification_settings->hide_story_sender,
notification_settings->use_default_disable_pinned_message_notifications,
notification_settings->disable_pinned_message_notifications,
notification_settings->use_default_disable_mention_notifications,
notification_settings->disable_mention_notifications);
@ -92,11 +103,19 @@ Result<DialogNotificationSettings> get_dialog_notification_settings(
if (is_notification_sound_default(old_settings->sound) && is_notification_sound_default(notification_sound)) {
notification_sound = dup_notification_sound(old_settings->sound);
}
auto story_notification_sound =
get_notification_sound(notification_settings->use_default_story_sound_, notification_settings->story_sound_id_);
if (is_notification_sound_default(old_settings->story_sound) &&
is_notification_sound_default(story_notification_sound)) {
story_notification_sound = dup_notification_sound(old_settings->story_sound);
}
return DialogNotificationSettings(
notification_settings->use_default_mute_for_, mute_until, std::move(notification_sound),
notification_settings->use_default_show_preview_, notification_settings->show_preview_,
notification_settings->use_default_mute_stories_, notification_settings->mute_stories_,
old_settings->silent_send_message, notification_settings->use_default_disable_pinned_message_notifications_,
std::move(story_notification_sound), notification_settings->use_default_show_story_sender_,
!notification_settings->show_story_sender_, old_settings->silent_send_message,
notification_settings->use_default_disable_pinned_message_notifications_,
notification_settings->disable_pinned_message_notifications_,
notification_settings->use_default_disable_mention_notifications_,
notification_settings->disable_mention_notifications_);
@ -128,6 +147,8 @@ DialogNotificationSettings get_dialog_notification_settings(tl_object_ptr<telegr
bool use_default_mute_until = (settings->flags_ & telegram_api::peerNotifySettings::MUTE_UNTIL_MASK) == 0;
bool use_default_show_preview = (settings->flags_ & telegram_api::peerNotifySettings::SHOW_PREVIEWS_MASK) == 0;
bool use_default_mute_stories = (settings->flags_ & telegram_api::peerNotifySettings::STORIES_MUTED_MASK) == 0;
bool use_default_hide_story_sender =
(settings->flags_ & telegram_api::peerNotifySettings::STORIES_HIDE_SENDER_MASK) == 0;
auto mute_until = use_default_mute_until || settings->mute_until_ <= G()->unix_time() ? 0 : settings->mute_until_;
bool silent_send_message = settings->silent_;
return {use_default_mute_until,
@ -137,6 +158,9 @@ DialogNotificationSettings get_dialog_notification_settings(tl_object_ptr<telegr
settings->show_previews_,
use_default_mute_stories,
settings->stories_muted_,
get_notification_sound(settings.get(), true),
use_default_hide_story_sender,
settings->stories_hide_sender_,
silent_send_message,
old_use_default_disable_pinned_message_notifications,
old_disable_pinned_message_notifications,
@ -147,20 +171,25 @@ DialogNotificationSettings get_dialog_notification_settings(tl_object_ptr<telegr
bool are_default_dialog_notification_settings(const DialogNotificationSettings &settings, bool compare_sound) {
return settings.use_default_mute_until && (!compare_sound || is_notification_sound_default(settings.sound)) &&
settings.use_default_show_preview && settings.use_default_mute_stories &&
settings.use_default_disable_pinned_message_notifications &&
(!compare_sound || is_notification_sound_default(settings.story_sound)) &&
settings.use_default_hide_story_sender && settings.use_default_disable_pinned_message_notifications &&
settings.use_default_disable_mention_notifications;
}
NeedUpdateDialogNotificationSettings need_update_dialog_notification_settings(
const DialogNotificationSettings *current_settings, const DialogNotificationSettings &new_settings) {
NeedUpdateDialogNotificationSettings result;
result.need_update_server = current_settings->mute_until != new_settings.mute_until ||
!are_equivalent_notification_sounds(current_settings->sound, new_settings.sound) ||
current_settings->show_preview != new_settings.show_preview ||
current_settings->mute_stories != new_settings.mute_stories ||
current_settings->use_default_mute_until != new_settings.use_default_mute_until ||
current_settings->use_default_show_preview != new_settings.use_default_show_preview ||
current_settings->use_default_mute_stories != new_settings.use_default_mute_stories;
result.need_update_server =
current_settings->mute_until != new_settings.mute_until ||
!are_equivalent_notification_sounds(current_settings->sound, new_settings.sound) ||
!are_equivalent_notification_sounds(current_settings->story_sound, new_settings.story_sound) ||
current_settings->show_preview != new_settings.show_preview ||
current_settings->mute_stories != new_settings.mute_stories ||
current_settings->hide_story_sender != new_settings.hide_story_sender ||
current_settings->use_default_mute_until != new_settings.use_default_mute_until ||
current_settings->use_default_show_preview != new_settings.use_default_show_preview ||
current_settings->use_default_mute_stories != new_settings.use_default_mute_stories ||
current_settings->use_default_hide_story_sender != new_settings.use_default_hide_story_sender;
result.need_update_local =
current_settings->use_default_disable_pinned_message_notifications !=
new_settings.use_default_disable_pinned_message_notifications ||
@ -168,10 +197,12 @@ NeedUpdateDialogNotificationSettings need_update_dialog_notification_settings(
current_settings->use_default_disable_mention_notifications !=
new_settings.use_default_disable_mention_notifications ||
current_settings->disable_mention_notifications != new_settings.disable_mention_notifications;
result.are_changed = result.need_update_server || result.need_update_local ||
current_settings->is_synchronized != new_settings.is_synchronized ||
current_settings->is_use_default_fixed != new_settings.is_use_default_fixed ||
are_different_equivalent_notification_sounds(current_settings->sound, new_settings.sound);
result.are_changed =
result.need_update_server || result.need_update_local ||
current_settings->is_synchronized != new_settings.is_synchronized ||
current_settings->is_use_default_fixed != new_settings.is_use_default_fixed ||
are_different_equivalent_notification_sounds(current_settings->sound, new_settings.sound) ||
are_different_equivalent_notification_sounds(current_settings->story_sound, new_settings.story_sound);
return result;
}

View File

@ -20,12 +20,15 @@ class DialogNotificationSettings {
public:
int32 mute_until = 0;
unique_ptr<NotificationSound> sound;
unique_ptr<NotificationSound> story_sound;
bool show_preview = true;
bool mute_stories = false;
bool hide_story_sender = false;
bool silent_send_message = false;
bool use_default_mute_until = true;
bool use_default_show_preview = true;
bool use_default_mute_stories = true;
bool use_default_hide_story_sender = true;
bool is_use_default_fixed = true;
bool is_secret_chat_show_preview_fixed = false;
bool is_synchronized = false;
@ -40,18 +43,22 @@ class DialogNotificationSettings {
DialogNotificationSettings(bool use_default_mute_until, int32 mute_until, unique_ptr<NotificationSound> &&sound,
bool use_default_show_preview, bool show_preview, bool use_default_mute_stories,
bool mute_stories, bool silent_send_message,
bool mute_stories, unique_ptr<NotificationSound> &&story_sound,
bool use_default_hide_story_sender, bool hide_story_sender, bool silent_send_message,
bool use_default_disable_pinned_message_notifications,
bool disable_pinned_message_notifications, bool use_default_disable_mention_notifications,
bool disable_mention_notifications)
: mute_until(mute_until)
, sound(std::move(sound))
, story_sound(std::move(story_sound))
, show_preview(show_preview)
, mute_stories(mute_stories)
, hide_story_sender(hide_story_sender)
, silent_send_message(silent_send_message)
, use_default_mute_until(use_default_mute_until)
, use_default_show_preview(use_default_show_preview)
, use_default_mute_stories(use_default_mute_stories)
, use_default_hide_story_sender(use_default_hide_story_sender)
, is_synchronized(true)
, use_default_disable_pinned_message_notifications(use_default_disable_pinned_message_notifications)
, disable_pinned_message_notifications(disable_pinned_message_notifications)

View File

@ -21,6 +21,8 @@ void store(const DialogNotificationSettings &notification_settings, StorerT &sto
bool has_sound = notification_settings.sound != nullptr;
bool has_ringtone_support = true;
bool use_mute_stories = !notification_settings.use_default_mute_stories;
bool has_story_sound = notification_settings.story_sound != nullptr;
bool use_hide_story_sender = !notification_settings.use_default_hide_story_sender;
BEGIN_STORE_FLAGS();
STORE_FLAG(is_muted);
STORE_FLAG(has_sound);
@ -39,6 +41,9 @@ void store(const DialogNotificationSettings &notification_settings, StorerT &sto
STORE_FLAG(has_ringtone_support);
STORE_FLAG(notification_settings.mute_stories);
STORE_FLAG(use_mute_stories);
STORE_FLAG(has_story_sound);
STORE_FLAG(notification_settings.hide_story_sender);
STORE_FLAG(use_hide_story_sender);
END_STORE_FLAGS();
if (is_muted) {
store(notification_settings.mute_until, storer);
@ -46,6 +51,9 @@ void store(const DialogNotificationSettings &notification_settings, StorerT &sto
if (has_sound) {
store(notification_settings.sound, storer);
}
if (has_story_sound) {
store(notification_settings.story_sound, storer);
}
}
template <class ParserT>
@ -57,6 +65,8 @@ void parse(DialogNotificationSettings &notification_settings, ParserT &parser) {
bool use_disable_mention_notifications;
bool has_ringtone_support;
bool use_mute_stories;
bool has_story_sound;
bool use_hide_story_sender;
BEGIN_PARSE_FLAGS();
PARSE_FLAG(is_muted);
PARSE_FLAG(has_sound);
@ -75,10 +85,14 @@ void parse(DialogNotificationSettings &notification_settings, ParserT &parser) {
PARSE_FLAG(has_ringtone_support);
PARSE_FLAG(notification_settings.mute_stories);
PARSE_FLAG(use_mute_stories);
PARSE_FLAG(has_story_sound);
PARSE_FLAG(notification_settings.hide_story_sender);
PARSE_FLAG(use_hide_story_sender);
END_PARSE_FLAGS();
notification_settings.use_default_disable_pinned_message_notifications = !use_disable_pinned_message_notifications;
notification_settings.use_default_disable_mention_notifications = !use_disable_mention_notifications;
notification_settings.use_default_mute_stories = !use_mute_stories;
notification_settings.use_default_hide_story_sender = !use_hide_story_sender;
if (is_muted) {
parse(notification_settings.mute_until, parser);
}
@ -91,6 +105,9 @@ void parse(DialogNotificationSettings &notification_settings, ParserT &parser) {
notification_settings.sound = use_default_sound ? nullptr : get_legacy_notification_sound(sound);
}
}
if (has_story_sound) {
parse_notification_sound(notification_settings.story_sound, parser);
}
}
} // namespace td

View File

@ -36378,8 +36378,9 @@ void MessagesManager::force_create_dialog(DialogId dialog_id, const char *source
auto new_notification_settings = DialogNotificationSettings(
user_settings->use_default_mute_until, user_settings->mute_until,
dup_notification_sound(user_settings->sound), true /*use_default_show_preview*/, false /*show_preview*/,
user_settings->use_default_mute_stories, user_settings->mute_stories, user_settings->silent_send_message,
true, false, true, false);
user_settings->use_default_mute_stories, user_settings->mute_stories,
dup_notification_sound(user_settings->story_sound), user_settings->use_default_hide_story_sender,
user_settings->hide_story_sender, user_settings->silent_send_message, true, false, true, false);
new_notification_settings.is_secret_chat_show_preview_fixed = true;
update_dialog_notification_settings(dialog_id, &d->notification_settings,
std::move(new_notification_settings));

View File

@ -5520,8 +5520,8 @@ class CliClient final : public Actor {
string hide_story_sender;
string disable_pinned_message_notifications;
string disable_mention_notifications;
get_args(args, scope, mute_for, sound_id, show_preview, mute_stories, disable_pinned_message_notifications,
disable_mention_notifications);
get_args(args, scope, mute_for, sound_id, show_preview, mute_stories, story_sound_id, hide_story_sender,
disable_pinned_message_notifications, disable_mention_notifications);
if (op == "ssns") {
send_request(td_api::make_object<td_api::setScopeNotificationSettings>(
as_notification_settings_scope(scope),
@ -5532,9 +5532,10 @@ class CliClient final : public Actor {
} else {
auto settings = td_api::make_object<td_api::chatNotificationSettings>(
mute_for.empty(), to_integer<int32>(mute_for), sound_id == -1, sound_id, show_preview.empty(),
as_bool(show_preview), mute_stories.empty(), as_bool(mute_stories),
disable_pinned_message_notifications.empty(), as_bool(disable_pinned_message_notifications),
disable_mention_notifications.empty(), as_bool(disable_mention_notifications));
as_bool(show_preview), mute_stories.empty(), as_bool(mute_stories), story_sound_id == -1, story_sound_id,
hide_story_sender.empty(), as_bool(hide_story_sender), disable_pinned_message_notifications.empty(),
as_bool(disable_pinned_message_notifications), disable_mention_notifications.empty(),
as_bool(disable_mention_notifications));
if (op == "scns") {
send_request(
td_api::make_object<td_api::setChatNotificationSettings>(as_chat_id(scope), std::move(settings)));