Add message.can_be_saved.
This commit is contained in:
parent
0ce9391ff1
commit
c1a5d4b76b
@ -781,6 +781,7 @@ messageSendingStateFailed error_code:int32 error_message:string can_retry:Bool r
|
|||||||
//@is_pinned True, if the message is pinned
|
//@is_pinned True, if the message is pinned
|
||||||
//@can_be_edited True, if the message can be edited. For live location and poll messages this fields shows whether editMessageLiveLocation or stopPoll can be used with this message by the application
|
//@can_be_edited True, if the message can be edited. For live location and poll messages this fields shows whether editMessageLiveLocation or stopPoll can be used with this message by the application
|
||||||
//@can_be_forwarded True, if the message can be forwarded
|
//@can_be_forwarded True, if the message can be forwarded
|
||||||
|
//@can_be_saved True, if content of the message can be saved locally or copied
|
||||||
//@can_be_deleted_only_for_self True, if the message can be deleted only for the current user while other users will continue to see it
|
//@can_be_deleted_only_for_self True, if the message can be deleted only for the current user while other users will continue to see it
|
||||||
//@can_be_deleted_for_all_users True, if the message can be deleted for all users
|
//@can_be_deleted_for_all_users True, if the message can be deleted for all users
|
||||||
//@can_get_statistics True, if the message statistics are available
|
//@can_get_statistics True, if the message statistics are available
|
||||||
@ -805,7 +806,7 @@ messageSendingStateFailed error_code:int32 error_message:string can_retry:Bool r
|
|||||||
//@restriction_reason If non-empty, contains a human-readable description of the reason why access to this message must be restricted
|
//@restriction_reason If non-empty, contains a human-readable description of the reason why access to this message must be restricted
|
||||||
//@content Content of the message
|
//@content Content of the message
|
||||||
//@reply_markup Reply markup for the message; may be null
|
//@reply_markup Reply markup for the message; may be null
|
||||||
message id:int53 sender_id:MessageSender chat_id:int53 sending_state:MessageSendingState scheduling_state:MessageSchedulingState is_outgoing:Bool is_pinned:Bool can_be_edited:Bool can_be_forwarded:Bool can_be_deleted_only_for_self:Bool can_be_deleted_for_all_users:Bool can_get_statistics:Bool can_get_message_thread:Bool can_get_viewers:Bool can_get_media_timestamp_links:Bool has_timestamped_media:Bool is_channel_post:Bool contains_unread_mention:Bool date:int32 edit_date:int32 forward_info:messageForwardInfo interaction_info:messageInteractionInfo reply_in_chat_id:int53 reply_to_message_id:int53 message_thread_id:int53 ttl:int32 ttl_expires_in:double via_bot_user_id:int53 author_signature:string media_album_id:int64 restriction_reason:string content:MessageContent reply_markup:ReplyMarkup = Message;
|
message id:int53 sender_id:MessageSender chat_id:int53 sending_state:MessageSendingState scheduling_state:MessageSchedulingState is_outgoing:Bool is_pinned:Bool can_be_edited:Bool can_be_forwarded:Bool can_be_saved:Bool can_be_deleted_only_for_self:Bool can_be_deleted_for_all_users:Bool can_get_statistics:Bool can_get_message_thread:Bool can_get_viewers:Bool can_get_media_timestamp_links:Bool has_timestamped_media:Bool is_channel_post:Bool contains_unread_mention:Bool date:int32 edit_date:int32 forward_info:messageForwardInfo interaction_info:messageInteractionInfo reply_in_chat_id:int53 reply_to_message_id:int53 message_thread_id:int53 ttl:int32 ttl_expires_in:double via_bot_user_id:int53 author_signature:string media_album_id:int64 restriction_reason:string content:MessageContent reply_markup:ReplyMarkup = Message;
|
||||||
|
|
||||||
//@description Contains a list of messages @total_count Approximate total count of messages found @messages List of messages; messages may be null
|
//@description Contains a list of messages @total_count Approximate total count of messages found @messages List of messages; messages may be null
|
||||||
messages total_count:int32 messages:vector<message> = Messages;
|
messages total_count:int32 messages:vector<message> = Messages;
|
||||||
|
@ -4810,7 +4810,7 @@ void MessagesManager::Message::store(StorerT &storer) const {
|
|||||||
bool has_ttl_period = ttl_period != 0;
|
bool has_ttl_period = ttl_period != 0;
|
||||||
bool has_max_reply_media_timestamp = max_reply_media_timestamp >= 0;
|
bool has_max_reply_media_timestamp = max_reply_media_timestamp >= 0;
|
||||||
bool are_message_media_timestamp_entities_found = true;
|
bool are_message_media_timestamp_entities_found = true;
|
||||||
bool has_flags3 = false;
|
bool has_flags3 = true;
|
||||||
BEGIN_STORE_FLAGS();
|
BEGIN_STORE_FLAGS();
|
||||||
STORE_FLAG(is_channel_post);
|
STORE_FLAG(is_channel_post);
|
||||||
STORE_FLAG(is_outgoing);
|
STORE_FLAG(is_outgoing);
|
||||||
@ -4877,6 +4877,11 @@ void MessagesManager::Message::store(StorerT &storer) const {
|
|||||||
STORE_FLAG(has_flags3);
|
STORE_FLAG(has_flags3);
|
||||||
END_STORE_FLAGS();
|
END_STORE_FLAGS();
|
||||||
}
|
}
|
||||||
|
if (has_flags3) {
|
||||||
|
BEGIN_STORE_FLAGS();
|
||||||
|
STORE_FLAG(noforwards);
|
||||||
|
END_STORE_FLAGS();
|
||||||
|
}
|
||||||
|
|
||||||
store(message_id, storer);
|
store(message_id, storer);
|
||||||
if (has_sender) {
|
if (has_sender) {
|
||||||
@ -5104,6 +5109,7 @@ void MessagesManager::Message::parse(ParserT &parser) {
|
|||||||
}
|
}
|
||||||
if (has_flags3) {
|
if (has_flags3) {
|
||||||
BEGIN_PARSE_FLAGS();
|
BEGIN_PARSE_FLAGS();
|
||||||
|
PARSE_FLAG(noforwards);
|
||||||
END_PARSE_FLAGS();
|
END_PARSE_FLAGS();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -12371,6 +12377,7 @@ void MessagesManager::on_message_ttl_expired_impl(Dialog *d, Message *m) {
|
|||||||
remove_message_notification_id(d, m, true, true);
|
remove_message_notification_id(d, m, true, true);
|
||||||
update_message_contains_unread_mention(d, m, false, "on_message_ttl_expired_impl");
|
update_message_contains_unread_mention(d, m, false, "on_message_ttl_expired_impl");
|
||||||
unregister_message_reply(d, m);
|
unregister_message_reply(d, m);
|
||||||
|
m->noforwards = false;
|
||||||
m->contains_mention = false;
|
m->contains_mention = false;
|
||||||
m->reply_to_message_id = MessageId();
|
m->reply_to_message_id = MessageId();
|
||||||
m->max_reply_media_timestamp = -1;
|
m->max_reply_media_timestamp = -1;
|
||||||
@ -13545,6 +13552,7 @@ std::pair<DialogId, unique_ptr<MessagesManager::Message>> MessagesManager::creat
|
|||||||
bool hide_edit_date = (flags & MESSAGE_FLAG_HIDE_EDIT_DATE) != 0;
|
bool hide_edit_date = (flags & MESSAGE_FLAG_HIDE_EDIT_DATE) != 0;
|
||||||
bool is_from_scheduled = (flags & MESSAGE_FLAG_IS_FROM_SCHEDULED) != 0;
|
bool is_from_scheduled = (flags & MESSAGE_FLAG_IS_FROM_SCHEDULED) != 0;
|
||||||
bool is_pinned = (flags & MESSAGE_FLAG_IS_PINNED) != 0;
|
bool is_pinned = (flags & MESSAGE_FLAG_IS_PINNED) != 0;
|
||||||
|
bool noforwards = (flags & MESSAGE_FLAG_NOFORWARDS) != 0;
|
||||||
|
|
||||||
LOG_IF(ERROR, is_channel_message != (dialog_type == DialogType::Channel))
|
LOG_IF(ERROR, is_channel_message != (dialog_type == DialogType::Channel))
|
||||||
<< "is_channel_message is wrong for " << message_id << " received in the " << dialog_id;
|
<< "is_channel_message is wrong for " << message_id << " received in the " << dialog_id;
|
||||||
@ -13707,6 +13715,7 @@ std::pair<DialogId, unique_ptr<MessagesManager::Message>> MessagesManager::creat
|
|||||||
message->hide_edit_date = hide_edit_date;
|
message->hide_edit_date = hide_edit_date;
|
||||||
message->is_from_scheduled = is_from_scheduled;
|
message->is_from_scheduled = is_from_scheduled;
|
||||||
message->is_pinned = is_pinned;
|
message->is_pinned = is_pinned;
|
||||||
|
message->noforwards = noforwards;
|
||||||
message->view_count = view_count;
|
message->view_count = view_count;
|
||||||
message->forward_count = forward_count;
|
message->forward_count = forward_count;
|
||||||
message->reply_info = std::move(reply_info);
|
message->reply_info = std::move(reply_info);
|
||||||
@ -23520,8 +23529,9 @@ tl_object_ptr<td_api::message> MessagesManager::get_message_object(DialogId dial
|
|||||||
auto scheduling_state = is_scheduled ? get_message_scheduling_state_object(m->date) : nullptr;
|
auto scheduling_state = is_scheduled ? get_message_scheduling_state_object(m->date) : nullptr;
|
||||||
auto forward_info = get_message_forward_info_object(m->forward_info);
|
auto forward_info = get_message_forward_info_object(m->forward_info);
|
||||||
auto interaction_info = get_message_interaction_info_object(dialog_id, m);
|
auto interaction_info = get_message_interaction_info_object(dialog_id, m);
|
||||||
|
auto can_be_saved = !m->noforwards && get_dialog_allow_saving_content(dialog_id) && !m->is_content_secret;
|
||||||
auto can_be_edited = for_event_log ? false : can_edit_message(dialog_id, m, false, td_->auth_manager_->is_bot());
|
auto can_be_edited = for_event_log ? false : can_edit_message(dialog_id, m, false, td_->auth_manager_->is_bot());
|
||||||
auto can_be_forwarded = for_event_log ? false : can_forward_message(dialog_id, m);
|
auto can_be_forwarded = for_event_log ? false : can_forward_message(dialog_id, m) && can_be_saved;
|
||||||
auto can_get_statistics = for_event_log ? false : can_get_message_statistics(dialog_id, m);
|
auto can_get_statistics = for_event_log ? false : can_get_message_statistics(dialog_id, m);
|
||||||
auto can_get_message_thread = for_event_log ? false : get_top_thread_full_message_id(dialog_id, m).is_ok();
|
auto can_get_message_thread = for_event_log ? false : get_top_thread_full_message_id(dialog_id, m).is_ok();
|
||||||
auto can_get_viewers = for_event_log ? false : can_get_message_viewers(dialog_id, m).is_ok();
|
auto can_get_viewers = for_event_log ? false : can_get_message_viewers(dialog_id, m).is_ok();
|
||||||
@ -23547,11 +23557,11 @@ tl_object_ptr<td_api::message> MessagesManager::get_message_object(DialogId dial
|
|||||||
skip_bot_commands, max_media_timestamp);
|
skip_bot_commands, max_media_timestamp);
|
||||||
return make_tl_object<td_api::message>(
|
return make_tl_object<td_api::message>(
|
||||||
m->message_id.get(), std::move(sender), dialog_id.get(), std::move(sending_state), std::move(scheduling_state),
|
m->message_id.get(), std::move(sender), dialog_id.get(), std::move(sending_state), std::move(scheduling_state),
|
||||||
is_outgoing, is_pinned, can_be_edited, can_be_forwarded, can_delete_for_self, can_delete_for_all_users,
|
is_outgoing, is_pinned, can_be_edited, can_be_forwarded, can_be_saved, can_delete_for_self,
|
||||||
can_get_statistics, can_get_message_thread, can_get_viewers, can_get_media_timestamp_links, has_timestamped_media,
|
can_delete_for_all_users, can_get_statistics, can_get_message_thread, can_get_viewers,
|
||||||
m->is_channel_post, contains_unread_mention, date, edit_date, std::move(forward_info),
|
can_get_media_timestamp_links, has_timestamped_media, m->is_channel_post, contains_unread_mention, date,
|
||||||
std::move(interaction_info), reply_in_dialog_id.get(), reply_to_message_id, top_thread_message_id, ttl,
|
edit_date, std::move(forward_info), std::move(interaction_info), reply_in_dialog_id.get(), reply_to_message_id,
|
||||||
ttl_expires_in, via_bot_user_id, m->author_signature, media_album_id,
|
top_thread_message_id, ttl, ttl_expires_in, via_bot_user_id, m->author_signature, media_album_id,
|
||||||
get_restriction_reason_description(m->restriction_reasons), std::move(content), std::move(reply_markup));
|
get_restriction_reason_description(m->restriction_reasons), std::move(content), std::move(reply_markup));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -34178,8 +34188,13 @@ bool MessagesManager::update_message(Dialog *d, Message *old_message, unique_ptr
|
|||||||
std::move(new_message->reply_info), "update_message")) {
|
std::move(new_message->reply_info), "update_message")) {
|
||||||
need_send_update = true;
|
need_send_update = true;
|
||||||
}
|
}
|
||||||
|
if (old_message->noforwards != new_message->noforwards) {
|
||||||
|
old_message->noforwards = new_message->noforwards;
|
||||||
|
need_send_update = true;
|
||||||
|
}
|
||||||
if (old_message->restriction_reasons != new_message->restriction_reasons) {
|
if (old_message->restriction_reasons != new_message->restriction_reasons) {
|
||||||
old_message->restriction_reasons = std::move(new_message->restriction_reasons);
|
old_message->restriction_reasons = std::move(new_message->restriction_reasons);
|
||||||
|
need_send_update = true;
|
||||||
}
|
}
|
||||||
if (old_message->legacy_layer != new_message->legacy_layer) {
|
if (old_message->legacy_layer != new_message->legacy_layer) {
|
||||||
old_message->legacy_layer = new_message->legacy_layer;
|
old_message->legacy_layer = new_message->legacy_layer;
|
||||||
|
@ -120,6 +120,7 @@ class MessagesManager final : public Actor {
|
|||||||
static constexpr int32 MESSAGE_FLAG_HAS_REPLY_INFO = 1 << 23;
|
static constexpr int32 MESSAGE_FLAG_HAS_REPLY_INFO = 1 << 23;
|
||||||
static constexpr int32 MESSAGE_FLAG_IS_PINNED = 1 << 24;
|
static constexpr int32 MESSAGE_FLAG_IS_PINNED = 1 << 24;
|
||||||
static constexpr int32 MESSAGE_FLAG_HAS_TTL_PERIOD = 1 << 25;
|
static constexpr int32 MESSAGE_FLAG_HAS_TTL_PERIOD = 1 << 25;
|
||||||
|
static constexpr int32 MESSAGE_FLAG_NOFORWARDS = 1 << 26;
|
||||||
|
|
||||||
static constexpr int32 SEND_MESSAGE_FLAG_IS_REPLY = 1 << 0;
|
static constexpr int32 SEND_MESSAGE_FLAG_IS_REPLY = 1 << 0;
|
||||||
static constexpr int32 SEND_MESSAGE_FLAG_DISABLE_WEB_PAGE_PREVIEW = 1 << 1;
|
static constexpr int32 SEND_MESSAGE_FLAG_DISABLE_WEB_PAGE_PREVIEW = 1 << 1;
|
||||||
@ -1082,6 +1083,7 @@ class MessagesManager final : public Actor {
|
|||||||
bool is_from_scheduled = false;
|
bool is_from_scheduled = false;
|
||||||
bool is_pinned = false;
|
bool is_pinned = false;
|
||||||
bool are_media_timestamp_entities_found = false;
|
bool are_media_timestamp_entities_found = false;
|
||||||
|
bool noforwards = false;
|
||||||
|
|
||||||
bool is_copy = false; // for send_message
|
bool is_copy = false; // for send_message
|
||||||
bool from_background = false; // for send_message
|
bool from_background = false; // for send_message
|
||||||
|
Loading…
x
Reference in New Issue
Block a user