2022-11-28 11:32:57 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class ChatMessageDestroyer
|
|
|
|
def destroy_in_batches(chat_messages_query, batch_size: 200)
|
|
|
|
chat_messages_query
|
|
|
|
.in_batches(of: batch_size)
|
|
|
|
.each do |relation|
|
|
|
|
destroyed_ids = relation.destroy_all.pluck(:id)
|
|
|
|
reset_last_read(destroyed_ids)
|
|
|
|
delete_flags(destroyed_ids)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-02-03 10:52:13 -05:00
|
|
|
def trash_message(message, actor)
|
|
|
|
ChatMessage.transaction do
|
|
|
|
message.trash!(actor)
|
|
|
|
ChatMention.where(chat_message: message).destroy_all
|
|
|
|
|
|
|
|
# FIXME: We should do something to prevent the blue/green bubble
|
|
|
|
# of other channel members from getting out of sync when a message
|
|
|
|
# gets deleted.
|
|
|
|
ChatPublisher.publish_delete!(message.chat_channel, message)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-11-28 11:32:57 -05:00
|
|
|
private
|
|
|
|
|
|
|
|
def reset_last_read(message_ids)
|
|
|
|
UserChatChannelMembership.where(last_read_message_id: message_ids).update_all(
|
|
|
|
last_read_message_id: nil,
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
def delete_flags(message_ids)
|
|
|
|
ReviewableChatMessage.where(target_id: message_ids).destroy_all
|
|
|
|
end
|
|
|
|
end
|