mirror of
https://github.com/discourse/discourse.git
synced 2026-03-03 23:54:20 +08:00
This change adds webhook support for the user anonymization event, allowing external systems to be notified when a user is anonymized in Discourse. Changes: - Add user_anonymized event type (ID: 310) to WebHookEventType - Wires up DiscourseEvent listener to trigger webhooks on anonymization - Add translation string for the event in admin UI - Add database fixture to seed the event type - Add comprehensive test coverage The webhook is triggered when UserAnonymizer.make_anonymous is called and sends the anonymized user data using WebHookUserSerializer. Nudged along the path by Claude Code
96 lines
3.1 KiB
Ruby
96 lines
3.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe "Webhook event handlers" do
|
|
fab!(:user_badge)
|
|
fab!(:web_hook, :user_badge_web_hook)
|
|
fab!(:user)
|
|
fab!(:badge)
|
|
fab!(:post)
|
|
|
|
describe "user_badge events" do
|
|
it "enqueues user_badge_granted webhook event" do
|
|
expect do
|
|
BadgeGranter.grant(badge, user, granted_by: Discourse.system_user, post_id: post.id)
|
|
end.to change { Jobs::EmitWebHookEvent.jobs.size }.by(1)
|
|
|
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
|
expect(job_args["id"]).to eq(user.user_badges.last.id)
|
|
expect(job_args["event_name"]).to eq("user_badge_granted")
|
|
end
|
|
|
|
it "enqueues user_badge_revoked webhook event" do
|
|
expect { BadgeGranter.revoke(user_badge) }.to change { Jobs::EmitWebHookEvent.jobs.size }.by(
|
|
1,
|
|
)
|
|
|
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
|
expect(job_args["id"]).to eq(user_badge.id)
|
|
expect(job_args["event_name"]).to eq("user_badge_revoked")
|
|
end
|
|
end
|
|
|
|
describe "user events" do
|
|
fab!(:user_webhook) do
|
|
wh = Fabricate(:web_hook)
|
|
wh.web_hook_event_types = [WebHookEventType.find_by(name: "user_anonymized")]
|
|
wh.save!
|
|
wh
|
|
end
|
|
|
|
it "enqueues user_anonymized webhook event" do
|
|
target_user = Fabricate(:user)
|
|
|
|
expect { UserAnonymizer.make_anonymous(target_user, user) }.to change {
|
|
Jobs::EmitWebHookEvent.jobs.size
|
|
}.by(1)
|
|
|
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
|
expect(job_args["id"]).to eq(target_user.id)
|
|
expect(job_args["event_name"]).to eq("user_anonymized")
|
|
expect(job_args["event_type"]).to eq("user")
|
|
end
|
|
end
|
|
|
|
describe "reviewable events" do
|
|
fab!(:reviewable_webhook) do
|
|
wh = Fabricate(:web_hook, categories: [post.topic.category])
|
|
wh.web_hook_event_types = [WebHookEventType.find_by(name: "reviewable_created")]
|
|
wh.save!
|
|
wh
|
|
end
|
|
|
|
it "includes category_id in the job arguments" do
|
|
reviewable = nil
|
|
expect do
|
|
reviewable =
|
|
ReviewableFlaggedPost.needs_review!(target: post, created_by: Discourse.system_user)
|
|
end.to change { Jobs::EmitWebHookEvent.jobs.size }.by(1)
|
|
|
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
|
expect(job_args["id"]).to eq(reviewable.id)
|
|
expect(job_args["event_name"]).to eq("reviewable_created")
|
|
expect(reviewable.category_id).to be_present
|
|
expect(job_args["category_id"]).to eq(reviewable.category_id)
|
|
end
|
|
|
|
it "includes tag_ids in the job arguments" do
|
|
tag = Fabricate(:tag)
|
|
post.topic.tags << tag
|
|
post.topic.save!
|
|
|
|
reviewable_webhook.tag_ids = [tag.id]
|
|
reviewable_webhook.save!
|
|
|
|
reviewable = nil
|
|
expect do
|
|
reviewable =
|
|
ReviewableFlaggedPost.needs_review!(target: post, created_by: Discourse.system_user)
|
|
end.to change { Jobs::EmitWebHookEvent.jobs.size }.by(1)
|
|
|
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
|
expect(job_args["id"]).to eq(reviewable.id)
|
|
expect(job_args["event_name"]).to eq("reviewable_created")
|
|
expect(job_args["tag_ids"]).to eq([tag.id])
|
|
end
|
|
end
|
|
end
|