DEV: Add 'chat_message_trashed' Discourse event (#20170)
Triggers a DiscourseEvent when a message is deleted, similar to `:chat_message_created` and `:chat_message_edited`. This is not used in this plugin, but can be used by other plugins to act when a message is trashed.
This commit is contained in:
parent
0ca2541b74
commit
25f2fb61b8
|
@ -15,6 +15,7 @@ class ChatMessageDestroyer
|
||||||
ChatMessage.transaction do
|
ChatMessage.transaction do
|
||||||
message.trash!(actor)
|
message.trash!(actor)
|
||||||
ChatMention.where(chat_message: message).destroy_all
|
ChatMention.where(chat_message: message).destroy_all
|
||||||
|
DiscourseEvent.trigger(:chat_message_trashed, message, message.chat_channel, actor)
|
||||||
|
|
||||||
# FIXME: We should do something to prevent the blue/green bubble
|
# FIXME: We should do something to prevent the blue/green bubble
|
||||||
# of other channel members from getting out of sync when a message
|
# of other channel members from getting out of sync when a message
|
||||||
|
|
|
@ -567,10 +567,17 @@ RSpec.describe Chat::ChatController do
|
||||||
it "Allows admin to delete others' messages" do
|
it "Allows admin to delete others' messages" do
|
||||||
sign_in(admin)
|
sign_in(admin)
|
||||||
|
|
||||||
expect { delete "/chat/#{chat_channel.id}/#{ChatMessage.last.id}.json" }.to change {
|
events = nil
|
||||||
ChatMessage.count
|
expect do
|
||||||
}.by(-1)
|
events =
|
||||||
|
DiscourseEvent.track_events do
|
||||||
|
delete "/chat/#{chat_channel.id}/#{ChatMessage.last.id}.json"
|
||||||
|
end
|
||||||
|
end.to change { ChatMessage.count }.by(-1)
|
||||||
|
|
||||||
expect(response.status).to eq(200)
|
expect(response.status).to eq(200)
|
||||||
|
expect(events.size).to eq(1)
|
||||||
|
expect(events.first[:event_name]).to eq(:chat_message_trashed)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "does not allow message delete when chat channel is read_only" do
|
it "does not allow message delete when chat channel is read_only" do
|
||||||
|
|
|
@ -86,5 +86,13 @@ RSpec.describe ChatMessageDestroyer do
|
||||||
expect(message_data[:deleted_id]).to eq(message_1.id)
|
expect(message_data[:deleted_id]).to eq(message_1.id)
|
||||||
expect(message_data[:deleted_at]).to be_present
|
expect(message_data[:deleted_at]).to be_present
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "triggers a DiscourseEvent" do
|
||||||
|
delete_event =
|
||||||
|
DiscourseEvent.track_events { described_class.new.trash_message(message_1, actor) }.first
|
||||||
|
|
||||||
|
expect(delete_event[:event_name]).to eq(:chat_message_trashed)
|
||||||
|
expect(delete_event[:params]).to eq([message_1, message_1.chat_channel, actor])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue