Add send_copy to inputMessageForwarded.
GitOrigin-RevId: 7327021564789e8ff436e2f56f243684b7ce8183
This commit is contained in:
parent
c71dbc28a0
commit
3bca7b1448
@ -1447,8 +1447,11 @@ inputMessageInvoice invoice:invoice title:string description:string photo_url:st
|
|||||||
//@description A message with a poll. Polls can't be sent to private or secret chats @question Poll question, 1-255 characters @options List of poll answer options, 2-10 strings 1-100 characters each
|
//@description A message with a poll. Polls can't be sent to private or secret chats @question Poll question, 1-255 characters @options List of poll answer options, 2-10 strings 1-100 characters each
|
||||||
inputMessagePoll question:string options:vector<string> = InputMessageContent;
|
inputMessagePoll question:string options:vector<string> = InputMessageContent;
|
||||||
|
|
||||||
//@description A forwarded message @from_chat_id Identifier for the chat this forwarded message came from @message_id Identifier of the message to forward @in_game_share True, if a game message should be shared within a launched game; applies only to game messages
|
//@description A forwarded message @from_chat_id Identifier for the chat this forwarded message came from @message_id Identifier of the message to forward
|
||||||
inputMessageForwarded from_chat_id:int53 message_id:int53 in_game_share:Bool = InputMessageContent;
|
//@in_game_share True, if a game message should be shared within a launched game; applies only to game messages
|
||||||
|
//@send_copy True, if content of the message needs to be copied without a link to the original message. Always true if the message is forwarded to a secret chat
|
||||||
|
//@remove_caption True, if media caption of the message copy needs to be removed. Ignored if send_copy is false
|
||||||
|
inputMessageForwarded from_chat_id:int53 message_id:int53 in_game_share:Bool send_copy:Bool remove_caption:Bool = InputMessageContent;
|
||||||
|
|
||||||
|
|
||||||
//@class SearchMessagesFilter @description Represents a filter for message search results
|
//@class SearchMessagesFilter @description Represents a filter for message search results
|
||||||
|
Binary file not shown.
@ -2113,6 +2113,9 @@ static tl_object_ptr<telegram_api::InputMedia> get_input_media(const MessageCont
|
|||||||
}
|
}
|
||||||
case MessageContentType::Game: {
|
case MessageContentType::Game: {
|
||||||
auto m = static_cast<const MessageGame *>(content);
|
auto m = static_cast<const MessageGame *>(content);
|
||||||
|
if (!m->game.get_bot_user_id().is_valid()) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
return m->game.get_input_media_game(td);
|
return m->game.get_input_media_game(td);
|
||||||
}
|
}
|
||||||
case MessageContentType::Invoice: {
|
case MessageContentType::Invoice: {
|
||||||
@ -2680,6 +2683,15 @@ int32 get_message_content_live_location_period(const MessageContent *content) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
UserId get_message_content_game_bot_user_id(const MessageContent *content) {
|
||||||
|
switch (content->get_type()) {
|
||||||
|
case MessageContentType::Game:
|
||||||
|
return static_cast<const MessageGame *>(content)->game.get_bot_user_id();
|
||||||
|
default:
|
||||||
|
return UserId();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool get_message_content_poll_is_closed(const Td *td, const MessageContent *content) {
|
bool get_message_content_poll_is_closed(const Td *td, const MessageContent *content) {
|
||||||
switch (content->get_type()) {
|
switch (content->get_type()) {
|
||||||
case MessageContentType::Poll:
|
case MessageContentType::Poll:
|
||||||
@ -3159,11 +3171,7 @@ void merge_message_contents(Td *td, const MessageContent *old_content, MessageCo
|
|||||||
auto old_ = static_cast<const MessagePoll *>(old_content);
|
auto old_ = static_cast<const MessagePoll *>(old_content);
|
||||||
auto new_ = static_cast<const MessagePoll *>(new_content);
|
auto new_ = static_cast<const MessagePoll *>(new_content);
|
||||||
if (old_->poll_id != new_->poll_id) {
|
if (old_->poll_id != new_->poll_id) {
|
||||||
if (!PollManager::is_local_poll_id(old_->poll_id)) {
|
need_update = true;
|
||||||
LOG(ERROR) << "Poll id has changed from " << old_->poll_id << " to " << new_->poll_id;
|
|
||||||
}
|
|
||||||
// polls are updated in a different way
|
|
||||||
is_content_changed = true;
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -175,6 +175,8 @@ vector<UserId> get_message_content_added_user_ids(const MessageContent *content)
|
|||||||
|
|
||||||
UserId get_message_content_deleted_user_id(const MessageContent *content);
|
UserId get_message_content_deleted_user_id(const MessageContent *content);
|
||||||
|
|
||||||
|
UserId get_message_content_game_bot_user_id(const MessageContent *content);
|
||||||
|
|
||||||
int32 get_message_content_live_location_period(const MessageContent *content);
|
int32 get_message_content_live_location_period(const MessageContent *content);
|
||||||
|
|
||||||
bool get_message_content_poll_is_closed(const Td *td, const MessageContent *content);
|
bool get_message_content_poll_is_closed(const Td *td, const MessageContent *content);
|
||||||
|
@ -15840,6 +15840,9 @@ Status MessagesManager::can_send_message_content(DialogId dialog_id, const Messa
|
|||||||
if (!can_send_games) {
|
if (!can_send_games) {
|
||||||
return Status::Error(400, "Not enough rights to send games to the chat");
|
return Status::Error(400, "Not enough rights to send games to the chat");
|
||||||
}
|
}
|
||||||
|
if (!is_forward && !get_message_content_game_bot_user_id(content).is_valid()) {
|
||||||
|
return Status::Error(400, "Games can't be copied");
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case MessageContentType::Invoice:
|
case MessageContentType::Invoice:
|
||||||
if (!is_forward) {
|
if (!is_forward) {
|
||||||
@ -16196,7 +16199,8 @@ Result<MessageId> MessagesManager::send_message(DialogId dialog_id, MessageId re
|
|||||||
if (input_message_content->get_id() == td_api::inputMessageForwarded::ID) {
|
if (input_message_content->get_id() == td_api::inputMessageForwarded::ID) {
|
||||||
auto input_message = static_cast<const td_api::inputMessageForwarded *>(input_message_content.get());
|
auto input_message = static_cast<const td_api::inputMessageForwarded *>(input_message_content.get());
|
||||||
return forward_message(dialog_id, DialogId(input_message->from_chat_id_), MessageId(input_message->message_id_),
|
return forward_message(dialog_id, DialogId(input_message->from_chat_id_), MessageId(input_message->message_id_),
|
||||||
disable_notification, from_background, input_message->in_game_share_);
|
disable_notification, from_background, input_message->in_game_share_,
|
||||||
|
input_message->send_copy_, input_message->remove_caption_);
|
||||||
}
|
}
|
||||||
|
|
||||||
Dialog *d = get_dialog_force(dialog_id);
|
Dialog *d = get_dialog_force(dialog_id);
|
||||||
@ -16239,9 +16243,45 @@ Result<MessageId> MessagesManager::send_message(DialogId dialog_id, MessageId re
|
|||||||
}
|
}
|
||||||
|
|
||||||
Result<InputMessageContent> MessagesManager::process_input_message_content(
|
Result<InputMessageContent> MessagesManager::process_input_message_content(
|
||||||
DialogId dialog_id, tl_object_ptr<td_api::InputMessageContent> &&input_message_content) const {
|
DialogId dialog_id, tl_object_ptr<td_api::InputMessageContent> &&input_message_content) {
|
||||||
if (input_message_content == nullptr) {
|
if (input_message_content == nullptr) {
|
||||||
return Status::Error(5, "Can't send message without content");
|
return Status::Error(400, "Can't send message without content");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (input_message_content->get_id() == td_api::inputMessageForwarded::ID) {
|
||||||
|
auto input_message = static_cast<const td_api::inputMessageForwarded *>(input_message_content.get());
|
||||||
|
if (!input_message->send_copy_) {
|
||||||
|
return Status::Error(400, "Can't use forwarded message");
|
||||||
|
}
|
||||||
|
|
||||||
|
DialogId from_dialog_id(input_message->from_chat_id_);
|
||||||
|
Dialog *from_dialog = get_dialog_force(from_dialog_id);
|
||||||
|
if (from_dialog == nullptr) {
|
||||||
|
return Status::Error(400, "Chat to copy message from not found");
|
||||||
|
}
|
||||||
|
if (!have_input_peer(from_dialog_id, AccessRights::Read)) {
|
||||||
|
return Status::Error(400, "Can't access the chat to copy message from");
|
||||||
|
}
|
||||||
|
if (from_dialog_id.get_type() == DialogType::SecretChat) {
|
||||||
|
return Status::Error(400, "Can't copy message from secret chats");
|
||||||
|
}
|
||||||
|
MessageId message_id = get_persistent_message_id(from_dialog, MessageId(input_message->message_id_));
|
||||||
|
|
||||||
|
const Message *copied_message = get_message_force(from_dialog, message_id, "process_input_message_content");
|
||||||
|
if (copied_message == nullptr) {
|
||||||
|
return Status::Error(400, "Can't find message to copy");
|
||||||
|
}
|
||||||
|
if (!can_forward_message(from_dialog_id, copied_message)) {
|
||||||
|
return Status::Error(400, "Can't copy message");
|
||||||
|
}
|
||||||
|
|
||||||
|
unique_ptr<MessageContent> content =
|
||||||
|
dup_message_content(td_, dialog_id, copied_message->content.get(), true, input_message->remove_caption_);
|
||||||
|
if (content == nullptr) {
|
||||||
|
return Status::Error(400, "Can't copy message content");
|
||||||
|
}
|
||||||
|
|
||||||
|
return InputMessageContent(std::move(content), copied_message->disable_web_page_preview, false, 0, UserId());
|
||||||
}
|
}
|
||||||
|
|
||||||
TRY_RESULT(content, get_input_message_content(dialog_id, std::move(input_message_content), td_));
|
TRY_RESULT(content, get_input_message_content(dialog_id, std::move(input_message_content), td_));
|
||||||
@ -16397,6 +16437,9 @@ void MessagesManager::do_send_message(DialogId dialog_id, Message *m, vector<int
|
|||||||
} else {
|
} else {
|
||||||
auto input_media = get_input_media(content, td_, m->ttl, false);
|
auto input_media = get_input_media(content, td_, m->ttl, false);
|
||||||
if (input_media == nullptr) {
|
if (input_media == nullptr) {
|
||||||
|
if (content_type == MessageContentType::Game) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (content_type == MessageContentType::Photo) {
|
if (content_type == MessageContentType::Photo) {
|
||||||
thumbnail_file_id = FileId();
|
thumbnail_file_id = FileId();
|
||||||
}
|
}
|
||||||
@ -18313,10 +18356,10 @@ void MessagesManager::do_forward_messages(DialogId to_dialog_id, DialogId from_d
|
|||||||
}
|
}
|
||||||
|
|
||||||
Result<MessageId> MessagesManager::forward_message(DialogId to_dialog_id, DialogId from_dialog_id, MessageId message_id,
|
Result<MessageId> MessagesManager::forward_message(DialogId to_dialog_id, DialogId from_dialog_id, MessageId message_id,
|
||||||
bool disable_notification, bool from_background,
|
bool disable_notification, bool from_background, bool in_game_share,
|
||||||
bool in_game_share) {
|
bool send_copy, bool remove_caption) {
|
||||||
TRY_RESULT(result, forward_messages(to_dialog_id, from_dialog_id, {message_id}, disable_notification, from_background,
|
TRY_RESULT(result, forward_messages(to_dialog_id, from_dialog_id, {message_id}, disable_notification, from_background,
|
||||||
in_game_share, false, false, false));
|
in_game_share, false, send_copy, remove_caption));
|
||||||
CHECK(result.size() == 1);
|
CHECK(result.size() == 1);
|
||||||
auto sent_message_id = result[0];
|
auto sent_message_id = result[0];
|
||||||
if (sent_message_id == MessageId()) {
|
if (sent_message_id == MessageId()) {
|
||||||
@ -18403,13 +18446,17 @@ Result<vector<MessageId>> MessagesManager::forward_messages(DialogId to_dialog_i
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
auto content_type = content->get_type();
|
||||||
|
bool is_game = content_type == MessageContentType::Game;
|
||||||
if (need_copy) {
|
if (need_copy) {
|
||||||
|
if (is_game) {
|
||||||
|
LOG(INFO) << "Can't copy game from " << message_id;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
copied_messages.push_back({std::move(content), forwarded_message->disable_web_page_preview, i});
|
copied_messages.push_back({std::move(content), forwarded_message->disable_web_page_preview, i});
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
auto content_type = content->get_type();
|
|
||||||
bool is_game = content_type == MessageContentType::Game;
|
|
||||||
unique_ptr<MessageForwardInfo> forward_info;
|
unique_ptr<MessageForwardInfo> forward_info;
|
||||||
if (!is_game && content_type != MessageContentType::Audio) {
|
if (!is_game && content_type != MessageContentType::Audio) {
|
||||||
DialogId saved_from_dialog_id;
|
DialogId saved_from_dialog_id;
|
||||||
@ -18696,13 +18743,6 @@ Result<MessageId> MessagesManager::add_local_message(
|
|||||||
}
|
}
|
||||||
|
|
||||||
LOG(INFO) << "Begin to add local message to " << dialog_id << " in reply to " << reply_to_message_id;
|
LOG(INFO) << "Begin to add local message to " << dialog_id << " in reply to " << reply_to_message_id;
|
||||||
if (input_message_content->get_id() == td_api::inputMessageForwarded::ID) {
|
|
||||||
return Status::Error(5, "Can't add forwarded local message");
|
|
||||||
}
|
|
||||||
if (input_message_content->get_id() == td_api::inputMessageGame::ID) {
|
|
||||||
return Status::Error(5, "Can't add local game message");
|
|
||||||
}
|
|
||||||
|
|
||||||
Dialog *d = get_dialog_force(dialog_id);
|
Dialog *d = get_dialog_force(dialog_id);
|
||||||
if (d == nullptr) {
|
if (d == nullptr) {
|
||||||
return Status::Error(5, "Chat not found");
|
return Status::Error(5, "Chat not found");
|
||||||
@ -18712,6 +18752,12 @@ Result<MessageId> MessagesManager::add_local_message(
|
|||||||
return Status::Error(400, "Can't access the chat");
|
return Status::Error(400, "Can't access the chat");
|
||||||
}
|
}
|
||||||
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)));
|
||||||
|
if (message_content.content->get_type() == MessageContentType::Poll) {
|
||||||
|
return Status::Error(400, "Can't add local poll message");
|
||||||
|
}
|
||||||
|
if (message_content.content->get_type() == MessageContentType::Game) {
|
||||||
|
return Status::Error(400, "Can't add local game message");
|
||||||
|
}
|
||||||
|
|
||||||
bool is_channel_post = is_broadcast_channel(dialog_id);
|
bool is_channel_post = is_broadcast_channel(dialog_id);
|
||||||
if (sender_user_id != UserId() && !td_->contacts_manager_->have_user_force(sender_user_id)) {
|
if (sender_user_id != UserId() && !td_->contacts_manager_->have_user_force(sender_user_id)) {
|
||||||
@ -25898,7 +25944,7 @@ MessagesManager::Message *MessagesManager::continue_send_message(DialogId dialog
|
|||||||
|
|
||||||
send_update_new_message(d, result_message);
|
send_update_new_message(d, result_message);
|
||||||
if (need_update_dialog_pos) {
|
if (need_update_dialog_pos) {
|
||||||
send_update_chat_last_message(d, "on_resend_message");
|
send_update_chat_last_message(d, "continue_send_message");
|
||||||
}
|
}
|
||||||
|
|
||||||
auto can_send_status = can_send_message(dialog_id);
|
auto can_send_status = can_send_message(dialog_id);
|
||||||
|
@ -1336,7 +1336,7 @@ class MessagesManager : public Actor {
|
|||||||
bool have_previous, bool have_next, const char *source);
|
bool have_previous, bool have_next, const char *source);
|
||||||
|
|
||||||
Result<InputMessageContent> process_input_message_content(
|
Result<InputMessageContent> process_input_message_content(
|
||||||
DialogId dialog_id, tl_object_ptr<td_api::InputMessageContent> &&input_message_content) const;
|
DialogId dialog_id, tl_object_ptr<td_api::InputMessageContent> &&input_message_content);
|
||||||
|
|
||||||
Message *get_message_to_send(Dialog *d, MessageId reply_to_message_id, bool disable_notification,
|
Message *get_message_to_send(Dialog *d, MessageId reply_to_message_id, bool disable_notification,
|
||||||
bool from_background, unique_ptr<MessageContent> &&content, bool *need_update_dialog_pos,
|
bool from_background, unique_ptr<MessageContent> &&content, bool *need_update_dialog_pos,
|
||||||
@ -1383,8 +1383,8 @@ class MessagesManager : public Actor {
|
|||||||
const vector<MessageId> &message_ids, uint64 logevent_id);
|
const vector<MessageId> &message_ids, uint64 logevent_id);
|
||||||
|
|
||||||
Result<MessageId> forward_message(DialogId to_dialog_id, DialogId from_dialog_id, MessageId message_id,
|
Result<MessageId> forward_message(DialogId to_dialog_id, DialogId from_dialog_id, MessageId message_id,
|
||||||
bool disable_notification, bool from_background,
|
bool disable_notification, bool from_background, bool in_game_share, bool send_copy,
|
||||||
bool in_game_share) TD_WARN_UNUSED_RESULT;
|
bool remove_caption) TD_WARN_UNUSED_RESULT;
|
||||||
|
|
||||||
void do_send_media(DialogId dialog_id, Message *m, FileId file_id, FileId thumbnail_file_id,
|
void do_send_media(DialogId dialog_id, Message *m, FileId file_id, FileId thumbnail_file_id,
|
||||||
tl_object_ptr<telegram_api::InputFile> input_file,
|
tl_object_ptr<telegram_api::InputFile> input_file,
|
||||||
|
@ -2924,7 +2924,7 @@ class CliClient final : public Actor {
|
|||||||
|
|
||||||
send_message(chat_id, td_api::make_object<td_api::inputMessageContact>(td_api::make_object<td_api::contact>(
|
send_message(chat_id, td_api::make_object<td_api::inputMessageContact>(td_api::make_object<td_api::contact>(
|
||||||
phone_number, first_name, last_name, string(), as_user_id(user_id))));
|
phone_number, first_name, last_name, string(), as_user_id(user_id))));
|
||||||
} else if (op == "sf") {
|
} else if (op == "sf" || op == "scopy") {
|
||||||
string chat_id;
|
string chat_id;
|
||||||
string from_chat_id;
|
string from_chat_id;
|
||||||
string from_message_id;
|
string from_message_id;
|
||||||
@ -2932,7 +2932,8 @@ class CliClient final : public Actor {
|
|||||||
std::tie(from_chat_id, from_message_id) = split(args);
|
std::tie(from_chat_id, from_message_id) = split(args);
|
||||||
|
|
||||||
send_message(chat_id, td_api::make_object<td_api::inputMessageForwarded>(as_chat_id(from_chat_id),
|
send_message(chat_id, td_api::make_object<td_api::inputMessageForwarded>(as_chat_id(from_chat_id),
|
||||||
as_message_id(from_message_id), true));
|
as_message_id(from_message_id), true,
|
||||||
|
op == "scopy", Random::fast(0, 1) == 0));
|
||||||
} else if (op == "sd") {
|
} else if (op == "sd") {
|
||||||
string chat_id;
|
string chat_id;
|
||||||
string document_path;
|
string document_path;
|
||||||
|
Reference in New Issue
Block a user