Hide Instant View for album link previews from Instagram and Twitter.

This commit is contained in:
levlam 2024-08-07 11:47:37 +03:00
parent 168a9dfc77
commit 7f364a7a18
4 changed files with 49 additions and 2 deletions

View File

@ -2491,4 +2491,19 @@ vector<td_api::object_ptr<td_api::PageBlock>> get_page_blocks_object(
return get_page_blocks_object(page_blocks, &context); return get_page_blocks_object(page_blocks, &context);
} }
bool WebPageBlock::are_allowed_album_block_types(const vector<unique_ptr<WebPageBlock>> &page_blocks) {
for (const auto &block : page_blocks) {
switch (block->get_type()) {
case Type::Title:
case Type::AuthorDate:
case Type::Collage:
case Type::Slideshow:
continue;
default:
return false;
}
}
return true;
}
} // namespace td } // namespace td

View File

@ -87,6 +87,8 @@ class WebPageBlock {
virtual void append_file_ids(const Td *td, vector<FileId> &file_ids) const = 0; virtual void append_file_ids(const Td *td, vector<FileId> &file_ids) const = 0;
virtual td_api::object_ptr<td_api::PageBlock> get_page_block_object(Context *context) const = 0; virtual td_api::object_ptr<td_api::PageBlock> get_page_block_object(Context *context) const = 0;
static bool are_allowed_album_block_types(const vector<unique_ptr<WebPageBlock>> &page_blocks);
}; };
void store(const unique_ptr<WebPageBlock> &block, LogEventStorerCalcLength &storer); void store(const unique_ptr<WebPageBlock> &block, LogEventStorerCalcLength &storer);

View File

@ -245,6 +245,8 @@ class WebPagesManager::WebPage {
int32 duration_ = 0; int32 duration_ = 0;
string author_; string author_;
bool has_large_media_ = false; bool has_large_media_ = false;
mutable bool is_album_ = false;
mutable bool is_album_checked_ = false;
Document document_; Document document_;
vector<Document> documents_; vector<Document> documents_;
ThemeSettings theme_settings_; ThemeSettings theme_settings_;
@ -1347,6 +1349,30 @@ bool WebPagesManager::have_web_page(WebPageId web_page_id) const {
return get_web_page(web_page_id) != nullptr; return get_web_page(web_page_id) != nullptr;
} }
bool WebPagesManager::can_web_page_be_album(const WebPage *web_page) {
if (web_page->type_ == "telegram_album") {
return true;
}
auto site_name = to_lower(web_page->site_name_);
return site_name == "instagram" || site_name == "twitter" || site_name == "x";
}
bool WebPagesManager::is_web_page_album(const WebPage *web_page) {
if (!web_page->is_album_checked_) {
web_page->is_album_checked_ = true;
if (web_page->type_ == "telegram_album") {
web_page->is_album_ = true;
} else if (can_web_page_be_album(web_page) && !web_page->instant_view_.is_empty_) {
if (!web_page->instant_view_.is_loaded_) {
LOG(ERROR) << "Have no instant view for " << web_page->url_;
} else {
web_page->is_album_ = WebPageBlock::are_allowed_album_block_types(web_page->instant_view_.page_blocks_);
}
}
}
return web_page->is_album_;
}
td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_type_object( td_api::object_ptr<td_api::LinkPreviewType> WebPagesManager::get_link_preview_type_object(
const WebPage *web_page) const { const WebPage *web_page) const {
if (begins_with(web_page->type_, "telegram_")) { if (begins_with(web_page->type_, "telegram_")) {
@ -1723,7 +1749,7 @@ td_api::object_ptr<td_api::linkPreview> WebPagesManager::get_link_preview_object
return nullptr; return nullptr;
} }
int32 instant_view_version = [web_page] { int32 instant_view_version = [web_page] {
if (web_page->instant_view_.is_empty_ || web_page->type_ == "telegram_album") { if (web_page->instant_view_.is_empty_ || is_web_page_album(web_page)) {
return 0; return 0;
} }
if (web_page->instant_view_.is_v2_) { if (web_page->instant_view_.is_v2_) {
@ -2292,7 +2318,7 @@ void WebPagesManager::on_load_web_page_from_database(WebPageId web_page_id, stri
update_web_page(std::move(result), web_page_id, true, true); update_web_page(std::move(result), web_page_id, true, true);
const WebPage *web_page = get_web_page(web_page_id); const WebPage *web_page = get_web_page(web_page_id);
if (web_page != nullptr && web_page->type_ == "telegram_album" && !web_page->instant_view_.is_empty_ && if (web_page != nullptr && can_web_page_be_album(web_page) && !web_page->instant_view_.is_empty_ &&
!web_page->instant_view_.is_loaded_) { !web_page->instant_view_.is_loaded_) {
LOG(INFO) << "Forcely load instant view of " << web_page_id; LOG(INFO) << "Forcely load instant view of " << web_page_id;
on_load_web_page_instant_view_from_database( on_load_web_page_instant_view_from_database(

View File

@ -193,6 +193,10 @@ class WebPagesManager final : public Actor {
vector<FileId> get_web_page_file_ids(const WebPage *web_page) const; vector<FileId> get_web_page_file_ids(const WebPage *web_page) const;
static bool can_web_page_be_album(const WebPage *web_page);
static bool is_web_page_album(const WebPage *web_page);
Td *td_; Td *td_;
ActorShared<> parent_; ActorShared<> parent_;
WaitFreeHashMap<WebPageId, unique_ptr<WebPage>, WebPageIdHash> web_pages_; WaitFreeHashMap<WebPageId, unique_ptr<WebPage>, WebPageIdHash> web_pages_;