Allow forwardSource without source message.

This commit is contained in:
levlam 2024-01-25 16:23:00 +03:00
parent 81f1d61e7f
commit 2f1423a284
4 changed files with 25 additions and 17 deletions

View File

@ -1201,8 +1201,8 @@ messageOriginChannel chat_id:int53 message_id:int53 author_signature:string = Me
//@description Contains information about the last message from which a new message was forwarded last time //@description Contains information about the last message from which a new message was forwarded last time
//@chat_id Identifier of the chat to which the message that was forwarded belonged //@chat_id Identifier of the chat to which the message that was forwarded belonged; may be 0 if unknown
//@message_id Identifier of the message //@message_id Identifier of the message; may be 0 if unknown
//@sender_id Identifier of the sender of the message; may be null if unknown or the new message was forwarded not to Saved Messages //@sender_id Identifier of the sender of the message; may be null if unknown or the new message was forwarded not to Saved Messages
//@sender_name Name of the sender of the message if the sender is hidden by their privacy settings //@sender_name Name of the sender of the message if the sender is hidden by their privacy settings
//@date Point in time (Unix timestamp) when the message is sent; 0 if unknown //@date Point in time (Unix timestamp) when the message is sent; 0 if unknown

View File

@ -21,23 +21,20 @@ bool LastForwardedMessageInfo::is_empty() const {
return *this == LastForwardedMessageInfo(); return *this == LastForwardedMessageInfo();
} }
bool LastForwardedMessageInfo::validate() { void LastForwardedMessageInfo::validate() {
if (is_empty()) { if (dialog_id_.is_valid() != message_id_.is_valid() ||
return true;
}
if (!dialog_id_.is_valid() || !message_id_.is_valid() ||
(sender_dialog_id_ != DialogId() && !sender_dialog_id_.is_valid()) || (sender_dialog_id_ != DialogId() && !sender_dialog_id_.is_valid()) ||
((sender_dialog_id_ != DialogId() || !sender_name_.empty()) && date_ <= 0)) { ((sender_dialog_id_ != DialogId() || !sender_name_.empty()) && date_ <= 0)) {
*this = {}; *this = {};
return false;
} }
return true;
} }
void LastForwardedMessageInfo::hide_sender_if_needed(Td *td) { void LastForwardedMessageInfo::hide_sender_if_needed(Td *td) {
if (sender_name_.empty() && sender_dialog_id_.get_type() == DialogType::User) { if (sender_name_.empty() && sender_dialog_id_.get_type() == DialogType::User) {
auto private_forward_name = td->contacts_manager_->get_user_private_forward_name(sender_dialog_id_.get_user_id()); auto private_forward_name = td->contacts_manager_->get_user_private_forward_name(sender_dialog_id_.get_user_id());
if (!private_forward_name.empty()) { if (!private_forward_name.empty()) {
dialog_id_ = DialogId();
message_id_ = MessageId();
sender_dialog_id_ = DialogId(); sender_dialog_id_ = DialogId();
sender_name_ = std::move(private_forward_name); sender_name_ = std::move(private_forward_name);
} }
@ -69,7 +66,7 @@ void LastForwardedMessageInfo::add_min_channel_ids(vector<ChannelId> &channel_id
td_api::object_ptr<td_api::forwardSource> LastForwardedMessageInfo::get_forward_source_object( td_api::object_ptr<td_api::forwardSource> LastForwardedMessageInfo::get_forward_source_object(
Td *td, bool for_saved_messages, const MessageOrigin &origin, int32 origin_date) const { Td *td, bool for_saved_messages, const MessageOrigin &origin, int32 origin_date) const {
if (is_empty()) { if (is_empty() && (origin.is_empty() || !for_saved_messages)) {
return nullptr; return nullptr;
} }
td_api::object_ptr<td_api::MessageSender> sender_id; td_api::object_ptr<td_api::MessageSender> sender_id;
@ -105,7 +102,11 @@ bool operator!=(const LastForwardedMessageInfo &lhs, const LastForwardedMessageI
StringBuilder &operator<<(StringBuilder &string_builder, const LastForwardedMessageInfo &last_message_info) { StringBuilder &operator<<(StringBuilder &string_builder, const LastForwardedMessageInfo &last_message_info) {
if (!last_message_info.is_empty()) { if (!last_message_info.is_empty()) {
string_builder << MessageFullId(last_message_info.dialog_id_, last_message_info.message_id_); string_builder << "last";
if (last_message_info.dialog_id_ != DialogId()) {
string_builder << " forwarded from "
<< MessageFullId(last_message_info.dialog_id_, last_message_info.message_id_);
}
if (last_message_info.sender_dialog_id_ != DialogId() || !last_message_info.sender_name_.empty()) { if (last_message_info.sender_dialog_id_ != DialogId() || !last_message_info.sender_name_.empty()) {
string_builder << " sent by "; string_builder << " sent by ";
if (last_message_info.sender_dialog_id_.is_valid()) { if (last_message_info.sender_dialog_id_.is_valid()) {
@ -138,16 +139,22 @@ unique_ptr<MessageForwardInfo> MessageForwardInfo::get_message_forward_info(
} }
LastForwardedMessageInfo last_message_info; LastForwardedMessageInfo last_message_info;
if (forward_header->saved_from_peer_ != nullptr) { if (forward_header->saved_from_peer_ != nullptr || forward_header->saved_from_id_ != nullptr ||
!forward_header->saved_from_name_.empty()) {
DialogId from_dialog_id;
if (forward_header->saved_from_peer_ != nullptr) {
from_dialog_id = DialogId(forward_header->saved_from_peer_);
}
DialogId sender_dialog_id; DialogId sender_dialog_id;
if (forward_header->saved_from_id_ != nullptr) { if (forward_header->saved_from_id_ != nullptr) {
sender_dialog_id = DialogId(forward_header->saved_from_id_); sender_dialog_id = DialogId(forward_header->saved_from_id_);
} }
last_message_info = LastForwardedMessageInfo( last_message_info = LastForwardedMessageInfo(
DialogId(forward_header->saved_from_peer_), MessageId(ServerMessageId(forward_header->saved_from_msg_id_)), from_dialog_id, MessageId(ServerMessageId(forward_header->saved_from_msg_id_)), sender_dialog_id,
sender_dialog_id, std::move(forward_header->saved_from_name_), forward_header->saved_date_, forward_header->saved_from_name_, forward_header->saved_date_,
forward_header->saved_out_ || sender_dialog_id == td->dialog_manager_->get_my_dialog_id()); forward_header->saved_out_ || sender_dialog_id == td->dialog_manager_->get_my_dialog_id());
if (last_message_info.is_empty() || !last_message_info.validate()) { last_message_info.validate();
if (last_message_info.is_empty()) {
LOG(ERROR) << "Receive wrong last message in message forward header: " << oneline(to_string(forward_header)); LOG(ERROR) << "Receive wrong last message in message forward header: " << oneline(to_string(forward_header));
} else { } else {
Dependencies dependencies; Dependencies dependencies;

View File

@ -50,7 +50,7 @@ class LastForwardedMessageInfo {
bool is_empty() const; bool is_empty() const;
bool validate(); void validate();
void hide_sender_if_needed(Td *td); void hide_sender_if_needed(Td *td);

View File

@ -26709,7 +26709,8 @@ unique_ptr<MessageForwardInfo> MessagesManager::create_message_forward_info(Dial
if (from_dialog_id != my_dialog_id || content_type == MessageContentType::Dice) { if (from_dialog_id != my_dialog_id || content_type == MessageContentType::Dice) {
auto origin = get_forwarded_message_origin(from_dialog_id, m); auto origin = get_forwarded_message_origin(from_dialog_id, m);
if (!origin.is_empty()) { if (!origin.is_empty()) {
if (!last_message_info.is_empty()) { last_message_info.hide_sender_if_needed(td_);
if (last_message_info.get_dialog_id() != DialogId()) {
last_message_info = last_message_info =
LastForwardedMessageInfo(from_dialog_id, m->message_id, DialogId(), string(), 0, m->is_outgoing); LastForwardedMessageInfo(from_dialog_id, m->message_id, DialogId(), string(), 0, m->is_outgoing);
} }