Don't warn about pre-release messages.

This commit is contained in:
levlam 2023-11-30 21:11:19 +03:00
parent e2ce0e7a0b
commit 6f3180aeaf
5 changed files with 28 additions and 20 deletions

View File

@ -5495,8 +5495,9 @@ unique_ptr<MessageContent> get_secret_message_content(
unique_ptr<MessageContent> get_message_content(Td *td, FormattedText message, unique_ptr<MessageContent> get_message_content(Td *td, FormattedText message,
tl_object_ptr<telegram_api::MessageMedia> &&media_ptr, tl_object_ptr<telegram_api::MessageMedia> &&media_ptr,
DialogId owner_dialog_id, bool is_content_read, UserId via_bot_user_id, DialogId owner_dialog_id, int32 message_date, bool is_content_read,
int32 *ttl, bool *disable_web_page_preview, const char *source) { UserId via_bot_user_id, int32 *ttl, bool *disable_web_page_preview,
const char *source) {
if (!td->auth_manager_->was_authorized() && !G()->close_flag() && media_ptr != nullptr && if (!td->auth_manager_->was_authorized() && !G()->close_flag() && media_ptr != nullptr &&
media_ptr->get_id() != telegram_api::messageMediaEmpty::ID) { media_ptr->get_id() != telegram_api::messageMediaEmpty::ID) {
LOG(ERROR) << "Receive without authorization from " << source << ": " << to_string(media_ptr); LOG(ERROR) << "Receive without authorization from " << source << ": " << to_string(media_ptr);
@ -5687,7 +5688,9 @@ unique_ptr<MessageContent> get_message_content(Td *td, FormattedText message,
} }
} }
if (channel_ids.empty() || media->quantity_ <= 0 || media->months_ <= 0 || media->until_date_ < 0) { if (channel_ids.empty() || media->quantity_ <= 0 || media->months_ <= 0 || media->until_date_ < 0) {
LOG(ERROR) << "Receive " << to_string(media); if (message_date >= 1700000000) { // approximate release date
LOG(ERROR) << "Receive " << to_string(media);
}
break; break;
} }
auto boosted_channel_id = channel_ids[0]; auto boosted_channel_id = channel_ids[0];
@ -5988,7 +5991,7 @@ unique_ptr<MessageContent> dup_message_content(Td *td, DialogId dialog_id, const
} }
unique_ptr<MessageContent> get_action_message_content(Td *td, tl_object_ptr<telegram_api::MessageAction> &&action_ptr, unique_ptr<MessageContent> get_action_message_content(Td *td, tl_object_ptr<telegram_api::MessageAction> &&action_ptr,
DialogId owner_dialog_id, DialogId owner_dialog_id, int32 message_date,
const RepliedMessageInfo &replied_message_info) { const RepliedMessageInfo &replied_message_info) {
CHECK(action_ptr != nullptr); CHECK(action_ptr != nullptr);
@ -6356,7 +6359,9 @@ unique_ptr<MessageContent> get_action_message_content(Td *td, tl_object_ptr<tele
auto action = move_tl_object_as<telegram_api::messageActionGiveawayResults>(action_ptr); auto action = move_tl_object_as<telegram_api::messageActionGiveawayResults>(action_ptr);
auto reply_to_message_id = replied_message_info.get_same_chat_reply_to_message_id(true); auto reply_to_message_id = replied_message_info.get_same_chat_reply_to_message_id(true);
if (!reply_to_message_id.is_valid()) { if (!reply_to_message_id.is_valid()) {
LOG(ERROR) << "Receive giveaway results message with " << reply_to_message_id << " in " << owner_dialog_id; if (message_date >= 1700000000) { // approximate release date
LOG(ERROR) << "Receive giveaway results message with " << reply_to_message_id << " in " << owner_dialog_id;
}
reply_to_message_id = MessageId(); reply_to_message_id = MessageId();
} }
return td::make_unique<MessageGiveawayResults>(reply_to_message_id, action->winners_count_, return td::make_unique<MessageGiveawayResults>(reply_to_message_id, action->winners_count_,

View File

@ -218,8 +218,9 @@ unique_ptr<MessageContent> get_secret_message_content(
unique_ptr<MessageContent> get_message_content(Td *td, FormattedText message_text, unique_ptr<MessageContent> get_message_content(Td *td, FormattedText message_text,
tl_object_ptr<telegram_api::MessageMedia> &&media_ptr, tl_object_ptr<telegram_api::MessageMedia> &&media_ptr,
DialogId owner_dialog_id, bool is_content_read, UserId via_bot_user_id, DialogId owner_dialog_id, int32 message_date, bool is_content_read,
int32 *ttl, bool *disable_web_page_preview, const char *source); UserId via_bot_user_id, int32 *ttl, bool *disable_web_page_preview,
const char *source);
enum class MessageContentDupType : int32 { enum class MessageContentDupType : int32 {
Send, // normal message sending Send, // normal message sending
@ -233,7 +234,7 @@ unique_ptr<MessageContent> dup_message_content(Td *td, DialogId dialog_id, const
MessageContentDupType type, MessageCopyOptions &&copy_options); MessageContentDupType type, MessageCopyOptions &&copy_options);
unique_ptr<MessageContent> get_action_message_content(Td *td, tl_object_ptr<telegram_api::MessageAction> &&action_ptr, unique_ptr<MessageContent> get_action_message_content(Td *td, tl_object_ptr<telegram_api::MessageAction> &&action_ptr,
DialogId owner_dialog_id, DialogId owner_dialog_id, int32 message_date,
const RepliedMessageInfo &replied_message_info); const RepliedMessageInfo &replied_message_info);
tl_object_ptr<td_api::MessageContent> get_message_content_object(const MessageContent *content, Td *td, tl_object_ptr<td_api::MessageContent> get_message_content_object(const MessageContent *content, Td *td,

View File

@ -6655,8 +6655,8 @@ void MessagesManager::on_update_service_notification(tl_object_ptr<telegram_api:
DialogId owner_dialog_id = is_user ? get_service_notifications_dialog()->dialog_id : DialogId(); DialogId owner_dialog_id = is_user ? get_service_notifications_dialog()->dialog_id : DialogId();
int32 ttl = 0; int32 ttl = 0;
bool disable_web_page_preview = false; bool disable_web_page_preview = false;
auto content = get_message_content(td_, std::move(message_text), std::move(update->media_), owner_dialog_id, false, auto content = get_message_content(td_, std::move(message_text), std::move(update->media_), owner_dialog_id, date,
UserId(), &ttl, &disable_web_page_preview, "updateServiceNotification"); false, UserId(), &ttl, &disable_web_page_preview, "updateServiceNotification");
bool is_content_secret = is_secret_message_content(ttl, content->get_type()); bool is_content_secret = is_secret_message_content(ttl, content->get_type());
if (update->popup_) { if (update->popup_) {
@ -14429,8 +14429,8 @@ MessagesManager::MessageInfo MessagesManager::parse_telegram_api_message(
true, td_->auth_manager_->is_bot(), true, td_->auth_manager_->is_bot(),
message_info.forward_header ? message_info.forward_header->date_ : message_info.date, message_info.forward_header ? message_info.forward_header->date_ : message_info.date,
message_info.media_album_id != 0, new_source.c_str()), message_info.media_album_id != 0, new_source.c_str()),
std::move(message->media_), message_info.dialog_id, is_content_read, message_info.via_bot_user_id, std::move(message->media_), message_info.dialog_id, message_info.date, is_content_read,
&message_info.ttl, &message_info.disable_web_page_preview, new_source.c_str()); message_info.via_bot_user_id, &message_info.ttl, &message_info.disable_web_page_preview, new_source.c_str());
message_info.reply_markup = std::move(message->reply_markup_); message_info.reply_markup = std::move(message->reply_markup_);
message_info.restriction_reasons = get_restriction_reasons(std::move(message->restriction_reason_)); message_info.restriction_reasons = get_restriction_reasons(std::move(message->restriction_reason_));
message_info.author_signature = std::move(message->post_author_); message_info.author_signature = std::move(message->post_author_);
@ -14457,8 +14457,9 @@ MessagesManager::MessageInfo MessagesManager::parse_telegram_api_message(
message_info.dialog_id.get_type() == DialogType::Channel && !is_broadcast_channel(message_info.dialog_id); message_info.dialog_id.get_type() == DialogType::Channel && !is_broadcast_channel(message_info.dialog_id);
message_info.reply_header = MessageReplyHeader(td_, std::move(message->reply_to_), message_info.dialog_id, message_info.reply_header = MessageReplyHeader(td_, std::move(message->reply_to_), message_info.dialog_id,
message_info.message_id, message_info.date, can_have_thread); message_info.message_id, message_info.date, can_have_thread);
message_info.content = get_action_message_content(td_, std::move(message->action_), message_info.dialog_id, message_info.content =
message_info.reply_header.replied_message_info_); get_action_message_content(td_, std::move(message->action_), message_info.dialog_id, message_info.date,
message_info.reply_header.replied_message_info_);
message_info.reply_header.replied_message_info_ = RepliedMessageInfo(); message_info.reply_header.replied_message_info_ = RepliedMessageInfo();
message_info.reply_header.story_full_id_ = StoryFullId(); message_info.reply_header.story_full_id_ = StoryFullId();
break; break;
@ -15523,7 +15524,7 @@ void MessagesManager::on_update_sent_text_message(int64 random_id,
FormattedText new_message_text = get_message_text( FormattedText new_message_text = get_message_text(
td_->contacts_manager_.get(), old_message_text->text, std::move(entities), true, td_->auth_manager_->is_bot(), td_->contacts_manager_.get(), old_message_text->text, std::move(entities), true, td_->auth_manager_->is_bot(),
m->forward_info ? m->forward_info->date : m->date, m->media_album_id != 0, "on_update_sent_text_message"); m->forward_info ? m->forward_info->date : m->date, m->media_album_id != 0, "on_update_sent_text_message");
auto new_content = get_message_content(td_, std::move(new_message_text), std::move(message_media), dialog_id, auto new_content = get_message_content(td_, std::move(new_message_text), std::move(message_media), dialog_id, m->date,
true /*likely ignored*/, UserId() /*likely ignored*/, nullptr /*ignored*/, true /*likely ignored*/, UserId() /*likely ignored*/, nullptr /*ignored*/,
nullptr, "on_update_sent_text_message"); nullptr, "on_update_sent_text_message");
if (new_content->get_type() != MessageContentType::Text) { if (new_content->get_type() != MessageContentType::Text) {
@ -25729,7 +25730,7 @@ void MessagesManager::on_upload_message_media_success(DialogId dialog_id, Messag
auto caption = get_message_content_caption(m->content.get()); auto caption = get_message_content_caption(m->content.get());
auto has_spoiler = get_message_content_has_spoiler(m->content.get()); auto has_spoiler = get_message_content_has_spoiler(m->content.get());
auto content = get_message_content(td_, caption == nullptr ? FormattedText() : *caption, std::move(media), dialog_id, auto content = get_message_content(td_, caption == nullptr ? FormattedText() : *caption, std::move(media), dialog_id,
false, UserId(), nullptr, nullptr, "on_upload_message_media_success"); m->date, false, UserId(), nullptr, nullptr, "on_upload_message_media_success");
set_message_content_has_spoiler(content.get(), has_spoiler); set_message_content_has_spoiler(content.get(), has_spoiler);
bool is_content_changed = false; bool is_content_changed = false;

View File

@ -105,8 +105,8 @@ RepliedMessageInfo::RepliedMessageInfo(Td *td, tl_object_ptr<telegram_api::messa
} }
if (!origin_.is_empty() && reply_header->reply_media_ != nullptr && if (!origin_.is_empty() && reply_header->reply_media_ != nullptr &&
reply_header->reply_media_->get_id() != telegram_api::messageMediaEmpty::ID) { reply_header->reply_media_->get_id() != telegram_api::messageMediaEmpty::ID) {
content_ = get_message_content(td, FormattedText(), std::move(reply_header->reply_media_), dialog_id, true, content_ = get_message_content(td, FormattedText(), std::move(reply_header->reply_media_), dialog_id,
UserId(), nullptr, nullptr, "messageReplyHeader"); origin_date_, true, UserId(), nullptr, nullptr, "messageReplyHeader");
CHECK(content_ != nullptr); CHECK(content_ != nullptr);
switch (content_->get_type()) { switch (content_->get_type()) {
case MessageContentType::Animation: case MessageContentType::Animation:

View File

@ -430,8 +430,9 @@ void SponsoredMessageManager::on_get_dialog_sponsored_messages(
"on_get_dialog_sponsored_messages"); "on_get_dialog_sponsored_messages");
int32 ttl = 0; int32 ttl = 0;
bool disable_web_page_preview = false; bool disable_web_page_preview = false;
auto content = get_message_content(td_, std::move(message_text), nullptr, sponsor_dialog_id, true, UserId(), auto content =
&ttl, &disable_web_page_preview, "on_get_dialog_sponsored_messages"); get_message_content(td_, std::move(message_text), nullptr, sponsor_dialog_id, G()->unix_time(), true,
UserId(), &ttl, &disable_web_page_preview, "on_get_dialog_sponsored_messages");
if (ttl != 0) { if (ttl != 0) {
LOG(ERROR) << "Receive sponsored message with self-destruct time " << ttl; LOG(ERROR) << "Receive sponsored message with self-destruct time " << ttl;
continue; continue;