FEATURE: emit external_id field with user webhook
This commit is contained in:
parent
fc36f095a7
commit
47058b29d3
|
@ -56,7 +56,6 @@ module Jobs
|
||||||
|
|
||||||
def build_web_hook_body(args, web_hook)
|
def build_web_hook_body(args, web_hook)
|
||||||
body = {}
|
body = {}
|
||||||
guardian = Guardian.new(Discourse.system_user)
|
|
||||||
event_type = args[:event_type].to_s
|
event_type = args[:event_type].to_s
|
||||||
|
|
||||||
if ping_event?(event_type)
|
if ping_event?(event_type)
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
class WebHookUserSerializer < UserSerializer
|
class WebHookUserSerializer < UserSerializer
|
||||||
|
attributes :external_id
|
||||||
|
|
||||||
# remove staff attributes
|
# remove staff attributes
|
||||||
def staff_attributes(*attrs)
|
def staff_attributes(*attrs)
|
||||||
end
|
end
|
||||||
|
@ -6,4 +8,13 @@ class WebHookUserSerializer < UserSerializer
|
||||||
def include_email?
|
def include_email?
|
||||||
scope.is_admin?
|
scope.is_admin?
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def include_external_id?
|
||||||
|
scope.is_admin? && object.single_sign_on_record
|
||||||
|
end
|
||||||
|
|
||||||
|
def external_id
|
||||||
|
object.single_sign_on_record.external_id
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -188,7 +188,7 @@ describe WebHook do
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should enqueue the right hooks for user events' do
|
it 'should enqueue the right hooks for user events' do
|
||||||
user_web_hook = Fabricate(:user_web_hook, active: true)
|
_user_web_hook = Fabricate(:user_web_hook, active: true)
|
||||||
|
|
||||||
Sidekiq::Testing.fake! do
|
Sidekiq::Testing.fake! do
|
||||||
user
|
user
|
||||||
|
|
|
@ -1,14 +1,21 @@
|
||||||
require 'rails_helper'
|
require 'rails_helper'
|
||||||
|
|
||||||
RSpec.describe WebHookUserSerializer do
|
RSpec.describe WebHookUserSerializer do
|
||||||
let(:user) { Fabricate(:user) }
|
let(:user) do
|
||||||
|
user = Fabricate(:user)
|
||||||
|
SingleSignOnRecord.create!(user_id: user.id, external_id: '12345', last_payload: '')
|
||||||
|
user
|
||||||
|
end
|
||||||
|
|
||||||
let(:admin) { Fabricate(:admin) }
|
let(:admin) { Fabricate(:admin) }
|
||||||
|
|
||||||
subject { described_class.new(user, scope: Guardian.new(admin), root: false) }
|
let :serializer do
|
||||||
|
WebHookUserSerializer.new(user, scope: Guardian.new(admin), root: false)
|
||||||
it "should include the user's email" do
|
end
|
||||||
payload = subject.as_json
|
|
||||||
|
|
||||||
|
it "should include relevant user info" do
|
||||||
|
payload = serializer.as_json
|
||||||
expect(payload[:email]).to eq(user.email)
|
expect(payload[:email]).to eq(user.email)
|
||||||
|
expect(payload[:external_id]).to eq('12345')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue