Always call on_message_deleted_from_database from delete_message_from_database.
This commit is contained in:
parent
151291dc50
commit
372509e838
@ -16305,7 +16305,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_message(Dialog *
|
|||||||
if (m == nullptr) {
|
if (m == nullptr) {
|
||||||
// currently there may be a race between add_message_to_database and get_message_force,
|
// currently there may be a race between add_message_to_database and get_message_force,
|
||||||
// so delete a message from database just in case
|
// so delete a message from database just in case
|
||||||
delete_message_from_database(d, message_id, nullptr, is_permanently_deleted);
|
delete_message_from_database(d, message_id, nullptr, is_permanently_deleted, source);
|
||||||
|
|
||||||
if (is_permanently_deleted && d->last_clear_history_message_id == message_id) {
|
if (is_permanently_deleted && d->last_clear_history_message_id == message_id) {
|
||||||
set_dialog_last_clear_history_date(d, 0, MessageId(), "do_delete_message");
|
set_dialog_last_clear_history_date(d, 0, MessageId(), "do_delete_message");
|
||||||
@ -16346,7 +16346,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_message(Dialog *
|
|||||||
if (!only_from_memory) {
|
if (!only_from_memory) {
|
||||||
LOG(INFO) << "Deleting " << full_message_id << " from " << source;
|
LOG(INFO) << "Deleting " << full_message_id << " from " << source;
|
||||||
|
|
||||||
delete_message_from_database(d, message_id, m, is_permanently_deleted);
|
delete_message_from_database(d, message_id, m, is_permanently_deleted, source);
|
||||||
|
|
||||||
delete_active_live_location(d->dialog_id, m);
|
delete_active_live_location(d->dialog_id, m);
|
||||||
remove_message_file_sources(d->dialog_id, m);
|
remove_message_file_sources(d->dialog_id, m);
|
||||||
@ -16440,13 +16440,9 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_message(Dialog *
|
|||||||
|
|
||||||
d->being_deleted_message_id = MessageId();
|
d->being_deleted_message_id = MessageId();
|
||||||
|
|
||||||
if (!only_from_memory) {
|
if (need_get_history) {
|
||||||
if (need_get_history && !td_->auth_manager_->is_bot() && have_input_peer(d->dialog_id, AccessRights::Read)) {
|
send_closure_later(actor_id(this), &MessagesManager::get_history_from_the_end, d->dialog_id, true, false,
|
||||||
send_closure_later(actor_id(this), &MessagesManager::get_history_from_the_end, d->dialog_id, true, false,
|
Promise<Unit>());
|
||||||
Promise<Unit>());
|
|
||||||
}
|
|
||||||
|
|
||||||
on_message_deleted_from_database(d, result.get(), source);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
on_message_deleted(d, result.get(), is_permanently_deleted, source);
|
on_message_deleted(d, result.get(), is_permanently_deleted, source);
|
||||||
@ -16456,8 +16452,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_message(Dialog *
|
|||||||
|
|
||||||
void MessagesManager::on_message_deleted_from_database(Dialog *d, const Message *m, const char *source) {
|
void MessagesManager::on_message_deleted_from_database(Dialog *d, const Message *m, const char *source) {
|
||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
CHECK(m != nullptr);
|
if (m == nullptr || td_->auth_manager_->is_bot()) {
|
||||||
if (td_->auth_manager_->is_bot()) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -16596,7 +16591,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_scheduled_messag
|
|||||||
if (message == nullptr) {
|
if (message == nullptr) {
|
||||||
// currently there may be a race between add_message_to_database and get_message_force,
|
// currently there may be a race between add_message_to_database and get_message_force,
|
||||||
// so delete a message from database just in case
|
// so delete a message from database just in case
|
||||||
delete_message_from_database(d, message_id, nullptr, is_permanently_deleted);
|
delete_message_from_database(d, message_id, nullptr, is_permanently_deleted, source);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
CHECK(d->scheduled_messages != nullptr);
|
CHECK(d->scheduled_messages != nullptr);
|
||||||
@ -16608,7 +16603,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_scheduled_messag
|
|||||||
if (message == nullptr) {
|
if (message == nullptr) {
|
||||||
// currently there may be a race between add_message_to_database and get_message_force,
|
// currently there may be a race between add_message_to_database and get_message_force,
|
||||||
// so delete a message from database just in case
|
// so delete a message from database just in case
|
||||||
delete_message_from_database(d, message_id, nullptr, is_permanently_deleted);
|
delete_message_from_database(d, message_id, nullptr, is_permanently_deleted, source);
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -16622,7 +16617,7 @@ unique_ptr<MessagesManager::Message> MessagesManager::do_delete_scheduled_messag
|
|||||||
|
|
||||||
LOG(INFO) << "Deleting " << FullMessageId{d->dialog_id, message_id} << " from " << source;
|
LOG(INFO) << "Deleting " << FullMessageId{d->dialog_id, message_id} << " from " << source;
|
||||||
|
|
||||||
delete_message_from_database(d, message_id, m, is_permanently_deleted);
|
delete_message_from_database(d, message_id, m, is_permanently_deleted, source);
|
||||||
|
|
||||||
remove_message_file_sources(d->dialog_id, m);
|
remove_message_file_sources(d->dialog_id, m);
|
||||||
|
|
||||||
@ -34245,8 +34240,7 @@ MessagesManager::Message *MessagesManager::add_message_to_dialog(Dialog *d, uniq
|
|||||||
if (!message_id.is_scheduled() && message_id <= d->last_clear_history_message_id) {
|
if (!message_id.is_scheduled() && message_id <= d->last_clear_history_message_id) {
|
||||||
LOG(INFO) << "Skip adding cleared " << message_id << " to " << dialog_id << " from " << source;
|
LOG(INFO) << "Skip adding cleared " << message_id << " to " << dialog_id << " from " << source;
|
||||||
if (from_database) {
|
if (from_database) {
|
||||||
delete_message_from_database(d, message_id, message.get(), true);
|
delete_message_from_database(d, message_id, message.get(), true, "cleared full history");
|
||||||
on_message_deleted_from_database(d, message.get(), "cleared full history");
|
|
||||||
}
|
}
|
||||||
debug_add_message_to_dialog_fail_reason_ = "cleared full history";
|
debug_add_message_to_dialog_fail_reason_ = "cleared full history";
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -34331,8 +34325,7 @@ MessagesManager::Message *MessagesManager::add_message_to_dialog(Dialog *d, uniq
|
|||||||
message_id <= d->max_unavailable_message_id) {
|
message_id <= d->max_unavailable_message_id) {
|
||||||
LOG(INFO) << "Can't add an unavailable " << message_id << " to " << dialog_id << " from " << source;
|
LOG(INFO) << "Can't add an unavailable " << message_id << " to " << dialog_id << " from " << source;
|
||||||
if (from_database) {
|
if (from_database) {
|
||||||
delete_message_from_database(d, message_id, message.get(), true);
|
delete_message_from_database(d, message_id, message.get(), true, "ignore unavailable message");
|
||||||
on_message_deleted_from_database(d, message.get(), "ignore unavailable message");
|
|
||||||
}
|
}
|
||||||
debug_add_message_to_dialog_fail_reason_ = "ignore unavailable message";
|
debug_add_message_to_dialog_fail_reason_ = "ignore unavailable message";
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -34552,8 +34545,7 @@ MessagesManager::Message *MessagesManager::add_message_to_dialog(Dialog *d, uniq
|
|||||||
if (dialog_type == DialogType::SecretChat) {
|
if (dialog_type == DialogType::SecretChat) {
|
||||||
LOG(INFO) << "Can't add " << message_id << " with expired self-destruct timer to " << dialog_id << " from "
|
LOG(INFO) << "Can't add " << message_id << " with expired self-destruct timer to " << dialog_id << " from "
|
||||||
<< source;
|
<< source;
|
||||||
delete_message_from_database(d, message_id, message.get(), true);
|
delete_message_from_database(d, message_id, message.get(), true, "delete self-destructed message");
|
||||||
on_message_deleted_from_database(d, message.get(), "delete self-destructed message");
|
|
||||||
debug_add_message_to_dialog_fail_reason_ = "delete self-destructed message";
|
debug_add_message_to_dialog_fail_reason_ = "delete self-destructed message";
|
||||||
d->being_added_message_id = MessageId();
|
d->being_added_message_id = MessageId();
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -34573,8 +34565,7 @@ MessagesManager::Message *MessagesManager::add_message_to_dialog(Dialog *d, uniq
|
|||||||
auto server_time = G()->server_time();
|
auto server_time = G()->server_time();
|
||||||
if (message->date + message->ttl_period <= server_time) {
|
if (message->date + message->ttl_period <= server_time) {
|
||||||
LOG(INFO) << "Can't add auto-deleted " << message_id << " to " << dialog_id << " from " << source;
|
LOG(INFO) << "Can't add auto-deleted " << message_id << " to " << dialog_id << " from " << source;
|
||||||
delete_message_from_database(d, message_id, message.get(), true);
|
delete_message_from_database(d, message_id, message.get(), true, "delete auto-deleted message");
|
||||||
on_message_deleted_from_database(d, message.get(), "delete auto-deleted message");
|
|
||||||
debug_add_message_to_dialog_fail_reason_ = "delete auto-deleted message";
|
debug_add_message_to_dialog_fail_reason_ = "delete auto-deleted message";
|
||||||
d->being_added_message_id = MessageId();
|
d->being_added_message_id = MessageId();
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@ -35329,7 +35320,7 @@ bool MessagesManager::need_delete_message_files(DialogId dialog_id, const Messag
|
|||||||
}
|
}
|
||||||
|
|
||||||
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, const char *source) {
|
||||||
CHECK(d != nullptr);
|
CHECK(d != nullptr);
|
||||||
if (!message_id.is_valid() && !message_id.is_valid_scheduled()) {
|
if (!message_id.is_valid() && !message_id.is_valid_scheduled()) {
|
||||||
return;
|
return;
|
||||||
@ -35409,19 +35400,19 @@ void MessagesManager::delete_message_from_database(Dialog *d, MessageId message_
|
|||||||
delete_message_files(d->dialog_id, m);
|
delete_message_files(d->dialog_id, m);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!G()->use_message_database()) {
|
if (G()->use_message_database()) {
|
||||||
return;
|
DeleteMessageLogEvent log_event;
|
||||||
|
|
||||||
|
log_event.full_message_id_ = {d->dialog_id, message_id};
|
||||||
|
|
||||||
|
if (need_delete_files) {
|
||||||
|
log_event.file_ids_ = get_message_file_ids(m);
|
||||||
|
}
|
||||||
|
|
||||||
|
do_delete_message_log_event(log_event);
|
||||||
}
|
}
|
||||||
|
|
||||||
DeleteMessageLogEvent log_event;
|
on_message_deleted_from_database(d, m, source);
|
||||||
|
|
||||||
log_event.full_message_id_ = {d->dialog_id, message_id};
|
|
||||||
|
|
||||||
if (need_delete_files) {
|
|
||||||
log_event.file_ids_ = get_message_file_ids(m);
|
|
||||||
}
|
|
||||||
|
|
||||||
do_delete_message_log_event(log_event);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MessagesManager::do_delete_message_log_event(const DeleteMessageLogEvent &log_event) const {
|
void MessagesManager::do_delete_message_log_event(const DeleteMessageLogEvent &log_event) const {
|
||||||
|
@ -2268,7 +2268,8 @@ class MessagesManager final : public Actor {
|
|||||||
|
|
||||||
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);
|
||||||
|
|
||||||
void delete_message_from_database(Dialog *d, MessageId message_id, const Message *m, bool is_permanently_deleted);
|
void delete_message_from_database(Dialog *d, MessageId message_id, const Message *m, bool is_permanently_deleted,
|
||||||
|
const char *source);
|
||||||
|
|
||||||
void update_reply_to_message_id(DialogId dialog_id, MessageId old_message_id, MessageId new_message_id,
|
void update_reply_to_message_id(DialogId dialog_id, MessageId old_message_id, MessageId new_message_id,
|
||||||
bool have_new_message, const char *source);
|
bool have_new_message, const char *source);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user