Add linkPreviewOptions.show_above_text.

This commit is contained in:
levlam 2023-10-22 00:50:19 +03:00
parent cb51944cb7
commit 2bbb0ed0ec
9 changed files with 113 additions and 62 deletions

View File

@ -2980,7 +2980,8 @@ messageCopyOptions send_copy:Bool replace_caption:Bool new_caption:formattedText
//@url URL to use for link preview. If empty, then the first URL found in the message text will be used //@url URL to use for link preview. If empty, then the first URL found in the message text will be used
//@force_small_media True, if shown media preview must be small; ignored in secret chats or if the URL isn't explicitly specified //@force_small_media True, if shown media preview must be small; ignored in secret chats or if the URL isn't explicitly specified
//@force_large_media True, if shown media preview must be large; ignored in secret chats or if the URL isn't explicitly specified //@force_large_media True, if shown media preview must be large; ignored in secret chats or if the URL isn't explicitly specified
linkPreviewOptions is_disabled:Bool url:string force_small_media:Bool force_large_media:Bool = LinkPreviewOptions; //@show_above_text True, if link preview must be shown above message text; otherwise, the link preview will be shown below the message text; ignored in secret chats
linkPreviewOptions is_disabled:Bool url:string force_small_media:Bool force_large_media:Bool show_above_text:Bool = LinkPreviewOptions;
//@class InputMessageContent @description The content of a message to send //@class InputMessageContent @description The content of a message to send

View File

@ -53,6 +53,10 @@ class SaveDraftMessageQuery final : public Td::ResultHandler {
*/ */
if (draft_message->input_message_text_.disable_web_page_preview) { if (draft_message->input_message_text_.disable_web_page_preview) {
flags |= telegram_api::messages_saveDraft::NO_WEBPAGE_MASK; flags |= telegram_api::messages_saveDraft::NO_WEBPAGE_MASK;
} else {
if (draft_message->input_message_text_.show_above_text) {
flags |= telegram_api::messages_saveDraft::INVERT_MEDIA_MASK;
}
} }
input_message_entities = get_input_message_entities( input_message_entities = get_input_message_entities(
td_->contacts_manager_.get(), draft_message->input_message_text_.text.entities, "SaveDraftMessageQuery"); td_->contacts_manager_.get(), draft_message->input_message_text_.text.entities, "SaveDraftMessageQuery");
@ -210,9 +214,9 @@ DraftMessage::DraftMessage(Td *td, telegram_api::object_ptr<telegram_api::draftM
force_large_media = media->force_large_media_; force_large_media = media->force_large_media_;
} }
} }
input_message_text_ = input_message_text_ = InputMessageText(FormattedText{std::move(draft_message->message_), std::move(entities)},
InputMessageText(FormattedText{std::move(draft_message->message_), std::move(entities)}, std::move(web_page_url), std::move(web_page_url), draft_message->no_webpage_, force_small_media,
draft_message->no_webpage_, force_small_media, force_large_media, false); force_large_media, draft_message->invert_media_, false);
} }
Result<unique_ptr<DraftMessage>> DraftMessage::get_draft_message( Result<unique_ptr<DraftMessage>> DraftMessage::get_draft_message(

View File

@ -394,6 +394,9 @@ Result<tl_object_ptr<telegram_api::InputBotInlineMessage>> InlineQueriesManager:
if (input_message_text.force_large_media) { if (input_message_text.force_large_media) {
flags |= telegram_api::inputBotInlineMessageMediaWebPage::FORCE_LARGE_MEDIA_MASK; flags |= telegram_api::inputBotInlineMessageMediaWebPage::FORCE_LARGE_MEDIA_MASK;
} }
if (input_message_text.show_above_text) {
flags |= telegram_api::inputBotInlineMessageMediaWebPage::INVERT_MEDIA_MASK;
}
if (!input_message_text.text.text.empty()) { if (!input_message_text.text.text.empty()) {
flags |= telegram_api::inputBotInlineMessageMediaWebPage::OPTIONAL_MASK; flags |= telegram_api::inputBotInlineMessageMediaWebPage::OPTIONAL_MASK;
} }
@ -408,6 +411,8 @@ Result<tl_object_ptr<telegram_api::InputBotInlineMessage>> InlineQueriesManager:
} }
if (input_message_text.disable_web_page_preview) { if (input_message_text.disable_web_page_preview) {
flags |= telegram_api::inputBotInlineMessageText::NO_WEBPAGE_MASK; flags |= telegram_api::inputBotInlineMessageText::NO_WEBPAGE_MASK;
} else if (input_message_text.show_above_text) {
flags |= telegram_api::inputBotInlineMessageText::INVERT_MEDIA_MASK;
} }
if (!entities.empty()) { if (!entities.empty()) {
flags |= telegram_api::inputBotInlineMessageText::ENTITIES_MASK; flags |= telegram_api::inputBotInlineMessageText::ENTITIES_MASK;

View File

@ -34,12 +34,14 @@ Result<InputMessageText> process_input_message_text(const Td *td, DialogId dialo
bool disable_web_page_preview = false; bool disable_web_page_preview = false;
bool force_small_media = false; bool force_small_media = false;
bool force_large_media = false; bool force_large_media = false;
bool show_above_text = false;
if (input_message_text->link_preview_options_ != nullptr) { if (input_message_text->link_preview_options_ != nullptr) {
auto options = std::move(input_message_text->link_preview_options_); auto options = std::move(input_message_text->link_preview_options_);
web_page_url = std::move(options->url_); web_page_url = std::move(options->url_);
disable_web_page_preview = options->is_disabled_; disable_web_page_preview = options->is_disabled_;
force_small_media = options->force_small_media_; force_small_media = options->force_small_media_;
force_large_media = options->force_large_media_; force_large_media = options->force_large_media_;
show_above_text = options->show_above_text_;
if (!clean_input_string(web_page_url)) { if (!clean_input_string(web_page_url)) {
return Status::Error(400, "Link preview URL must be encoded in UTF-8"); return Status::Error(400, "Link preview URL must be encoded in UTF-8");
@ -60,8 +62,9 @@ Result<InputMessageText> process_input_message_text(const Td *td, DialogId dialo
if (!disable_web_page_preview && web_page_url.empty() && dialog_id.get_type() == DialogType::SecretChat) { if (!disable_web_page_preview && web_page_url.empty() && dialog_id.get_type() == DialogType::SecretChat) {
web_page_url = get_first_url(text); web_page_url = get_first_url(text);
} }
return InputMessageText{std::move(text), std::move(web_page_url), disable_web_page_preview, return InputMessageText{
force_small_media, force_large_media, input_message_text->clear_draft_}; std::move(text), std::move(web_page_url), disable_web_page_preview, force_small_media,
force_large_media, show_above_text, input_message_text->clear_draft_};
} }
void InputMessageText::add_dependencies(Dependencies &dependencies) const { void InputMessageText::add_dependencies(Dependencies &dependencies) const {
@ -89,9 +92,9 @@ telegram_api::object_ptr<telegram_api::InputMedia> InputMessageText::get_input_m
// used only for draft // used only for draft
td_api::object_ptr<td_api::inputMessageText> InputMessageText::get_input_message_text_object() const { td_api::object_ptr<td_api::inputMessageText> InputMessageText::get_input_message_text_object() const {
td_api::object_ptr<td_api::linkPreviewOptions> options; td_api::object_ptr<td_api::linkPreviewOptions> options;
if (!web_page_url.empty() || disable_web_page_preview || force_small_media || force_large_media) { if (!web_page_url.empty() || disable_web_page_preview || force_small_media || force_large_media || show_above_text) {
options = td_api::make_object<td_api::linkPreviewOptions>(disable_web_page_preview, web_page_url, force_small_media, options = td_api::make_object<td_api::linkPreviewOptions>(disable_web_page_preview, web_page_url, force_small_media,
force_large_media); force_large_media, show_above_text);
} }
return td_api::make_object<td_api::inputMessageText>(get_formatted_text_object(text, false, -1), std::move(options), return td_api::make_object<td_api::inputMessageText>(get_formatted_text_object(text, false, -1), std::move(options),
clear_draft); clear_draft);

View File

@ -25,16 +25,18 @@ class InputMessageText {
bool disable_web_page_preview = false; bool disable_web_page_preview = false;
bool force_small_media = false; bool force_small_media = false;
bool force_large_media = false; bool force_large_media = false;
bool show_above_text = false;
bool clear_draft = false; bool clear_draft = false;
InputMessageText() = default; InputMessageText() = default;
InputMessageText(FormattedText text, string &&web_page_url, bool disable_web_page_preview, bool force_small_media, InputMessageText(FormattedText text, string &&web_page_url, bool disable_web_page_preview, bool force_small_media,
bool force_large_media, bool clear_draft) bool force_large_media, bool show_above_text, bool clear_draft)
: text(std::move(text)) : text(std::move(text))
, web_page_url(std::move(web_page_url)) , web_page_url(std::move(web_page_url))
, disable_web_page_preview(disable_web_page_preview) , disable_web_page_preview(disable_web_page_preview)
, force_small_media(force_small_media) , force_small_media(force_small_media)
, force_large_media(force_large_media) , force_large_media(force_large_media)
, show_above_text(show_above_text)
, clear_draft(clear_draft) { , clear_draft(clear_draft) {
} }

View File

@ -2066,6 +2066,7 @@ InlineMessageContent create_inline_message_content(Td *td, FileId file_id,
InlineMessageContent result; InlineMessageContent result;
tl_object_ptr<telegram_api::ReplyMarkup> reply_markup; tl_object_ptr<telegram_api::ReplyMarkup> reply_markup;
result.disable_web_page_preview = false; result.disable_web_page_preview = false;
result.invert_media = false;
switch (bot_inline_message->get_id()) { switch (bot_inline_message->get_id()) {
case telegram_api::botInlineMessageText::ID: { case telegram_api::botInlineMessageText::ID: {
auto inline_message = move_tl_object_as<telegram_api::botInlineMessageText>(bot_inline_message); auto inline_message = move_tl_object_as<telegram_api::botInlineMessageText>(bot_inline_message);
@ -2078,6 +2079,7 @@ InlineMessageContent create_inline_message_content(Td *td, FileId file_id,
} }
result.disable_web_page_preview = inline_message->no_webpage_; result.disable_web_page_preview = inline_message->no_webpage_;
result.invert_media = inline_message->invert_media_;
FormattedText text{std::move(inline_message->message_), std::move(entities)}; FormattedText text{std::move(inline_message->message_), std::move(entities)};
WebPageId web_page_id; WebPageId web_page_id;
if (!result.disable_web_page_preview) { if (!result.disable_web_page_preview) {
@ -2111,6 +2113,7 @@ InlineMessageContent create_inline_message_content(Td *td, FileId file_id,
std::move(text), web_page_id, inline_message->force_small_media_, inline_message->force_large_media_, std::move(text), web_page_id, inline_message->force_small_media_, inline_message->force_large_media_,
inline_message->safe_, std::move(web_page_url)); inline_message->safe_, std::move(web_page_url));
reply_markup = std::move(inline_message->reply_markup_); reply_markup = std::move(inline_message->reply_markup_);
result.invert_media = inline_message->invert_media_;
break; break;
} }
case telegram_api::botInlineMessageMediaInvoice::ID: { case telegram_api::botInlineMessageMediaInvoice::ID: {
@ -2175,6 +2178,7 @@ InlineMessageContent create_inline_message_content(Td *td, FileId file_id,
LOG(WARNING) << "Unallowed bot inline message " << to_string(inline_message); LOG(WARNING) << "Unallowed bot inline message " << to_string(inline_message);
} }
result.invert_media = inline_message->invert_media_;
reply_markup = std::move(inline_message->reply_markup_); reply_markup = std::move(inline_message->reply_markup_);
break; break;
} }
@ -2223,6 +2227,7 @@ static Result<InputMessageContent> create_input_message_content(
} }
bool disable_web_page_preview = false; bool disable_web_page_preview = false;
bool invert_media = false;
bool clear_draft = false; bool clear_draft = false;
unique_ptr<MessageContent> content; unique_ptr<MessageContent> content;
UserId via_bot_user_id; UserId via_bot_user_id;
@ -2236,6 +2241,7 @@ static Result<InputMessageContent> create_input_message_content(
process_input_message_text(td, dialog_id, std::move(input_message_content), is_bot)); process_input_message_text(td, dialog_id, std::move(input_message_content), is_bot));
auto web_page_url = std::move(input_message_text.web_page_url); auto web_page_url = std::move(input_message_text.web_page_url);
disable_web_page_preview = input_message_text.disable_web_page_preview; disable_web_page_preview = input_message_text.disable_web_page_preview;
invert_media = input_message_text.show_above_text;
clear_draft = input_message_text.clear_draft; clear_draft = input_message_text.clear_draft;
if (is_bot && static_cast<int64>(utf8_length(input_message_text.text.text)) > if (is_bot && static_cast<int64>(utf8_length(input_message_text.text.text)) >
@ -2522,7 +2528,7 @@ static Result<InputMessageContent> create_input_message_content(
} }
} }
return InputMessageContent{std::move(content), disable_web_page_preview, clear_draft, ttl, return InputMessageContent{std::move(content), disable_web_page_preview, invert_media, clear_draft, ttl,
via_bot_user_id, std::move(emoji)}; via_bot_user_id, std::move(emoji)};
} }

View File

@ -62,15 +62,17 @@ class MessageContent {
struct InputMessageContent { struct InputMessageContent {
unique_ptr<MessageContent> content; unique_ptr<MessageContent> content;
bool disable_web_page_preview = false; bool disable_web_page_preview = false;
bool invert_media = false;
bool clear_draft = false; bool clear_draft = false;
int32 ttl = 0; int32 ttl = 0;
UserId via_bot_user_id; UserId via_bot_user_id;
string emoji; string emoji;
InputMessageContent(unique_ptr<MessageContent> &&content, bool disable_web_page_preview, bool clear_draft, int32 ttl, InputMessageContent(unique_ptr<MessageContent> &&content, bool disable_web_page_preview, bool invert_media,
UserId via_bot_user_id, string emoji) bool clear_draft, int32 ttl, UserId via_bot_user_id, string emoji)
: content(std::move(content)) : content(std::move(content))
, disable_web_page_preview(disable_web_page_preview) , disable_web_page_preview(disable_web_page_preview)
, invert_media(invert_media)
, clear_draft(clear_draft) , clear_draft(clear_draft)
, ttl(ttl) , ttl(ttl)
, via_bot_user_id(via_bot_user_id) , via_bot_user_id(via_bot_user_id)
@ -82,6 +84,7 @@ struct InlineMessageContent {
unique_ptr<MessageContent> message_content; unique_ptr<MessageContent> message_content;
unique_ptr<ReplyMarkup> message_reply_markup; unique_ptr<ReplyMarkup> message_reply_markup;
bool disable_web_page_preview; bool disable_web_page_preview;
bool invert_media;
}; };
void store_message_content(const MessageContent *content, LogEventStorerCalcLength &storer); void store_message_content(const MessageContent *content, LogEventStorerCalcLength &storer);

View File

@ -3665,7 +3665,7 @@ class EditMessageQuery final : public Td::ResultHandler {
void send(int32 flags, DialogId dialog_id, MessageId message_id, const string &text, void send(int32 flags, DialogId dialog_id, MessageId message_id, const string &text,
vector<tl_object_ptr<telegram_api::MessageEntity>> &&entities, vector<tl_object_ptr<telegram_api::MessageEntity>> &&entities,
tl_object_ptr<telegram_api::InputMedia> &&input_media, tl_object_ptr<telegram_api::InputMedia> &&input_media, bool invert_media,
tl_object_ptr<telegram_api::ReplyMarkup> &&reply_markup, int32 schedule_date) { tl_object_ptr<telegram_api::ReplyMarkup> &&reply_markup, int32 schedule_date) {
dialog_id_ = dialog_id; dialog_id_ = dialog_id;
message_id_ = message_id; message_id_ = message_id;
@ -3691,6 +3691,9 @@ class EditMessageQuery final : public Td::ResultHandler {
if (input_media != nullptr) { if (input_media != nullptr) {
flags |= telegram_api::messages_editMessage::MEDIA_MASK; flags |= telegram_api::messages_editMessage::MEDIA_MASK;
} }
if (invert_media) {
flags |= telegram_api::messages_editMessage::INVERT_MEDIA_MASK;
}
if (schedule_date != 0) { if (schedule_date != 0) {
flags |= telegram_api::messages_editMessage::SCHEDULE_DATE_MASK; flags |= telegram_api::messages_editMessage::SCHEDULE_DATE_MASK;
} }
@ -3737,7 +3740,7 @@ class EditInlineMessageQuery final : public Td::ResultHandler {
void send(int32 flags, tl_object_ptr<telegram_api::InputBotInlineMessageID> input_bot_inline_message_id, void send(int32 flags, tl_object_ptr<telegram_api::InputBotInlineMessageID> input_bot_inline_message_id,
const string &text, vector<tl_object_ptr<telegram_api::MessageEntity>> &&entities, const string &text, vector<tl_object_ptr<telegram_api::MessageEntity>> &&entities,
tl_object_ptr<telegram_api::InputMedia> &&input_media, tl_object_ptr<telegram_api::InputMedia> &&input_media, bool invert_media,
tl_object_ptr<telegram_api::ReplyMarkup> &&reply_markup) { tl_object_ptr<telegram_api::ReplyMarkup> &&reply_markup) {
CHECK(input_bot_inline_message_id != nullptr); CHECK(input_bot_inline_message_id != nullptr);
@ -3757,6 +3760,9 @@ class EditInlineMessageQuery final : public Td::ResultHandler {
if (input_media != nullptr) { if (input_media != nullptr) {
flags |= telegram_api::messages_editInlineBotMessage::MEDIA_MASK; flags |= telegram_api::messages_editInlineBotMessage::MEDIA_MASK;
} }
if (invert_media) {
flags |= telegram_api::messages_editInlineBotMessage::INVERT_MEDIA_MASK;
}
auto dc_id = DcId::internal(InlineQueriesManager::get_inline_message_dc_id(input_bot_inline_message_id)); auto dc_id = DcId::internal(InlineQueriesManager::get_inline_message_dc_id(input_bot_inline_message_id));
send_query(G()->net_query_creator().create( send_query(G()->net_query_creator().create(
@ -6564,7 +6570,7 @@ void MessagesManager::on_update_service_notification(tl_object_ptr<telegram_api:
send_closure(G()->td(), &Td::send_update, send_closure(G()->td(), &Td::send_update,
td_api::make_object<td_api::updateServiceNotification>( td_api::make_object<td_api::updateServiceNotification>(
update->type_, get_message_content_object(content.get(), td_, owner_dialog_id, date, update->type_, get_message_content_object(content.get(), td_, owner_dialog_id, date,
is_content_secret, true, -1, false))); is_content_secret, true, -1, update->invert_media_)));
} }
if (has_date && is_user) { if (has_date && is_user) {
Dialog *d = get_service_notifications_dialog(); Dialog *d = get_service_notifications_dialog();
@ -6579,6 +6585,7 @@ void MessagesManager::on_update_service_notification(tl_object_ptr<telegram_api:
new_message->ttl = ttl; new_message->ttl = ttl;
new_message->disable_web_page_preview = disable_web_page_preview; new_message->disable_web_page_preview = disable_web_page_preview;
new_message->is_content_secret = is_content_secret; new_message->is_content_secret = is_content_secret;
new_message->invert_media = update->invert_media_;
new_message->content = std::move(content); new_message->content = std::move(content);
bool need_update = true; bool need_update = true;
@ -14453,6 +14460,7 @@ std::pair<DialogId, unique_ptr<MessagesManager::Message>> MessagesManager::creat
LOG(INFO) << "Replace emoji sticker with an empty message"; LOG(INFO) << "Replace emoji sticker with an empty message";
message_info.content = message_info.content =
create_text_message_content("Invalid sticker", {}, WebPageId(), false, false, false, string()); create_text_message_content("Invalid sticker", {}, WebPageId(), false, false, false, string());
message_info.invert_media = false;
content_type = message_info.content->get_type(); content_type = message_info.content->get_type();
} }
@ -24228,8 +24236,8 @@ int64 MessagesManager::generate_new_random_id(const Dialog *d) {
unique_ptr<MessagesManager::Message> MessagesManager::create_message_to_send( unique_ptr<MessagesManager::Message> MessagesManager::create_message_to_send(
Dialog *d, MessageId top_thread_message_id, MessageInputReplyTo input_reply_to, const MessageSendOptions &options, Dialog *d, MessageId top_thread_message_id, MessageInputReplyTo input_reply_to, const MessageSendOptions &options,
unique_ptr<MessageContent> &&content, bool suppress_reply_info, unique_ptr<MessageForwardInfo> forward_info, unique_ptr<MessageContent> &&content, bool invert_media, bool suppress_reply_info,
bool is_copy, DialogId send_as_dialog_id) const { unique_ptr<MessageForwardInfo> forward_info, bool is_copy, DialogId send_as_dialog_id) const {
CHECK(d != nullptr); CHECK(d != nullptr);
CHECK(content != nullptr); CHECK(content != nullptr);
@ -24343,6 +24351,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::create_message_to_send(
} }
} }
m->content = std::move(content); m->content = std::move(content);
m->invert_media = invert_media;
m->forward_info = std::move(forward_info); m->forward_info = std::move(forward_info);
m->is_copy = is_copy || m->forward_info != nullptr; m->is_copy = is_copy || m->forward_info != nullptr;
m->sending_id = options.sending_id; m->sending_id = options.sending_id;
@ -24368,12 +24377,13 @@ unique_ptr<MessagesManager::Message> MessagesManager::create_message_to_send(
MessagesManager::Message *MessagesManager::get_message_to_send( MessagesManager::Message *MessagesManager::get_message_to_send(
Dialog *d, MessageId top_thread_message_id, MessageInputReplyTo input_reply_to, const MessageSendOptions &options, Dialog *d, MessageId top_thread_message_id, MessageInputReplyTo input_reply_to, const MessageSendOptions &options,
unique_ptr<MessageContent> &&content, bool *need_update_dialog_pos, bool suppress_reply_info, unique_ptr<MessageContent> &&content, bool invert_media, bool *need_update_dialog_pos, bool suppress_reply_info,
unique_ptr<MessageForwardInfo> forward_info, bool is_copy, DialogId send_as_dialog_id) { unique_ptr<MessageForwardInfo> forward_info, bool is_copy, DialogId send_as_dialog_id) {
d->was_opened = true; d->was_opened = true;
auto message = create_message_to_send(d, top_thread_message_id, input_reply_to, options, std::move(content), auto message =
suppress_reply_info, std::move(forward_info), is_copy, send_as_dialog_id); create_message_to_send(d, top_thread_message_id, input_reply_to, options, std::move(content), invert_media,
suppress_reply_info, std::move(forward_info), is_copy, send_as_dialog_id);
MessageId message_id = options.schedule_date != 0 ? get_next_yet_unsent_scheduled_message_id(d, options.schedule_date) MessageId message_id = options.schedule_date != 0 ? get_next_yet_unsent_scheduled_message_id(d, options.schedule_date)
: get_next_yet_unsent_message_id(d); : get_next_yet_unsent_message_id(d);
@ -24907,7 +24917,8 @@ Result<td_api::object_ptr<td_api::message>> MessagesManager::send_message(
Message *m = get_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options, Message *m = get_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options,
dup_message_content(td_, dialog_id, message_content.content.get(), dup_message_content(td_, dialog_id, message_content.content.get(),
MessageContentDupType::Send, MessageCopyOptions()), MessageContentDupType::Send, MessageCopyOptions()),
&need_update_dialog_pos, false, nullptr, message_content.via_bot_user_id.is_valid()); message_content.invert_media, &need_update_dialog_pos, false, nullptr,
message_content.via_bot_user_id.is_valid());
m->reply_markup = std::move(message_reply_markup); m->reply_markup = std::move(message_reply_markup);
m->via_bot_user_id = message_content.via_bot_user_id; m->via_bot_user_id = message_content.via_bot_user_id;
m->disable_web_page_preview = message_content.disable_web_page_preview; m->disable_web_page_preview = message_content.disable_web_page_preview;
@ -24979,8 +24990,8 @@ Result<InputMessageContent> MessagesManager::process_input_message_content(
return Status::Error(400, "Can't copy message content"); return Status::Error(400, "Can't copy message content");
} }
return InputMessageContent(std::move(content), get_message_disable_web_page_preview(copied_message), false, 0, return InputMessageContent(std::move(content), get_message_disable_web_page_preview(copied_message),
UserId(), copied_message->send_emoji); copied_message->invert_media, false, 0, UserId(), copied_message->send_emoji);
} }
bool is_premium = td_->option_manager_->get_option_boolean("is_premium"); bool is_premium = td_->option_manager_->get_option_boolean("is_premium");
@ -25128,7 +25139,7 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::send_message_group
TRY_STATUS(can_send_message(dialog_id)); TRY_STATUS(can_send_message(dialog_id));
TRY_RESULT(message_send_options, process_message_send_options(dialog_id, std::move(options), true)); TRY_RESULT(message_send_options, process_message_send_options(dialog_id, std::move(options), true));
vector<std::pair<unique_ptr<MessageContent>, int32>> message_contents; vector<InputMessageContent> message_contents;
std::unordered_set<MessageContentType, MessageContentTypeHash> message_content_types; std::unordered_set<MessageContentType, MessageContentTypeHash> message_content_types;
for (auto &input_message_content : input_message_contents) { for (auto &input_message_content : input_message_contents) {
TRY_RESULT(message_content, process_input_message_content(dialog_id, std::move(input_message_content))); TRY_RESULT(message_content, process_input_message_content(dialog_id, std::move(input_message_content)));
@ -25139,7 +25150,7 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::send_message_group
} }
message_content_types.insert(message_content_type); message_content_types.insert(message_content_type);
message_contents.emplace_back(std::move(message_content.content), message_content.ttl); message_contents.push_back(std::move(message_content));
} }
if (message_content_types.size() > 1) { if (message_content_types.size() > 1) {
for (auto message_content_type : message_content_types) { for (auto message_content_type : message_content_types) {
@ -25167,7 +25178,8 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::send_message_group
Message *m; Message *m;
if (only_preview) { if (only_preview) {
message = create_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options, message = create_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options,
std::move(message_content.first), i != 0, nullptr, false, DialogId()); std::move(message_content.content), message_content.invert_media, i != 0,
nullptr, false, DialogId());
MessageId new_message_id = message_send_options.schedule_date != 0 MessageId new_message_id = message_send_options.schedule_date != 0
? get_next_yet_unsent_scheduled_message_id(d, message_send_options.schedule_date) ? get_next_yet_unsent_scheduled_message_id(d, message_send_options.schedule_date)
: get_next_yet_unsent_message_id(d); : get_next_yet_unsent_message_id(d);
@ -25175,12 +25187,12 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::send_message_group
m = message.get(); m = message.get();
} else { } else {
m = get_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options, m = get_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options,
dup_message_content(td_, dialog_id, message_content.first.get(), dup_message_content(td_, dialog_id, message_content.content.get(),
MessageContentDupType::Send, MessageCopyOptions()), MessageContentDupType::Send, MessageCopyOptions()),
&need_update_dialog_pos, i != 0); message_content.invert_media, &need_update_dialog_pos, i != 0);
} }
auto ttl = message_content.second; auto ttl = message_content.ttl;
if (ttl > 0) { if (ttl > 0) {
m->ttl = ttl; m->ttl = ttl;
m->is_content_secret = is_secret_message_content(m->ttl, m->content->get_type()); m->is_content_secret = is_secret_message_content(m->ttl, m->content->get_type());
@ -25322,7 +25334,7 @@ void MessagesManager::on_message_media_uploaded(DialogId dialog_id, const Messag
td_->create_handler<EditMessageQuery>(std::move(promise)) td_->create_handler<EditMessageQuery>(std::move(promise))
->send(1 << 11, dialog_id, message_id, caption == nullptr ? "" : caption->text, ->send(1 << 11, dialog_id, message_id, caption == nullptr ? "" : caption->text,
get_input_message_entities(td_->contacts_manager_.get(), caption, "edit_message_media"), get_input_message_entities(td_->contacts_manager_.get(), caption, "edit_message_media"),
std::move(input_media), std::move(input_reply_markup), schedule_date); std::move(input_media), m->edited_invert_media, std::move(input_reply_markup), schedule_date);
return; return;
} }
@ -25917,7 +25929,7 @@ Result<MessageId> MessagesManager::send_bot_start_message(UserId bot_user_id, Di
bool need_update_dialog_pos = false; bool need_update_dialog_pos = false;
Message *m = get_message_to_send( Message *m = get_message_to_send(
d, MessageId(), MessageInputReplyTo(), MessageSendOptions(), d, MessageId(), MessageInputReplyTo(), MessageSendOptions(),
create_text_message_content(text, std::move(text_entities), WebPageId(), false, false, false, string()), create_text_message_content(text, std::move(text_entities), WebPageId(), false, false, false, string()), false,
&need_update_dialog_pos); &need_update_dialog_pos);
m->is_bot_start_message = true; m->is_bot_start_message = true;
@ -26055,7 +26067,7 @@ Result<MessageId> MessagesManager::send_inline_query_result_message(
Message *m = get_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options, Message *m = get_message_to_send(d, top_thread_message_id, input_reply_to, message_send_options,
dup_message_content(td_, dialog_id, content->message_content.get(), dup_message_content(td_, dialog_id, content->message_content.get(),
MessageContentDupType::SendViaBot, MessageCopyOptions()), MessageContentDupType::SendViaBot, MessageCopyOptions()),
&need_update_dialog_pos, false, nullptr, true); content->invert_media, &need_update_dialog_pos, false, nullptr, true);
m->hide_via_bot = hide_via_bot; m->hide_via_bot = hide_via_bot;
if (!hide_via_bot) { if (!hide_via_bot) {
m->via_bot_user_id = td_->inline_queries_manager_->get_inline_bot_user_id(query_id); m->via_bot_user_id = td_->inline_queries_manager_->get_inline_bot_user_id(query_id);
@ -26518,8 +26530,8 @@ void MessagesManager::edit_message_text(MessageFullId message_full_id,
->send(flags, dialog_id, m->message_id, input_message_text.text.text, ->send(flags, dialog_id, m->message_id, input_message_text.text.text,
get_input_message_entities(td_->contacts_manager_.get(), input_message_text.text.entities, get_input_message_entities(td_->contacts_manager_.get(), input_message_text.text.entities,
"edit_message_text"), "edit_message_text"),
input_message_text.get_input_media_web_page(), std::move(input_reply_markup), input_message_text.get_input_media_web_page(), input_message_text.show_above_text,
get_message_schedule_date(m)); std::move(input_reply_markup), get_message_schedule_date(m));
} }
void MessagesManager::edit_message_live_location(MessageFullId message_full_id, void MessagesManager::edit_message_live_location(MessageFullId message_full_id,
@ -26578,7 +26590,7 @@ void MessagesManager::edit_message_live_location(MessageFullId message_full_id,
flags, false /*ignored*/, location.get_input_geo_point(), heading, 0, proximity_alert_radius); flags, false /*ignored*/, location.get_input_geo_point(), heading, 0, proximity_alert_radius);
td_->create_handler<EditMessageQuery>(std::move(promise)) td_->create_handler<EditMessageQuery>(std::move(promise))
->send(0, dialog_id, m->message_id, string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(), ->send(0, dialog_id, m->message_id, string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(),
std::move(input_media), std::move(input_reply_markup), get_message_schedule_date(m)); std::move(input_media), false, std::move(input_reply_markup), get_message_schedule_date(m));
} }
void MessagesManager::cancel_edit_message_media(DialogId dialog_id, Message *m, Slice error_message) { void MessagesManager::cancel_edit_message_media(DialogId dialog_id, Message *m, Slice error_message) {
@ -26589,6 +26601,7 @@ void MessagesManager::cancel_edit_message_media(DialogId dialog_id, Message *m,
cancel_upload_message_content_files(m->edited_content.get()); cancel_upload_message_content_files(m->edited_content.get());
m->edited_content = nullptr; m->edited_content = nullptr;
m->edited_invert_media = false;
m->edited_reply_markup = nullptr; m->edited_reply_markup = nullptr;
m->edit_generation = 0; m->edit_generation = 0;
m->edit_promise.set_error(Status::Error(400, error_message)); m->edit_promise.set_error(Status::Error(400, error_message));
@ -26673,6 +26686,7 @@ void MessagesManager::on_message_media_edited(DialogId dialog_id, MessageId mess
m->edited_schedule_date = 0; m->edited_schedule_date = 0;
} }
m->edited_content = nullptr; m->edited_content = nullptr;
m->edited_invert_media = false;
m->edited_reply_markup = nullptr; m->edited_reply_markup = nullptr;
m->edit_generation = 0; m->edit_generation = 0;
if (result.is_ok()) { if (result.is_ok()) {
@ -26762,6 +26776,7 @@ void MessagesManager::edit_message_media(MessageFullId message_full_id,
m->edited_content = m->edited_content =
dup_message_content(td_, dialog_id, content.content.get(), MessageContentDupType::Send, MessageCopyOptions()); dup_message_content(td_, dialog_id, content.content.get(), MessageContentDupType::Send, MessageCopyOptions());
CHECK(m->edited_content != nullptr); CHECK(m->edited_content != nullptr);
m->edited_invert_media = content.invert_media;
m->edited_reply_markup = r_new_reply_markup.move_as_ok(); m->edited_reply_markup = r_new_reply_markup.move_as_ok();
m->edit_generation = ++current_message_edit_generation_; m->edit_generation = ++current_message_edit_generation_;
m->edit_promise = std::move(promise); m->edit_promise = std::move(promise);
@ -26813,7 +26828,7 @@ void MessagesManager::edit_message_caption(MessageFullId message_full_id,
td_->create_handler<EditMessageQuery>(std::move(promise)) td_->create_handler<EditMessageQuery>(std::move(promise))
->send(1 << 11, dialog_id, m->message_id, caption.text, ->send(1 << 11, dialog_id, m->message_id, caption.text,
get_input_message_entities(td_->contacts_manager_.get(), caption.entities, "edit_message_caption"), get_input_message_entities(td_->contacts_manager_.get(), caption.entities, "edit_message_caption"),
nullptr, std::move(input_reply_markup), get_message_schedule_date(m)); nullptr, m->invert_media, std::move(input_reply_markup), get_message_schedule_date(m));
} }
void MessagesManager::edit_message_reply_markup(MessageFullId message_full_id, void MessagesManager::edit_message_reply_markup(MessageFullId message_full_id,
@ -26848,7 +26863,7 @@ void MessagesManager::edit_message_reply_markup(MessageFullId message_full_id,
auto input_reply_markup = get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok()); auto input_reply_markup = get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok());
td_->create_handler<EditMessageQuery>(std::move(promise)) td_->create_handler<EditMessageQuery>(std::move(promise))
->send(0, dialog_id, m->message_id, string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(), nullptr, ->send(0, dialog_id, m->message_id, string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(), nullptr,
std::move(input_reply_markup), get_message_schedule_date(m)); false, std::move(input_reply_markup), get_message_schedule_date(m));
} }
void MessagesManager::edit_inline_message_text(const string &inline_message_id, void MessagesManager::edit_inline_message_text(const string &inline_message_id,
@ -26890,7 +26905,7 @@ void MessagesManager::edit_inline_message_text(const string &inline_message_id,
->send(flags, std::move(input_bot_inline_message_id), input_message_text.text.text, ->send(flags, std::move(input_bot_inline_message_id), input_message_text.text.text,
get_input_message_entities(td_->contacts_manager_.get(), input_message_text.text.entities, get_input_message_entities(td_->contacts_manager_.get(), input_message_text.text.entities,
"edit_inline_message_text"), "edit_inline_message_text"),
input_message_text.get_input_media_web_page(), input_message_text.get_input_media_web_page(), input_message_text.show_above_text,
get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok())); get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok()));
} }
@ -26927,7 +26942,8 @@ void MessagesManager::edit_inline_message_live_location(const string &inline_mes
flags, false /*ignored*/, location.get_input_geo_point(), heading, 0, proximity_alert_radius); flags, false /*ignored*/, location.get_input_geo_point(), heading, 0, proximity_alert_radius);
td_->create_handler<EditInlineMessageQuery>(std::move(promise)) td_->create_handler<EditInlineMessageQuery>(std::move(promise))
->send(0, std::move(input_bot_inline_message_id), "", vector<tl_object_ptr<telegram_api::MessageEntity>>(), ->send(0, std::move(input_bot_inline_message_id), "", vector<tl_object_ptr<telegram_api::MessageEntity>>(),
std::move(input_media), get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok())); std::move(input_media), false,
get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok()));
} }
void MessagesManager::edit_inline_message_media(const string &inline_message_id, void MessagesManager::edit_inline_message_media(const string &inline_message_id,
@ -26976,7 +26992,8 @@ void MessagesManager::edit_inline_message_media(const string &inline_message_id,
td_->create_handler<EditInlineMessageQuery>(std::move(promise)) td_->create_handler<EditInlineMessageQuery>(std::move(promise))
->send(1 << 11, std::move(input_bot_inline_message_id), caption == nullptr ? "" : caption->text, ->send(1 << 11, std::move(input_bot_inline_message_id), caption == nullptr ? "" : caption->text,
get_input_message_entities(td_->contacts_manager_.get(), caption, "edit_inline_message_media"), get_input_message_entities(td_->contacts_manager_.get(), caption, "edit_inline_message_media"),
std::move(input_media), get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok())); std::move(input_media), content.invert_media,
get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok()));
} }
void MessagesManager::edit_inline_message_caption(const string &inline_message_id, void MessagesManager::edit_inline_message_caption(const string &inline_message_id,
@ -27005,7 +27022,7 @@ void MessagesManager::edit_inline_message_caption(const string &inline_message_i
td_->create_handler<EditInlineMessageQuery>(std::move(promise)) td_->create_handler<EditInlineMessageQuery>(std::move(promise))
->send(1 << 11, std::move(input_bot_inline_message_id), caption.text, ->send(1 << 11, std::move(input_bot_inline_message_id), caption.text,
get_input_message_entities(td_->contacts_manager_.get(), caption.entities, "edit_inline_message_caption"), get_input_message_entities(td_->contacts_manager_.get(), caption.entities, "edit_inline_message_caption"),
nullptr, get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok())); nullptr, false, get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok()));
} }
void MessagesManager::edit_inline_message_reply_markup(const string &inline_message_id, void MessagesManager::edit_inline_message_reply_markup(const string &inline_message_id,
@ -27025,7 +27042,7 @@ void MessagesManager::edit_inline_message_reply_markup(const string &inline_mess
td_->create_handler<EditInlineMessageQuery>(std::move(promise)) td_->create_handler<EditInlineMessageQuery>(std::move(promise))
->send(0, std::move(input_bot_inline_message_id), string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(), ->send(0, std::move(input_bot_inline_message_id), string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(),
nullptr, get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok())); nullptr, false, get_input_reply_markup(td_->contacts_manager_.get(), r_new_reply_markup.ok()));
} }
void MessagesManager::edit_message_scheduling_state( void MessagesManager::edit_message_scheduling_state(
@ -27067,7 +27084,7 @@ void MessagesManager::edit_message_scheduling_state(
if (schedule_date > 0) { if (schedule_date > 0) {
td_->create_handler<EditMessageQuery>(std::move(promise)) td_->create_handler<EditMessageQuery>(std::move(promise))
->send(0, dialog_id, m->message_id, string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(), nullptr, ->send(0, dialog_id, m->message_id, string(), vector<tl_object_ptr<telegram_api::MessageEntity>>(), nullptr,
nullptr, schedule_date); false, nullptr, schedule_date);
} else { } else {
td_->create_handler<SendScheduledMessageQuery>(std::move(promise))->send(dialog_id, m->message_id); td_->create_handler<SendScheduledMessageQuery>(std::move(promise))->send(dialog_id, m->message_id);
} }
@ -27954,12 +27971,13 @@ Result<MessagesManager::ForwardedMessages> MessagesManager::get_forwarded_messag
if (is_local_copy) { if (is_local_copy) {
auto original_reply_to_message_id = auto original_reply_to_message_id =
forwarded_message->reply_in_dialog_id == DialogId() ? forwarded_message->reply_to_message_id : MessageId(); forwarded_message->reply_in_dialog_id == DialogId() ? forwarded_message->reply_to_message_id : MessageId();
copied_messages.push_back({std::move(content), input_reply_to, forwarded_message->message_id, copied_messages.push_back(
original_reply_to_message_id, std::move(reply_markup), {std::move(content), input_reply_to, forwarded_message->message_id, original_reply_to_message_id,
forwarded_message->media_album_id, std::move(reply_markup), forwarded_message->media_album_id,
get_message_disable_web_page_preview(forwarded_message), i}); get_message_disable_web_page_preview(forwarded_message), forwarded_message->invert_media, i});
} else { } else {
forwarded_message_contents.push_back({std::move(content), forwarded_message->media_album_id, i}); forwarded_message_contents.push_back(
{std::move(content), forwarded_message->invert_media, forwarded_message->media_album_id, i});
} }
} }
result.top_thread_message_id = top_thread_message_id; result.top_thread_message_id = top_thread_message_id;
@ -28048,7 +28066,8 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::forward_messages(
if (only_preview) { if (only_preview) {
message = create_message_to_send( message = create_message_to_send(
to_dialog, top_thread_message_id, MessageInputReplyTo{reply_to_message_id}, message_send_options, to_dialog, top_thread_message_id, MessageInputReplyTo{reply_to_message_id}, message_send_options,
std::move(content), j + 1 != forwarded_message_contents.size(), std::move(forward_info), false, DialogId()); std::move(content), forwarded_message_contents[j].invert_media, j + 1 != forwarded_message_contents.size(),
std::move(forward_info), false, DialogId());
MessageId new_message_id = MessageId new_message_id =
message_send_options.schedule_date != 0 message_send_options.schedule_date != 0
? get_next_yet_unsent_scheduled_message_id(to_dialog, message_send_options.schedule_date) ? get_next_yet_unsent_scheduled_message_id(to_dialog, message_send_options.schedule_date)
@ -28057,8 +28076,9 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::forward_messages(
m = message.get(); m = message.get();
} else { } else {
m = get_message_to_send(to_dialog, top_thread_message_id, MessageInputReplyTo{reply_to_message_id}, m = get_message_to_send(to_dialog, top_thread_message_id, MessageInputReplyTo{reply_to_message_id},
message_send_options, std::move(content), &need_update_dialog_pos, message_send_options, std::move(content), forwarded_message_contents[j].invert_media,
j + 1 != forwarded_message_contents.size(), std::move(forward_info)); &need_update_dialog_pos, j + 1 != forwarded_message_contents.size(),
std::move(forward_info));
} }
fix_forwarded_message(m, to_dialog_id, forwarded_message, forwarded_message_contents[j].media_album_id, fix_forwarded_message(m, to_dialog_id, forwarded_message, forwarded_message_contents[j].media_album_id,
drop_author); drop_author);
@ -28109,7 +28129,8 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::forward_messages(
Message *m; Message *m;
if (only_preview) { if (only_preview) {
message = create_message_to_send(to_dialog, top_thread_message_id, input_reply_to, message_send_options, message = create_message_to_send(to_dialog, top_thread_message_id, input_reply_to, message_send_options,
std::move(copied_message.content), false, nullptr, is_copy, DialogId()); std::move(copied_message.content), copied_message.invert_media, false, nullptr,
is_copy, DialogId());
MessageId new_message_id = MessageId new_message_id =
message_send_options.schedule_date != 0 message_send_options.schedule_date != 0
? get_next_yet_unsent_scheduled_message_id(to_dialog, message_send_options.schedule_date) ? get_next_yet_unsent_scheduled_message_id(to_dialog, message_send_options.schedule_date)
@ -28124,7 +28145,8 @@ Result<td_api::object_ptr<td_api::messages>> MessagesManager::forward_messages(
} }
m = get_message_to_send(to_dialog, top_thread_message_id, input_reply_to, message_send_options, m = get_message_to_send(to_dialog, top_thread_message_id, input_reply_to, message_send_options,
std::move(copied_message.content), &need_update_dialog_pos, false, nullptr, is_copy); std::move(copied_message.content), copied_message.invert_media, &need_update_dialog_pos,
false, nullptr, is_copy);
} }
m->disable_web_page_preview = copied_message.disable_web_page_preview; m->disable_web_page_preview = copied_message.disable_web_page_preview;
m->media_album_id = copied_message.media_album_id; m->media_album_id = copied_message.media_album_id;
@ -28248,8 +28270,8 @@ Result<vector<MessageId>> MessagesManager::resend_messages(DialogId dialog_id, v
get_message_schedule_date(message.get()), message->sending_id); get_message_schedule_date(message.get()), message->sending_id);
Message *m = Message *m =
get_message_to_send(d, message->top_thread_message_id, get_message_input_reply_to(message.get()), options, get_message_to_send(d, message->top_thread_message_id, get_message_input_reply_to(message.get()), options,
std::move(new_contents[i]), &need_update_dialog_pos, false, nullptr, message->is_copy, std::move(new_contents[i]), message->invert_media, &need_update_dialog_pos, false, nullptr,
need_another_sender ? DialogId() : get_message_sender(message.get())); message->is_copy, need_another_sender ? DialogId() : get_message_sender(message.get()));
m->reply_markup = std::move(message->reply_markup); m->reply_markup = std::move(message->reply_markup);
// m->via_bot_user_id = message->via_bot_user_id; // m->via_bot_user_id = message->via_bot_user_id;
m->disable_web_page_preview = message->disable_web_page_preview; m->disable_web_page_preview = message->disable_web_page_preview;
@ -28282,7 +28304,7 @@ void MessagesManager::send_screenshot_taken_notification_message(Dialog *d) {
if (dialog_type == DialogType::User) { if (dialog_type == DialogType::User) {
bool need_update_dialog_pos = false; bool need_update_dialog_pos = false;
const Message *m = get_message_to_send(d, MessageId(), MessageInputReplyTo(), MessageSendOptions(), const Message *m = get_message_to_send(d, MessageId(), MessageInputReplyTo(), MessageSendOptions(),
create_screenshot_taken_message_content(), &need_update_dialog_pos); create_screenshot_taken_message_content(), false, &need_update_dialog_pos);
do_send_screenshot_taken_notification_message(d->dialog_id, m, 0); do_send_screenshot_taken_notification_message(d->dialog_id, m, 0);
@ -28479,6 +28501,7 @@ Result<MessageId> MessagesManager::add_local_message(
m->view_count = 0; m->view_count = 0;
m->forward_count = 0; m->forward_count = 0;
m->content = std::move(message_content.content); m->content = std::move(message_content.content);
m->invert_media = message_content.invert_media;
m->disable_web_page_preview = message_content.disable_web_page_preview; m->disable_web_page_preview = message_content.disable_web_page_preview;
m->clear_draft = message_content.clear_draft; m->clear_draft = message_content.clear_draft;
if (dialog_type == DialogType::SecretChat) { if (dialog_type == DialogType::SecretChat) {
@ -33758,8 +33781,9 @@ void MessagesManager::set_dialog_message_ttl(DialogId dialog_id, int32 ttl, Prom
td_->create_handler<SetHistoryTtlQuery>(std::move(promise))->send(dialog_id, ttl); td_->create_handler<SetHistoryTtlQuery>(std::move(promise))->send(dialog_id, ttl);
} else { } else {
bool need_update_dialog_pos = false; bool need_update_dialog_pos = false;
Message *m = get_message_to_send(d, MessageId(), MessageInputReplyTo(), MessageSendOptions(), Message *m =
create_chat_set_ttl_message_content(ttl, UserId()), &need_update_dialog_pos); get_message_to_send(d, MessageId(), MessageInputReplyTo(), MessageSendOptions(),
create_chat_set_ttl_message_content(ttl, UserId()), false, &need_update_dialog_pos);
send_update_new_message(d, m); send_update_new_message(d, m);
if (need_update_dialog_pos) { if (need_update_dialog_pos) {

View File

@ -1227,6 +1227,7 @@ class MessagesManager final : public Actor {
unique_ptr<ReplyMarkup> reply_markup; unique_ptr<ReplyMarkup> reply_markup;
int32 edited_schedule_date = 0; int32 edited_schedule_date = 0;
bool edited_invert_media = false;
unique_ptr<MessageContent> edited_content; unique_ptr<MessageContent> edited_content;
unique_ptr<ReplyMarkup> edited_reply_markup; unique_ptr<ReplyMarkup> edited_reply_markup;
uint64 edit_generation = 0; uint64 edit_generation = 0;
@ -1798,13 +1799,13 @@ class MessagesManager final : public Actor {
unique_ptr<Message> create_message_to_send(Dialog *d, MessageId top_thread_message_id, unique_ptr<Message> create_message_to_send(Dialog *d, MessageId top_thread_message_id,
MessageInputReplyTo input_reply_to, const MessageSendOptions &options, MessageInputReplyTo input_reply_to, const MessageSendOptions &options,
unique_ptr<MessageContent> &&content, bool suppress_reply_info, unique_ptr<MessageContent> &&content, bool invert_media,
unique_ptr<MessageForwardInfo> forward_info, bool is_copy, bool suppress_reply_info, unique_ptr<MessageForwardInfo> forward_info,
DialogId send_as_dialog_id) const; bool is_copy, DialogId send_as_dialog_id) const;
Message *get_message_to_send(Dialog *d, MessageId top_thread_message_id, MessageInputReplyTo input_reply_to, Message *get_message_to_send(Dialog *d, MessageId top_thread_message_id, MessageInputReplyTo input_reply_to,
const MessageSendOptions &options, unique_ptr<MessageContent> &&content, const MessageSendOptions &options, unique_ptr<MessageContent> &&content,
bool *need_update_dialog_pos, bool suppress_reply_info = false, bool invert_media, bool *need_update_dialog_pos, bool suppress_reply_info = false,
unique_ptr<MessageForwardInfo> forward_info = nullptr, bool is_copy = false, unique_ptr<MessageForwardInfo> forward_info = nullptr, bool is_copy = false,
DialogId sender_dialog_id = DialogId()); DialogId sender_dialog_id = DialogId());
@ -1901,12 +1902,14 @@ class MessagesManager final : public Actor {
unique_ptr<ReplyMarkup> reply_markup; unique_ptr<ReplyMarkup> reply_markup;
int64 media_album_id; int64 media_album_id;
bool disable_web_page_preview; bool disable_web_page_preview;
bool invert_media;
size_t index; size_t index;
}; };
vector<CopiedMessage> copied_messages; vector<CopiedMessage> copied_messages;
struct ForwardedMessageContent { struct ForwardedMessageContent {
unique_ptr<MessageContent> content; unique_ptr<MessageContent> content;
bool invert_media;
int64 media_album_id; int64 media_album_id;
size_t index; size_t index;
}; };