Add StoryManager::delete_pending_story.

This commit is contained in:
levlam 2023-07-03 18:01:25 +03:00
parent 36518625c3
commit 51547fba0e
2 changed files with 19 additions and 6 deletions

View File

@ -573,6 +573,8 @@ class StoryManager::SendStoryQuery final : public Td::ResultHandler {
LOG(INFO) << "Receive result for SendStoryQuery: " << to_string(ptr); LOG(INFO) << "Receive result for SendStoryQuery: " << to_string(ptr);
td_->updates_manager_->on_get_updates(std::move(ptr), Promise<Unit>()); td_->updates_manager_->on_get_updates(std::move(ptr), Promise<Unit>());
td_->story_manager_->delete_pending_story(std::move(pending_story_));
td_->file_manager_->delete_partial_remote_location(file_id_); td_->file_manager_->delete_partial_remote_location(file_id_);
} }
@ -589,6 +591,7 @@ class StoryManager::SendStoryQuery final : public Td::ResultHandler {
return; return;
} else { } else {
td_->file_manager_->delete_partial_remote_location(file_id_); td_->file_manager_->delete_partial_remote_location(file_id_);
td_->story_manager_->delete_pending_story(std::move(pending_story_));
} }
} }
}; };
@ -2565,11 +2568,19 @@ void StoryManager::send_story(td_api::object_ptr<td_api::InputStoryContent> &&in
auto pending_story = td::make_unique<PendingStory>(dialog_id, StoryId(), 0 /*log_event_id*/, ++send_story_count_, auto pending_story = td::make_unique<PendingStory>(dialog_id, StoryId(), 0 /*log_event_id*/, ++send_story_count_,
random_id, std::move(story)); random_id, std::move(story));
do_send_story(std::move(pending_story), {}); do_send_story(std::move(pending_story), {});
promise.set_value(get_story_object({dialog_id, StoryId()}, story_ptr)); promise.set_value(get_story_object({dialog_id, StoryId()}, story_ptr));
} }
void StoryManager::delete_pending_story(unique_ptr<PendingStory> &&pending_story) {
CHECK(pending_story != nullptr);
if (pending_story->log_event_id_ != 0) {
binlog_erase(G()->td_db()->get_binlog(), pending_story->log_event_id_);
}
}
void StoryManager::do_send_story(unique_ptr<PendingStory> &&pending_story, vector<int> bad_parts) { void StoryManager::do_send_story(unique_ptr<PendingStory> &&pending_story, vector<int> bad_parts) {
CHECK(pending_story != nullptr); CHECK(pending_story != nullptr);
CHECK(pending_story->story_ != nullptr); CHECK(pending_story->story_ != nullptr);
@ -2610,10 +2621,12 @@ void StoryManager::on_upload_story(FileId file_id, telegram_api::object_ptr<tele
if (input_file == nullptr && file_view.has_remote_location()) { if (input_file == nullptr && file_view.has_remote_location()) {
if (file_view.main_remote_location().is_web()) { if (file_view.main_remote_location().is_web()) {
LOG(ERROR) << "Can't use web photo as story"; LOG(ERROR) << "Can't use web photo as story";
delete_pending_story(std::move(pending_story));
return; return;
} }
if (pending_story->was_reuploaded_) { if (pending_story->was_reuploaded_) {
LOG(ERROR) << "Failed to reupload story"; LOG(ERROR) << "Failed to reupload story";
delete_pending_story(std::move(pending_story));
return; return;
} }
pending_story->was_reuploaded_ = true; pending_story->was_reuploaded_ = true;
@ -2655,9 +2668,7 @@ void StoryManager::on_upload_story_error(FileId file_id, Status status) {
if (is_edit) { if (is_edit) {
on_story_edited(file_id, std::move(pending_story), std::move(status)); on_story_edited(file_id, std::move(pending_story), std::move(status));
} else { } else {
if (pending_story->log_event_id_ != 0) { delete_pending_story(std::move(pending_story));
binlog_erase(G()->td_db()->get_binlog(), pending_story->log_event_id_);
}
} }
} }
@ -2742,6 +2753,7 @@ void StoryManager::do_edit_story(FileId file_id, unique_ptr<PendingStory> &&pend
if (file_id.is_valid()) { if (file_id.is_valid()) {
td_->file_manager_->cancel_upload(file_id); td_->file_manager_->cancel_upload(file_id);
} }
delete_pending_story(std::move(pending_story));
return; return;
} }
CHECK(story->content_ != nullptr); CHECK(story->content_ != nullptr);
@ -2761,12 +2773,11 @@ void StoryManager::on_story_edited(FileId file_id, unique_ptr<PendingStory> pend
auto it = being_edited_stories_.find(story_full_id); auto it = being_edited_stories_.find(story_full_id);
if (story == nullptr || story->edit_generation_ != pending_story->random_id_ || it == being_edited_stories_.end()) { if (story == nullptr || story->edit_generation_ != pending_story->random_id_ || it == being_edited_stories_.end()) {
LOG(INFO) << "Ignore outdated edit of " << story_full_id; LOG(INFO) << "Ignore outdated edit of " << story_full_id;
delete_pending_story(std::move(pending_story));
return; return;
} }
delete_pending_story(std::move(pending_story));
CHECK(story->content_ != nullptr); CHECK(story->content_ != nullptr);
if (pending_story->log_event_id_ != 0) {
binlog_erase(G()->td_db()->get_binlog(), pending_story->log_event_id_);
}
auto promises = std::move(it->second->promises_); auto promises = std::move(it->second->promises_);
bool is_changed = it->second->content_ != nullptr || bool is_changed = it->second->content_ != nullptr ||
(it->second->edit_caption_ && it->second->caption_ != story->caption_) || (it->second->edit_caption_ && it->second->caption_ != story->caption_) ||

View File

@ -326,6 +326,8 @@ class StoryManager final : public Actor {
void on_reload_story(StoryFullId story_full_id, Result<Unit> &&result); void on_reload_story(StoryFullId story_full_id, Result<Unit> &&result);
static void delete_pending_story(unique_ptr<PendingStory> &&pending_story);
void do_send_story(unique_ptr<PendingStory> &&pending_story, vector<int> bad_parts); void do_send_story(unique_ptr<PendingStory> &&pending_story, vector<int> bad_parts);
void on_upload_story(FileId file_id, telegram_api::object_ptr<telegram_api::InputFile> input_file); void on_upload_story(FileId file_id, telegram_api::object_ptr<telegram_api::InputFile> input_file);