FIX: ensures `all_mentioned_user_ids` is not used as identifier (#21452)

When making the list of users to notify we set `all_mentioned_user_ids` key on the `to_notify` Hash.

This hash will be passed around until the actual moment where we send the notifications:

```ruby
identifier_text =
  case identifier_type
  when :here_mentions
    "@here"
  when :global_mentions
    "@all"
  when :direct_mentions
    ""
  else
    "@#{identifier_type}"
  end
```

As not found `all_mentioned_user_ids` would end up being sent as `@all_mentioned_user_ids` which is obviously incorrect.

This commit is a direct fix to the issue and will remove the key as soon as we have used it sooner up in the chain.

This bug was reproducible when doing this sequence of events:

- create a message with a direct mention: `@bob hi`
- edit this message into a global mention `@all hi`
This commit is contained in:
Joffrey JAFFEUX 2023-05-09 13:00:19 +02:00 committed by GitHub
parent ae369b1100
commit 54b2a85b27
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 1 deletions

View File

@ -95,7 +95,7 @@ module Chat
notify_creator_of_inaccessible_mentions(to_notify) notify_creator_of_inaccessible_mentions(to_notify)
notify_mentioned_users(to_notify, already_notified_user_ids: already_notified_user_ids) notify_mentioned_users(to_notify, already_notified_user_ids: already_notified_user_ids)
to_notify to_notify.except(:all_mentioned_user_ids)
end end
private private

View File

@ -121,6 +121,23 @@ describe Chat::Notifier do
include_examples "channel-wide mentions" include_examples "channel-wide mentions"
include_examples "ensure only channel members are notified" include_examples "ensure only channel members are notified"
describe "editing a direct mention into a global mention" do
let(:mention) { "hello @#{user_2.username}!" }
it "doesn't return :all_mentioned_user_ids" do
msg = build_cooked_msg(mention, user_1)
Chat::MessageUpdater.update(
guardian: user_1.guardian,
chat_message: msg,
new_content: "hello @all",
)
to_notify = described_class.new(msg, msg.created_at).notify_edit
expect(to_notify[:all_mentioned_user_ids]).not_to be_present
end
end
describe "users ignoring or muting the user creating the message" do describe "users ignoring or muting the user creating the message" do
it "does not send notifications to the user who is muting the acting user" do it "does not send notifications to the user who is muting the acting user" do
Fabricate(:muted_user, user: user_2, muted_user: user_1) Fabricate(:muted_user, user: user_2, muted_user: user_1)