FEATURE: Add user_confirmed_email to user event webhook (#12539)
This commit is contained in:
parent
5b342ae505
commit
d5b30b9b7b
|
@ -72,6 +72,7 @@ class EmailToken < ActiveRecord::Base
|
||||||
user.save!
|
user.save!
|
||||||
user.create_reviewable unless skip_reviewable
|
user.create_reviewable unless skip_reviewable
|
||||||
user.set_automatic_groups
|
user.set_automatic_groups
|
||||||
|
DiscourseEvent.trigger(:user_confirmed_email, user)
|
||||||
end
|
end
|
||||||
|
|
||||||
if user
|
if user
|
||||||
|
|
|
@ -41,6 +41,7 @@ end
|
||||||
user_logged_in
|
user_logged_in
|
||||||
user_approved
|
user_approved
|
||||||
user_updated
|
user_updated
|
||||||
|
user_confirmed_email
|
||||||
).each do |event|
|
).each do |event|
|
||||||
DiscourseEvent.on(event) do |user|
|
DiscourseEvent.on(event) do |user|
|
||||||
WebHook.enqueue_object_hooks(:user, user, event)
|
WebHook.enqueue_object_hooks(:user, user, event)
|
||||||
|
|
|
@ -3999,7 +3999,7 @@ en:
|
||||||
details: "When there is a new reply, edit, deleted or recovered."
|
details: "When there is a new reply, edit, deleted or recovered."
|
||||||
user_event:
|
user_event:
|
||||||
name: "User Event"
|
name: "User Event"
|
||||||
details: "When a user logs in, logs out, is created, approved or updated."
|
details: "When a user logs in, logs out, confirms their email, is created, approved or updated."
|
||||||
group_event:
|
group_event:
|
||||||
name: "Group Event"
|
name: "Group Event"
|
||||||
details: "When a group is created, updated or destroyed."
|
details: "When a group is created, updated or destroyed."
|
||||||
|
|
|
@ -324,7 +324,6 @@ describe WebHook do
|
||||||
Fabricate(:user_web_hook, active: true)
|
Fabricate(:user_web_hook, active: true)
|
||||||
|
|
||||||
user
|
user
|
||||||
user.activate
|
|
||||||
Jobs::CreateUserReviewable.new.execute(user_id: user.id)
|
Jobs::CreateUserReviewable.new.execute(user_id: user.id)
|
||||||
|
|
||||||
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
||||||
|
@ -333,6 +332,14 @@ describe WebHook do
|
||||||
payload = JSON.parse(job_args["payload"])
|
payload = JSON.parse(job_args["payload"])
|
||||||
expect(payload["id"]).to eq(user.id)
|
expect(payload["id"]).to eq(user.id)
|
||||||
|
|
||||||
|
email_token = user.email_tokens.create(email: user.email)
|
||||||
|
EmailToken.confirm(email_token.token)
|
||||||
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
||||||
|
|
||||||
|
expect(job_args["event_name"]).to eq("user_confirmed_email")
|
||||||
|
payload = JSON.parse(job_args["payload"])
|
||||||
|
expect(payload["id"]).to eq(user.id)
|
||||||
|
|
||||||
admin
|
admin
|
||||||
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
job_args = Jobs::EmitWebHookEvent.jobs.last["args"].first
|
||||||
|
|
||||||
|
|
|
@ -230,7 +230,7 @@ describe UsersController do
|
||||||
end
|
end
|
||||||
|
|
||||||
expect(events.map { |event| event[:event_name] }).to contain_exactly(
|
expect(events.map { |event| event[:event_name] }).to contain_exactly(
|
||||||
:user_logged_in, :user_first_logged_in
|
:user_logged_in, :user_first_logged_in, :user_confirmed_email
|
||||||
)
|
)
|
||||||
|
|
||||||
expect(response.status).to eq(200)
|
expect(response.status).to eq(200)
|
||||||
|
|
Loading…
Reference in New Issue