DEV: adds event hook when add/remove user to group (#8038)

This commit is contained in:
Joffrey JAFFEUX 2019-09-10 11:58:08 -05:00 committed by GitHub
parent 1cebe7670a
commit a25869969a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 45 additions and 3 deletions

View File

@ -22,7 +22,7 @@ module Jobs
.where(staged: false) .where(staged: false)
.find_each do |user| .find_each do |user|
next unless user.email_confirmed? next unless user.email_confirmed?
group.add(user) group.add(user, automatic: true)
GroupActionLogger.new(Discourse.system_user, group).log_add_user_to_group(user) GroupActionLogger.new(Discourse.system_user, group).log_add_user_to_group(user)
end end

View File

@ -613,7 +613,7 @@ class Group < ActiveRecord::Base
PUBLISH_CATEGORIES_LIMIT = 10 PUBLISH_CATEGORIES_LIMIT = 10
def add(user, notify: false) def add(user, notify: false, automatic: false)
self.users.push(user) unless self.users.include?(user) self.users.push(user) unless self.users.include?(user)
if notify if notify
@ -635,12 +635,15 @@ class Group < ActiveRecord::Base
Discourse.request_refresh!(user_ids: [user.id]) Discourse.request_refresh!(user_ids: [user.id])
end end
DiscourseEvent.trigger(:user_added_to_group, user, self, automatic: automatic)
self self
end end
def remove(user) def remove(user)
self.group_users.where(user: user).each(&:destroy) self.group_users.where(user: user).each(&:destroy)
user.update_columns(primary_group_id: nil) if user.primary_group_id == self.id user.update_columns(primary_group_id: nil) if user.primary_group_id == self.id
DiscourseEvent.trigger(:user_removed_from_group, user, self)
end end
def add_owner(user) def add_owner(user)

View File

@ -23,8 +23,23 @@ describe Jobs::AutomaticGroupMembership do
group = Fabricate(:group, automatic_membership_email_domains: "wat.com", automatic_membership_retroactive: true) group = Fabricate(:group, automatic_membership_email_domains: "wat.com", automatic_membership_retroactive: true)
begin
automatic = nil
called = false
DiscourseEvent.on(:user_added_to_group) do |_u, _g, options|
automatic = options[:automatic]
called = true
end
Jobs::AutomaticGroupMembership.new.execute(group_id: group.id) Jobs::AutomaticGroupMembership.new.execute(group_id: group.id)
expect(automatic).to eql(true)
expect(called).to eq(true)
ensure
DiscourseEvent.off(:user_added_to_group)
end
group.reload group.reload
expect(group.users.include?(user1)).to eq(false) expect(group.users.include?(user1)).to eq(false)
expect(group.users.include?(user2)).to eq(false) expect(group.users.include?(user2)).to eq(false)

View File

@ -806,6 +806,11 @@ describe Group do
user.update(primary_group: group) user.update(primary_group: group)
expect { group.remove(user) }.to change { user.reload.primary_group }.from(group).to(nil) expect { group.remove(user) }.to change { user.reload.primary_group }.from(group).to(nil)
end end
it 'triggers a user_removed_from_group event' do
events = DiscourseEvent.track_events { group.remove(user) }.map { |e| e[:event_name] }
expect(events).to include(:user_removed_from_group)
end
end end
describe '#add' do describe '#add' do
@ -839,6 +844,25 @@ describe Group do
expect(notification.user_id).to eq(user.id) expect(notification.user_id).to eq(user.id)
end end
it 'triggers a user_added_to_group event' do
begin
automatic = nil
called = false
DiscourseEvent.on(:user_added_to_group) do |_u, _g, options|
automatic = options[:automatic]
called = true
end
group.add(user)
expect(automatic).to eql(false)
expect(called).to eq(true)
ensure
DiscourseEvent.off(:user_added_to_group)
end
end
context 'when adding a user into a public group' do context 'when adding a user into a public group' do
fab!(:category) { Fabricate(:category) } fab!(:category) { Fabricate(:category) }