FEATURE: adds the user_promoted event to webhooks (#15996)
This commit is contained in:
parent
316206a991
commit
f5ec32bc8c
|
@ -14,6 +14,7 @@ class WebHookEventType < ActiveRecord::Base
|
||||||
USER_BADGE = 13
|
USER_BADGE = 13
|
||||||
GROUP_USER = 14
|
GROUP_USER = 14
|
||||||
LIKE = 15
|
LIKE = 15
|
||||||
|
USER_PROMOTED = 16
|
||||||
|
|
||||||
has_and_belongs_to_many :web_hooks
|
has_and_belongs_to_many :web_hooks
|
||||||
|
|
||||||
|
|
|
@ -114,6 +114,15 @@ DiscourseEvent.on(:user_added_to_group) do |user, group, options|
|
||||||
WebHook.enqueue_object_hooks(:group_user, group_user, :user_added_to_group, WebHookGroupUserSerializer)
|
WebHook.enqueue_object_hooks(:group_user, group_user, :user_added_to_group, WebHookGroupUserSerializer)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
DiscourseEvent.on(:user_promoted) do |payload|
|
||||||
|
user_id, new_trust_level, old_trust_level = payload.values_at(:user_id, :new_trust_level, :old_trust_level)
|
||||||
|
|
||||||
|
next if new_trust_level < old_trust_level
|
||||||
|
|
||||||
|
user = User.find(user_id)
|
||||||
|
WebHook.enqueue_object_hooks(:user_promoted, user, :user_promoted, UserSerializer)
|
||||||
|
end
|
||||||
|
|
||||||
DiscourseEvent.on(:like_created) do |post_action|
|
DiscourseEvent.on(:like_created) do |post_action|
|
||||||
user = post_action.user
|
user = post_action.user
|
||||||
group_ids = user.groups.map(&:id)
|
group_ids = user.groups.map(&:id)
|
||||||
|
|
|
@ -4300,6 +4300,9 @@ en:
|
||||||
notification_event:
|
notification_event:
|
||||||
name: "Notification Event"
|
name: "Notification Event"
|
||||||
details: "When a user receives a notification in their feed."
|
details: "When a user receives a notification in their feed."
|
||||||
|
user_promoted_event:
|
||||||
|
name: "User Promoted Event"
|
||||||
|
details: "When a user is promoted from one trust level to another."
|
||||||
user_badge_event:
|
user_badge_event:
|
||||||
name: "Badge Grant Event"
|
name: "Badge Grant Event"
|
||||||
details: "When a user receives a badge."
|
details: "When a user receives a badge."
|
||||||
|
|
|
@ -64,3 +64,8 @@ WebHookEventType.seed do |b|
|
||||||
b.id = WebHookEventType::LIKE
|
b.id = WebHookEventType::LIKE
|
||||||
b.name = "like"
|
b.name = "like"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
WebHookEventType.seed do |b|
|
||||||
|
b.id = WebHookEventType::USER_PROMOTED
|
||||||
|
b.name = "user_promoted"
|
||||||
|
end
|
||||||
|
|
|
@ -110,3 +110,11 @@ Fabricator(:like_web_hook, from: :web_hook) do
|
||||||
web_hook.web_hook_event_types = [transients[:like_hook]]
|
web_hook.web_hook_event_types = [transients[:like_hook]]
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Fabricator(:user_promoted_web_hook, from: :web_hook) do
|
||||||
|
transient user_promoted_hook: WebHookEventType.find_by(name: 'user_promoted')
|
||||||
|
|
||||||
|
after_build do |web_hook, transients|
|
||||||
|
web_hook.web_hook_event_types = [transients[:user_promoted_hook]]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
|
@ -574,6 +574,26 @@ describe WebHook do
|
||||||
expect(payload["user_id"]).to eq(user.id)
|
expect(payload["user_id"]).to eq(user.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'user promoted hooks' do
|
||||||
|
fab!(:user_promoted_web_hook) { Fabricate(:user_promoted_web_hook) }
|
||||||
|
fab!(:another_user) { Fabricate(:user, trust_level: 2) }
|
||||||
|
|
||||||
|
it 'should pass the user to the webhook job when a user is promoted' do
|
||||||
|
another_user.change_trust_level!(another_user.trust_level + 1)
|
||||||
|
|
||||||
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
||||||
|
expect(job_args["event_name"]).to eq("user_promoted")
|
||||||
|
payload = JSON.parse(job_args["payload"])
|
||||||
|
expect(payload["id"]).to eq(another_user.id)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'shouldn’t trigger when the user is demoted' do
|
||||||
|
expect {
|
||||||
|
another_user.change_trust_level!(another_user.trust_level - 1)
|
||||||
|
}.to change { Jobs::EmitWebHookEvent.jobs.length }.by(0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context 'like created hooks' do
|
context 'like created hooks' do
|
||||||
fab!(:like_web_hook) { Fabricate(:like_web_hook) }
|
fab!(:like_web_hook) { Fabricate(:like_web_hook) }
|
||||||
fab!(:another_user) { Fabricate(:user) }
|
fab!(:another_user) { Fabricate(:user) }
|
||||||
|
|
Loading…
Reference in New Issue