Add MessagesManager::need_delete_message_files.

GitOrigin-RevId: a80f3af30813063872adb791820205a66990640a
This commit is contained in:
levlam 2019-04-20 16:41:32 +03:00
parent 7072ee111a
commit 74ca960636
2 changed files with 17 additions and 6 deletions

View File

@ -22422,8 +22422,7 @@ MessagesManager::Message *MessagesManager::add_message_to_dialog(Dialog *d, uniq
} }
auto new_file_ids = get_message_content_file_ids(m->content.get(), td_); auto new_file_ids = get_message_content_file_ids(m->content.get(), td_);
if (new_file_ids != old_file_ids) { if (new_file_ids != old_file_ids) {
if (m->message_id.is_server() && if (need_delete_message_files(d, m)) {
(dialog_id.get_type() == DialogType::User || dialog_id.get_type() == DialogType::SecretChat)) {
for (auto file_id : old_file_ids) { for (auto file_id : old_file_ids) {
if (std::find(new_file_ids.begin(), new_file_ids.end(), file_id) == new_file_ids.end()) { if (std::find(new_file_ids.begin(), new_file_ids.end(), file_id) == new_file_ids.end()) {
send_closure(G()->file_manager(), &FileManager::delete_file, file_id, Promise<>(), send_closure(G()->file_manager(), &FileManager::delete_file, file_id, Promise<>(),
@ -23089,8 +23088,19 @@ void MessagesManager::delete_message_files(const Message *m) const {
} }
} }
bool MessagesManager::need_delete_message_files(Dialog *d, const Message *m) {
CHECK(d != nullptr);
if (m == nullptr || !m->message_id.is_server()) {
return false;
}
auto dialog_type = d->dialog_id.get_type();
return dialog_type == DialogType::User || dialog_type == DialogType::SecretChat;
}
void MessagesManager::delete_message_from_database(Dialog *d, MessageId message_id, const Message *m, void MessagesManager::delete_message_from_database(Dialog *d, MessageId message_id, const Message *m,
bool is_permanently_deleted) { bool is_permanently_deleted) {
CHECK(d != nullptr);
if (!message_id.is_valid()) { if (!message_id.is_valid()) {
return; return;
} }
@ -23124,9 +23134,8 @@ void MessagesManager::delete_message_from_database(Dialog *d, MessageId message_
d->mention_notification_group.group_id, message_id, false, "delete_message_from_database"); d->mention_notification_group.group_id, message_id, false, "delete_message_from_database");
} }
auto need_delete_message_files = m != nullptr && (d->dialog_id.get_type() == DialogType::User || auto need_delete_files = need_delete_message_files(d, m);
d->dialog_id.get_type() == DialogType::SecretChat); if (need_delete_files) {
if (need_delete_message_files) {
delete_message_files(m); delete_message_files(m);
} }
@ -23138,7 +23147,7 @@ void MessagesManager::delete_message_from_database(Dialog *d, MessageId message_
logevent.full_message_id_ = {d->dialog_id, message_id}; logevent.full_message_id_ = {d->dialog_id, message_id};
if (need_delete_message_files) { if (need_delete_files) {
logevent.file_ids_ = get_message_file_ids(m); logevent.file_ids_ = get_message_file_ids(m);
} }

View File

@ -1556,6 +1556,8 @@ class MessagesManager : public Actor {
void on_message_changed(const Dialog *d, const Message *m, bool need_send_update, const char *source); void on_message_changed(const Dialog *d, const Message *m, bool need_send_update, const char *source);
bool need_delete_message_files(Dialog *d, const Message *m);
void add_message_to_database(const Dialog *d, const Message *m, const char *source); void add_message_to_database(const Dialog *d, const Message *m, const char *source);
void delete_all_dialog_messages_from_database(Dialog *d, MessageId max_message_id, const char *source); void delete_all_dialog_messages_from_database(Dialog *d, MessageId max_message_id, const char *source);