Don't send updateChatActiveStories about chats with unknown active stories.

This commit is contained in:
levlam 2023-08-16 17:34:36 +03:00
parent 11f4af48e0
commit 5c63b80cce
3 changed files with 36 additions and 21 deletions

View File

@ -1159,10 +1159,10 @@ StoryManager::StoryManager(Td *td, ActorShared<> parent) : td_(td), parent_(std:
} }
StoryManager::~StoryManager() { StoryManager::~StoryManager() {
Scheduler::instance()->destroy_on_scheduler(G()->get_gc_scheduler_id(), story_full_id_to_file_source_id_, stories_, Scheduler::instance()->destroy_on_scheduler(
stories_by_global_id_, inaccessible_story_full_ids_, G()->get_gc_scheduler_id(), story_full_id_to_file_source_id_, stories_, stories_by_global_id_,
deleted_story_full_ids_, failed_to_load_story_full_ids_, story_messages_, inaccessible_story_full_ids_, deleted_story_full_ids_, failed_to_load_story_full_ids_, story_messages_,
active_stories_, max_read_story_ids_, failed_to_load_active_stories_); active_stories_, updated_active_stories_, max_read_story_ids_, failed_to_load_active_stories_);
} }
void StoryManager::start_up() { void StoryManager::start_up() {
@ -2026,6 +2026,9 @@ void StoryManager::get_dialog_expiring_stories(DialogId owner_dialog_id,
return promise.set_error(Status::Error(400, "Can't access the story sender")); return promise.set_error(Status::Error(400, "Can't access the story sender"));
} }
if (owner_dialog_id.get_type() != DialogType::User) { if (owner_dialog_id.get_type() != DialogType::User) {
if (updated_active_stories_.insert(owner_dialog_id)) {
send_update_chat_active_stories(owner_dialog_id, nullptr);
}
return promise.set_value(get_chat_active_stories_object(owner_dialog_id, nullptr)); return promise.set_value(get_chat_active_stories_object(owner_dialog_id, nullptr));
} }
@ -2035,6 +2038,9 @@ void StoryManager::get_dialog_expiring_stories(DialogId owner_dialog_id,
if (!promise) { if (!promise) {
return promise.set_value(nullptr); return promise.set_value(nullptr);
} }
if (updated_active_stories_.insert(owner_dialog_id)) {
send_update_chat_active_stories(owner_dialog_id, active_stories);
}
promise.set_value(get_chat_active_stories_object(owner_dialog_id, active_stories)); promise.set_value(get_chat_active_stories_object(owner_dialog_id, active_stories));
promise = {}; promise = {};
} }
@ -2126,7 +2132,11 @@ void StoryManager::on_get_dialog_expiring_stories(DialogId owner_dialog_id,
td_->contacts_manager_->on_get_users(std::move(stories->users_), "on_get_dialog_expiring_stories"); td_->contacts_manager_->on_get_users(std::move(stories->users_), "on_get_dialog_expiring_stories");
owner_dialog_id = on_get_user_stories(owner_dialog_id, std::move(stories->stories_), Promise<Unit>()); owner_dialog_id = on_get_user_stories(owner_dialog_id, std::move(stories->stories_), Promise<Unit>());
if (promise) { if (promise) {
promise.set_value(get_chat_active_stories_object(owner_dialog_id)); auto active_stories = get_active_stories(owner_dialog_id);
if (updated_active_stories_.insert(owner_dialog_id)) {
send_update_chat_active_stories(owner_dialog_id, active_stories);
}
promise.set_value(get_chat_active_stories_object(owner_dialog_id, active_stories));
} else { } else {
promise.set_value(nullptr); promise.set_value(nullptr);
} }
@ -2711,11 +2721,6 @@ td_api::object_ptr<td_api::stories> StoryManager::get_stories_object(int32 total
})); }));
} }
td_api::object_ptr<td_api::chatActiveStories> StoryManager::get_chat_active_stories_object(
DialogId owner_dialog_id) const {
return get_chat_active_stories_object(owner_dialog_id, get_active_stories(owner_dialog_id));
}
td_api::object_ptr<td_api::chatActiveStories> StoryManager::get_chat_active_stories_object( td_api::object_ptr<td_api::chatActiveStories> StoryManager::get_chat_active_stories_object(
DialogId owner_dialog_id, const ActiveStories *active_stories) const { DialogId owner_dialog_id, const ActiveStories *active_stories) const {
StoryListId story_list_id; StoryListId story_list_id;
@ -3486,15 +3491,21 @@ void StoryManager::send_update_story(StoryFullId story_full_id, const Story *sto
send_closure(G()->td(), &Td::send_update, td_api::make_object<td_api::updateStory>(std::move(story_object))); send_closure(G()->td(), &Td::send_update, td_api::make_object<td_api::updateStory>(std::move(story_object)));
} }
td_api::object_ptr<td_api::updateChatActiveStories> StoryManager::get_update_chat_active_stories( td_api::object_ptr<td_api::updateChatActiveStories> StoryManager::get_update_chat_active_stories_object(
DialogId owner_dialog_id, const ActiveStories *active_stories) const { DialogId owner_dialog_id, const ActiveStories *active_stories) const {
return td_api::make_object<td_api::updateChatActiveStories>( return td_api::make_object<td_api::updateChatActiveStories>(
get_chat_active_stories_object(owner_dialog_id, active_stories)); get_chat_active_stories_object(owner_dialog_id, active_stories));
} }
void StoryManager::send_update_chat_active_stories(DialogId owner_dialog_id, void StoryManager::send_update_chat_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories) {
const ActiveStories *active_stories) const { if (updated_active_stories_.count(owner_dialog_id) == 0) {
send_closure(G()->td(), &Td::send_update, get_update_chat_active_stories(owner_dialog_id, active_stories)); if (active_stories == nullptr || active_stories->public_order_ == 0) {
LOG(INFO) << "Skip update about active stories in " << owner_dialog_id;
return;
}
updated_active_stories_.insert(owner_dialog_id);
}
send_closure(G()->td(), &Td::send_update, get_update_chat_active_stories_object(owner_dialog_id, active_stories));
} }
void StoryManager::save_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories, void StoryManager::save_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories,
@ -4011,6 +4022,7 @@ void StoryManager::do_send_story(unique_ptr<PendingStory> &&pending_story, vecto
being_sent_stories_[pending_story->random_id_] = story_full_id; being_sent_stories_[pending_story->random_id_] = story_full_id;
being_sent_story_random_ids_[story_full_id] = pending_story->random_id_; being_sent_story_random_ids_[story_full_id] = pending_story->random_id_;
updated_active_stories_.insert(pending_story->dialog_id_);
send_update_chat_active_stories(pending_story->dialog_id_, active_stories); send_update_chat_active_stories(pending_story->dialog_id_, active_stories);
} else { } else {
pending_story->story_->content_ = dup_story_content(td_, pending_story->story_->content_.get()); pending_story->story_->content_ = dup_story_content(td_, pending_story->story_->content_.get());
@ -4569,7 +4581,9 @@ void StoryManager::remove_story_notifications_by_story_ids(DialogId dialog_id, c
void StoryManager::get_current_state(vector<td_api::object_ptr<td_api::Update>> &updates) const { void StoryManager::get_current_state(vector<td_api::object_ptr<td_api::Update>> &updates) const {
active_stories_.foreach([&](const DialogId &dialog_id, const unique_ptr<ActiveStories> &active_stories) { active_stories_.foreach([&](const DialogId &dialog_id, const unique_ptr<ActiveStories> &active_stories) {
updates.push_back(get_update_chat_active_stories(dialog_id, active_stories.get())); if (updated_active_stories_.count(dialog_id) > 0) {
updates.push_back(get_update_chat_active_stories_object(dialog_id, active_stories.get()));
}
}); });
if (!td_->auth_manager_->is_bot()) { if (!td_->auth_manager_->is_bot()) {
for (auto story_list_id : {StoryListId::main(), StoryListId::archive()}) { for (auto story_list_id : {StoryListId::main(), StoryListId::archive()}) {

View File

@ -398,8 +398,6 @@ class StoryManager final : public Actor {
td_api::object_ptr<td_api::story> get_story_object(StoryFullId story_full_id, const Story *story) const; td_api::object_ptr<td_api::story> get_story_object(StoryFullId story_full_id, const Story *story) const;
td_api::object_ptr<td_api::chatActiveStories> get_chat_active_stories_object(DialogId owner_dialog_id) const;
td_api::object_ptr<td_api::chatActiveStories> get_chat_active_stories_object( td_api::object_ptr<td_api::chatActiveStories> get_chat_active_stories_object(
DialogId owner_dialog_id, const ActiveStories *active_stories) const; DialogId owner_dialog_id, const ActiveStories *active_stories) const;
@ -498,10 +496,10 @@ class StoryManager final : public Actor {
void send_update_story(StoryFullId story_full_id, const Story *story); void send_update_story(StoryFullId story_full_id, const Story *story);
td_api::object_ptr<td_api::updateChatActiveStories> get_update_chat_active_stories( td_api::object_ptr<td_api::updateChatActiveStories> get_update_chat_active_stories_object(
DialogId owner_dialog_id, const ActiveStories *active_stories) const; DialogId owner_dialog_id, const ActiveStories *active_stories) const;
void send_update_chat_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories) const; void send_update_chat_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories);
void save_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories, Promise<Unit> &&promise, void save_active_stories(DialogId owner_dialog_id, const ActiveStories *active_stories, Promise<Unit> &&promise,
const char *source) const; const char *source) const;
@ -566,6 +564,8 @@ class StoryManager final : public Actor {
WaitFreeHashMap<DialogId, unique_ptr<ActiveStories>, DialogIdHash> active_stories_; WaitFreeHashMap<DialogId, unique_ptr<ActiveStories>, DialogIdHash> active_stories_;
WaitFreeHashSet<DialogId, DialogIdHash> updated_active_stories_;
WaitFreeHashMap<DialogId, StoryId, DialogIdHash> max_read_story_ids_; WaitFreeHashMap<DialogId, StoryId, DialogIdHash> max_read_story_ids_;
WaitFreeHashSet<DialogId, DialogIdHash> failed_to_load_active_stories_; WaitFreeHashSet<DialogId, DialogIdHash> failed_to_load_active_stories_;

View File

@ -56,15 +56,16 @@ class WaitFreeHashSet {
} }
public: public:
void insert(const KeyT &key) { bool insert(const KeyT &key) {
if (wait_free_storage_ != nullptr) { if (wait_free_storage_ != nullptr) {
return get_wait_free_storage(key).insert(key); return get_wait_free_storage(key).insert(key);
} }
default_set_.insert(key); auto result = default_set_.insert(key).second;
if (default_set_.size() == max_storage_size_) { if (default_set_.size() == max_storage_size_) {
split_storage(); split_storage();
} }
return result;
} }
size_t count(const KeyT &key) const { size_t count(const KeyT &key) const {