Support media in "article" link previews.

This commit is contained in:
levlam 2024-07-17 15:15:02 +03:00
parent f730830154
commit 6f3fd97877

View File

@ -1555,16 +1555,12 @@ td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_ty
LOG(ERROR) << "Have type = " << web_page->type_ << " for embedded " << web_page->url_; LOG(ERROR) << "Have type = " << web_page->type_ << " for embedded " << web_page->url_;
return td_api::make_object<td_api::linkPreviewTypeUnsupported>(); return td_api::make_object<td_api::linkPreviewTypeUnsupported>();
} }
bool is_generic = web_page->type_ == "document" || web_page->type_ == "article";
if (web_page->type_ == "app") { if (web_page->type_ == "app") {
return td_api::make_object<td_api::linkPreviewTypeApp>(get_photo_object(td_->file_manager_.get(), web_page->photo_), return td_api::make_object<td_api::linkPreviewTypeApp>(get_photo_object(td_->file_manager_.get(), web_page->photo_),
web_page->author_); web_page->author_);
} }
if (web_page->type_ == "article") { if (web_page->type_ == "audio" || (web_page->document_.type == Document::Type::Audio && is_generic)) {
return td_api::make_object<td_api::linkPreviewTypeArticle>(
get_photo_object(td_->file_manager_.get(), web_page->photo_), web_page->author_);
}
if (web_page->type_ == "audio" ||
(web_page->document_.type == Document::Type::Audio && web_page->type_ == "document")) {
LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_; LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_;
auto audio = web_page->document_.type == Document::Type::Audio auto audio = web_page->document_.type == Document::Type::Audio
? td_->audios_manager_->get_audio_object(web_page->document_.file_id) ? td_->audios_manager_->get_audio_object(web_page->document_.file_id)
@ -1578,13 +1574,12 @@ td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_ty
return td_api::make_object<td_api::linkPreviewTypeUnsupported>(); return td_api::make_object<td_api::linkPreviewTypeUnsupported>();
} }
} }
if (web_page->document_.type == Document::Type::General && web_page->type_ == "document") { if (web_page->document_.type == Document::Type::General && is_generic) {
LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_; LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_;
auto document = td_->documents_manager_->get_document_object(web_page->document_.file_id, PhotoFormat::Jpeg); auto document = td_->documents_manager_->get_document_object(web_page->document_.file_id, PhotoFormat::Jpeg);
return td_api::make_object<td_api::linkPreviewTypeDocument>(std::move(document), web_page->author_); return td_api::make_object<td_api::linkPreviewTypeDocument>(std::move(document), web_page->author_);
} }
if (web_page->type_ == "gif" || if (web_page->type_ == "gif" || (web_page->document_.type == Document::Type::Animation && is_generic)) {
(web_page->document_.type == Document::Type::Animation && web_page->type_ == "document")) {
auto animation = web_page->document_.type == Document::Type::Animation auto animation = web_page->document_.type == Document::Type::Animation
? td_->animations_manager_->get_animation_object(web_page->document_.file_id) ? td_->animations_manager_->get_animation_object(web_page->document_.file_id)
: nullptr; : nullptr;
@ -1600,8 +1595,7 @@ td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_ty
} }
} }
if (web_page->type_ == "photo" || if (web_page->type_ == "photo" ||
(web_page->type_ == "document" && web_page->document_.type == Document::Type::Unknown && (is_generic && web_page->document_.type == Document::Type::Unknown && !web_page->photo_.is_empty())) {
!web_page->photo_.is_empty())) {
auto photo = get_photo_object(td_->file_manager_.get(), web_page->photo_); auto photo = get_photo_object(td_->file_manager_.get(), web_page->photo_);
if (photo != nullptr) { if (photo != nullptr) {
return td_api::make_object<td_api::linkPreviewTypePhoto>(std::move(photo), web_page->author_); return td_api::make_object<td_api::linkPreviewTypePhoto>(std::move(photo), web_page->author_);
@ -1610,12 +1604,11 @@ td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_ty
return td_api::make_object<td_api::linkPreviewTypeUnsupported>(); return td_api::make_object<td_api::linkPreviewTypeUnsupported>();
} }
} }
if (web_page->document_.type == Document::Type::Sticker && web_page->type_ == "document") { if (web_page->document_.type == Document::Type::Sticker && is_generic) {
auto sticker = td_->stickers_manager_->get_sticker_object(web_page->document_.file_id); auto sticker = td_->stickers_manager_->get_sticker_object(web_page->document_.file_id);
return td_api::make_object<td_api::linkPreviewTypeSticker>(std::move(sticker)); return td_api::make_object<td_api::linkPreviewTypeSticker>(std::move(sticker));
} }
if (web_page->type_ == "video" || if (web_page->type_ == "video" || (web_page->document_.type == Document::Type::Video && is_generic)) {
(web_page->document_.type == Document::Type::Video && web_page->type_ == "document")) {
auto video = web_page->document_.type == Document::Type::Video auto video = web_page->document_.type == Document::Type::Video
? td_->videos_manager_->get_video_object(web_page->document_.file_id) ? td_->videos_manager_->get_video_object(web_page->document_.file_id)
: nullptr; : nullptr;
@ -1635,16 +1628,20 @@ td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_ty
web_page->duration_, web_page->author_); web_page->duration_, web_page->author_);
} }
} }
if (web_page->document_.type == Document::Type::VideoNote && web_page->type_ == "document") { if (web_page->document_.type == Document::Type::VideoNote && is_generic) {
LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_; LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_;
auto video_note = td_->video_notes_manager_->get_video_note_object(web_page->document_.file_id); auto video_note = td_->video_notes_manager_->get_video_note_object(web_page->document_.file_id);
return td_api::make_object<td_api::linkPreviewTypeVideoNote>(std::move(video_note)); return td_api::make_object<td_api::linkPreviewTypeVideoNote>(std::move(video_note));
} }
if (web_page->document_.type == Document::Type::VoiceNote && web_page->type_ == "document") { if (web_page->document_.type == Document::Type::VoiceNote && is_generic) {
LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_; LOG_IF(ERROR, !web_page->photo_.is_empty()) << "Receive photo for " << web_page->url_;
auto voice_note = td_->voice_notes_manager_->get_voice_note_object(web_page->document_.file_id); auto voice_note = td_->voice_notes_manager_->get_voice_note_object(web_page->document_.file_id);
return td_api::make_object<td_api::linkPreviewTypeVoiceNote>(std::move(voice_note)); return td_api::make_object<td_api::linkPreviewTypeVoiceNote>(std::move(voice_note));
} }
if (web_page->type_ == "article") {
return td_api::make_object<td_api::linkPreviewTypeArticle>(
get_photo_object(td_->file_manager_.get(), web_page->photo_), web_page->author_);
}
LOG(ERROR) << "Receive link preview of unsupported type " << web_page->type_; LOG(ERROR) << "Receive link preview of unsupported type " << web_page->type_;
return td_api::make_object<td_api::linkPreviewTypeUnsupported>(); return td_api::make_object<td_api::linkPreviewTypeUnsupported>();