DEV: adds event hook when add/remove user to group (#8038)
This commit is contained in:
parent
1cebe7670a
commit
a25869969a
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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) }
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue