Add LoadDialogExpiringStoriesLogEvent.
This commit is contained in:
parent
ce9bce5994
commit
a52bdbf79c
|
@ -4954,7 +4954,7 @@ stories total_count:int32 stories:vector<story> = Stories;
|
||||||
storyInfo story_id:int32 date:int32 = StoryInfo;
|
storyInfo story_id:int32 date:int32 = StoryInfo;
|
||||||
|
|
||||||
//@description Describes active stories sent by the same sender
|
//@description Describes active stories sent by the same sender
|
||||||
//@list Identifier of the story list in which the stories are shown; maybe null if the stories aren't from a current user's contact
|
//@list Identifier of the story list in which the stories are shown; may be null if the stories aren't from a current user's contact
|
||||||
//@story_sender_chat_id Identifier of the sender of the stories
|
//@story_sender_chat_id Identifier of the sender of the stories
|
||||||
//@max_read_story_id Identifier of the last read active story
|
//@max_read_story_id Identifier of the last read active story
|
||||||
//@stories Basic information about the stories; use getStory to get full information about the stories
|
//@stories Basic information about the stories; use getStory to get full information about the stories
|
||||||
|
|
|
@ -971,10 +971,62 @@ void StoryManager::get_dialog_expiring_stories(DialogId owner_dialog_id,
|
||||||
td_->create_handler<GetUserStoriesQuery>(std::move(query_promise))->send(owner_dialog_id.get_user_id());
|
td_->create_handler<GetUserStoriesQuery>(std::move(query_promise))->send(owner_dialog_id.get_user_id());
|
||||||
}
|
}
|
||||||
|
|
||||||
void StoryManager::load_dialog_expiring_stories(DialogId owner_dialog_id) {
|
class StoryManager::LoadDialogExpiringStoriesLogEvent {
|
||||||
|
public:
|
||||||
|
DialogId dialog_id_;
|
||||||
|
|
||||||
|
template <class StorerT>
|
||||||
|
void store(StorerT &storer) const {
|
||||||
|
td::store(dialog_id_, storer);
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class ParserT>
|
||||||
|
void parse(ParserT &parser) {
|
||||||
|
td::parse(dialog_id_, parser);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
uint64 StoryManager::save_load_dialog_expiring_stories_log_event(DialogId owner_dialog_id) {
|
||||||
|
LoadDialogExpiringStoriesLogEvent log_event{owner_dialog_id};
|
||||||
|
return binlog_add(G()->td_db()->get_binlog(), LogEvent::HandlerType::LoadDialogExpiringStories,
|
||||||
|
get_log_event_storer(log_event));
|
||||||
|
}
|
||||||
|
|
||||||
|
void StoryManager::load_dialog_expiring_stories(DialogId owner_dialog_id, uint64 log_event_id) {
|
||||||
|
if (load_expiring_stories_log_event_ids_.count(owner_dialog_id)) {
|
||||||
|
if (log_event_id != 0) {
|
||||||
|
binlog_erase(G()->td_db()->get_binlog(), log_event_id);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (log_event_id == 0 && G()->use_message_database()) {
|
||||||
|
log_event_id = save_load_dialog_expiring_stories_log_event(owner_dialog_id);
|
||||||
|
}
|
||||||
|
load_expiring_stories_log_event_ids_[owner_dialog_id] = log_event_id;
|
||||||
|
|
||||||
// send later to ensure that active stories are inited before sending the request
|
// send later to ensure that active stories are inited before sending the request
|
||||||
send_closure_later(actor_id(this), &StoryManager::get_dialog_expiring_stories, owner_dialog_id,
|
auto promise = PromiseCreator::lambda(
|
||||||
Promise<td_api::object_ptr<td_api::activeStories>>());
|
[actor_id = actor_id(this), owner_dialog_id](Result<td_api::object_ptr<td_api::activeStories>> &&) {
|
||||||
|
if (!G()->close_flag()) {
|
||||||
|
send_closure(actor_id, &StoryManager::on_load_dialog_expiring_stories, owner_dialog_id);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
send_closure_later(actor_id(this), &StoryManager::get_dialog_expiring_stories, owner_dialog_id, std::move(promise));
|
||||||
|
}
|
||||||
|
|
||||||
|
void StoryManager::on_load_dialog_expiring_stories(DialogId owner_dialog_id) {
|
||||||
|
if (G()->close_flag()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
auto it = load_expiring_stories_log_event_ids_.find(owner_dialog_id);
|
||||||
|
if (it != load_expiring_stories_log_event_ids_.end()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
auto log_event_id = it->second;
|
||||||
|
load_expiring_stories_log_event_ids_.erase(it);
|
||||||
|
if (log_event_id != 0) {
|
||||||
|
binlog_erase(G()->td_db()->get_binlog(), log_event_id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void StoryManager::on_get_dialog_expiring_stories(DialogId owner_dialog_id,
|
void StoryManager::on_get_dialog_expiring_stories(DialogId owner_dialog_id,
|
||||||
|
@ -1197,7 +1249,7 @@ uint64 StoryManager::save_read_stories_on_server_log_event(DialogId dialog_id, S
|
||||||
}
|
}
|
||||||
|
|
||||||
void StoryManager::read_stories_on_server(DialogId owner_dialog_id, StoryId story_id, uint64 log_event_id) {
|
void StoryManager::read_stories_on_server(DialogId owner_dialog_id, StoryId story_id, uint64 log_event_id) {
|
||||||
if (log_event_id == 0 && G()->use_chat_info_database()) {
|
if (log_event_id == 0 && G()->use_message_database()) {
|
||||||
log_event_id = save_read_stories_on_server_log_event(owner_dialog_id, story_id);
|
log_event_id = save_read_stories_on_server_log_event(owner_dialog_id, story_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1638,7 +1690,7 @@ StoryId StoryManager::on_get_new_story(DialogId owner_dialog_id,
|
||||||
auto active_stories = get_active_stories(owner_dialog_id);
|
auto active_stories = get_active_stories(owner_dialog_id);
|
||||||
if (active_stories == nullptr) {
|
if (active_stories == nullptr) {
|
||||||
if (is_subscribed_to_dialog_stories(owner_dialog_id)) {
|
if (is_subscribed_to_dialog_stories(owner_dialog_id)) {
|
||||||
load_dialog_expiring_stories(owner_dialog_id);
|
load_dialog_expiring_stories(owner_dialog_id, 0);
|
||||||
}
|
}
|
||||||
} else if (!contains(active_stories->story_ids_, story_id)) {
|
} else if (!contains(active_stories->story_ids_, story_id)) {
|
||||||
auto story_ids = active_stories->story_ids_;
|
auto story_ids = active_stories->story_ids_;
|
||||||
|
@ -2508,6 +2560,18 @@ void StoryManager::on_binlog_events(vector<BinlogEvent> &&events) {
|
||||||
read_stories_on_server(dialog_id, max_read_story_id, event.id_);
|
read_stories_on_server(dialog_id, max_read_story_id, event.id_);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case LogEvent::HandlerType::LoadDialogExpiringStories: {
|
||||||
|
LoadDialogExpiringStoriesLogEvent log_event;
|
||||||
|
log_event_parse(log_event, event.get_data()).ensure();
|
||||||
|
|
||||||
|
auto dialog_id = log_event.dialog_id_;
|
||||||
|
if (!td_->messages_manager_->have_dialog_force(dialog_id, "LoadDialogExpiringStoriesLogEvent")) {
|
||||||
|
binlog_erase(G()->td_db()->get_binlog(), event.id_);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
load_dialog_expiring_stories(dialog_id, event.id_);
|
||||||
|
break;
|
||||||
|
}
|
||||||
default:
|
default:
|
||||||
LOG(FATAL) << "Unsupported log event type " << event.type_;
|
LOG(FATAL) << "Unsupported log event type " << event.type_;
|
||||||
}
|
}
|
||||||
|
|
|
@ -195,6 +195,7 @@ class StoryManager final : public Actor {
|
||||||
|
|
||||||
class DeleteStoryOnServerLogEvent;
|
class DeleteStoryOnServerLogEvent;
|
||||||
class ReadStoriesOnServerLogEvent;
|
class ReadStoriesOnServerLogEvent;
|
||||||
|
class LoadDialogExpiringStoriesLogEvent;
|
||||||
|
|
||||||
static constexpr int32 OPENED_STORY_POLL_PERIOD = 60;
|
static constexpr int32 OPENED_STORY_POLL_PERIOD = 60;
|
||||||
static constexpr int32 VIEWED_STORY_POLL_PERIOD = 300;
|
static constexpr int32 VIEWED_STORY_POLL_PERIOD = 300;
|
||||||
|
@ -268,7 +269,11 @@ class StoryManager final : public Actor {
|
||||||
telegram_api::object_ptr<telegram_api::stories_userStories> &&stories,
|
telegram_api::object_ptr<telegram_api::stories_userStories> &&stories,
|
||||||
Promise<td_api::object_ptr<td_api::activeStories>> &&promise);
|
Promise<td_api::object_ptr<td_api::activeStories>> &&promise);
|
||||||
|
|
||||||
void load_dialog_expiring_stories(DialogId owner_dialog_id);
|
static uint64 save_load_dialog_expiring_stories_log_event(DialogId owner_dialog_id);
|
||||||
|
|
||||||
|
void load_dialog_expiring_stories(DialogId owner_dialog_id, uint64 log_event_id);
|
||||||
|
|
||||||
|
void on_load_dialog_expiring_stories(DialogId owner_dialog_id);
|
||||||
|
|
||||||
vector<FileId> get_story_file_ids(const Story *story) const;
|
vector<FileId> get_story_file_ids(const Story *story) const;
|
||||||
|
|
||||||
|
@ -340,6 +345,8 @@ class StoryManager final : public Actor {
|
||||||
|
|
||||||
WaitFreeHashMap<DialogId, StoryId, DialogIdHash> max_read_story_ids_;
|
WaitFreeHashMap<DialogId, StoryId, DialogIdHash> max_read_story_ids_;
|
||||||
|
|
||||||
|
FlatHashMap<DialogId, uint64, DialogIdHash> load_expiring_stories_log_event_ids_;
|
||||||
|
|
||||||
FlatHashMap<StoryFullId, unique_ptr<BeingEditedStory>, StoryFullIdHash> being_edited_stories_;
|
FlatHashMap<StoryFullId, unique_ptr<BeingEditedStory>, StoryFullIdHash> being_edited_stories_;
|
||||||
|
|
||||||
FlatHashMap<DialogId, PendingStoryViews, DialogIdHash> pending_story_views_;
|
FlatHashMap<DialogId, PendingStoryViews, DialogIdHash> pending_story_views_;
|
||||||
|
|
|
@ -128,6 +128,7 @@ Status init_binlog(Binlog &binlog, string path, BinlogKeyValue<Binlog> &binlog_p
|
||||||
break;
|
break;
|
||||||
case LogEvent::HandlerType::DeleteStoryOnServer:
|
case LogEvent::HandlerType::DeleteStoryOnServer:
|
||||||
case LogEvent::HandlerType::ReadStoriesOnServer:
|
case LogEvent::HandlerType::ReadStoriesOnServer:
|
||||||
|
case LogEvent::HandlerType::LoadDialogExpiringStories:
|
||||||
events.to_story_manager.push_back(event.clone());
|
events.to_story_manager.push_back(event.clone());
|
||||||
break;
|
break;
|
||||||
case LogEvent::HandlerType::UpdateScopeNotificationSettingsOnServer:
|
case LogEvent::HandlerType::UpdateScopeNotificationSettingsOnServer:
|
||||||
|
|
|
@ -109,6 +109,7 @@ class LogEvent {
|
||||||
SaveAppLog = 0x300,
|
SaveAppLog = 0x300,
|
||||||
DeleteStoryOnServer = 0x400,
|
DeleteStoryOnServer = 0x400,
|
||||||
ReadStoriesOnServer = 0x401,
|
ReadStoriesOnServer = 0x401,
|
||||||
|
LoadDialogExpiringStories = 0x402,
|
||||||
ConfigPmcMagic = 0x1f18,
|
ConfigPmcMagic = 0x1f18,
|
||||||
BinlogPmcMagic = 0x4327
|
BinlogPmcMagic = 0x4327
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue
Block a user