FIX: Deleting Users should work nicely with Reviewable Users
"Rejecting" a user in the queue is equivalent to deleting them, which would then making it impossible to review rejected users. Now we store information about the user in the payload so if they are deleted things still display in the Rejected view. Secondly, if a user is destroyed outside of the review queue, it will now automatically "Reject" that queue item.
This commit is contained in:
parent
3cf922a58a
commit
111a502231
|
@ -1,7 +1,7 @@
|
||||||
<div class='reviewable-user-info'>
|
<div class='reviewable-user-info'>
|
||||||
<div class='reviewable-user-details'>
|
<div class='reviewable-user-details'>
|
||||||
{{reviewable.username}}
|
{{reviewable.payload.username}}
|
||||||
{{reviewable.email}}
|
{{reviewable.payload.email}}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{{yield}}
|
{{yield}}
|
||||||
|
|
|
@ -5,7 +5,16 @@ class Jobs::CreateUserReviewable < Jobs::Base
|
||||||
if user = User.find_by(id: args[:user_id])
|
if user = User.find_by(id: args[:user_id])
|
||||||
return if user.approved?
|
return if user.approved?
|
||||||
|
|
||||||
reviewable = ReviewableUser.create!(target: user, created_by: Discourse.system_user, reviewable_by_moderator: true)
|
reviewable = ReviewableUser.create!(
|
||||||
|
target: user,
|
||||||
|
created_by: Discourse.system_user,
|
||||||
|
reviewable_by_moderator: true,
|
||||||
|
payload: {
|
||||||
|
username: user.username,
|
||||||
|
name: user.name,
|
||||||
|
email: user.email
|
||||||
|
}
|
||||||
|
)
|
||||||
reviewable.add_score(
|
reviewable.add_score(
|
||||||
Discourse.system_user,
|
Discourse.system_user,
|
||||||
ReviewableScore.types[:needs_approval],
|
ReviewableScore.types[:needs_approval],
|
||||||
|
|
|
@ -34,7 +34,7 @@ class ReviewableUser < Reviewable
|
||||||
end
|
end
|
||||||
|
|
||||||
def perform_reject(performed_by, args)
|
def perform_reject(performed_by, args)
|
||||||
destroyer = UserDestroyer.new(performed_by)
|
destroyer = UserDestroyer.new(performed_by) unless args[:skip_delete]
|
||||||
|
|
||||||
# If a user has posts, we won't delete them to preserve their content.
|
# If a user has posts, we won't delete them to preserve their content.
|
||||||
# However the reviable record will be "rejected" and they will remain
|
# However the reviable record will be "rejected" and they will remain
|
||||||
|
|
|
@ -1220,7 +1220,6 @@ class User < ActiveRecord::Base
|
||||||
Jobs.enqueue(:create_user_reviewable, user_id: self.id)
|
Jobs.enqueue(:create_user_reviewable, user_id: self.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def badge_grant
|
def badge_grant
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
class ReviewableUserSerializer < ReviewableSerializer
|
class ReviewableUserSerializer < ReviewableSerializer
|
||||||
|
|
||||||
target_attributes(
|
payload_attributes(
|
||||||
:username,
|
:username,
|
||||||
:email,
|
:email,
|
||||||
:name
|
:name
|
||||||
|
|
|
@ -28,6 +28,10 @@ class UserDestroyer
|
||||||
Draft.where(user_id: user.id).delete_all
|
Draft.where(user_id: user.id).delete_all
|
||||||
Reviewable.where(created_by_id: user.id).delete_all
|
Reviewable.where(created_by_id: user.id).delete_all
|
||||||
|
|
||||||
|
if reviewable = Reviewable.find_by(target: user)
|
||||||
|
reviewable.perform(@actor, :reject, skip_delete: true)
|
||||||
|
end
|
||||||
|
|
||||||
if opts[:delete_posts]
|
if opts[:delete_posts]
|
||||||
user.posts.each do |post|
|
user.posts.each do |post|
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
class FixReviewableUsers < ActiveRecord::Migration[5.2]
|
||||||
|
def up
|
||||||
|
execute(<<~SQL)
|
||||||
|
UPDATE reviewables
|
||||||
|
SET payload = json_build_object(
|
||||||
|
'username', u.username,
|
||||||
|
'name', u.name,
|
||||||
|
'email', ue.email
|
||||||
|
)::jsonb
|
||||||
|
FROM reviewables AS r
|
||||||
|
LEFT OUTER JOIN users AS u ON u.id = r.target_id
|
||||||
|
LEFT OUTER JOIN user_emails AS ue ON ue.user_id = u.id AND ue.primary
|
||||||
|
WHERE r.id = reviewables.id
|
||||||
|
AND r.type = 'ReviewableUser'
|
||||||
|
SQL
|
||||||
|
end
|
||||||
|
|
||||||
|
def down
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,19 @@
|
||||||
|
require 'rails_helper'
|
||||||
|
require_dependency 'jobs/regular/create_user_reviewable'
|
||||||
|
|
||||||
|
describe Jobs::CreateUserReviewable do
|
||||||
|
|
||||||
|
let(:user) { Fabricate(:user) }
|
||||||
|
|
||||||
|
it "creates the reviewable" do
|
||||||
|
described_class.new.execute(user_id: user.id)
|
||||||
|
|
||||||
|
reviewable = Reviewable.find_by(target: user)
|
||||||
|
expect(reviewable).to be_present
|
||||||
|
expect(reviewable.pending?).to eq(true)
|
||||||
|
expect(reviewable.reviewable_scores).to be_present
|
||||||
|
expect(reviewable.payload['username']).to eq(user.username)
|
||||||
|
expect(reviewable.payload['name']).to eq(user.name)
|
||||||
|
expect(reviewable.payload['email']).to eq(user.email)
|
||||||
|
end
|
||||||
|
end
|
|
@ -36,6 +36,17 @@ RSpec.describe ReviewableUser, type: :model do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "when a user is deleted" do
|
||||||
|
it "should reject the reviewable" do
|
||||||
|
Jobs::CreateUserReviewable.new.execute(user_id: user.id)
|
||||||
|
reviewable = Reviewable.find_by(target: user)
|
||||||
|
expect(reviewable.pending?).to eq(true)
|
||||||
|
|
||||||
|
UserDestroyer.new(Discourse.system_user).destroy(user)
|
||||||
|
expect(reviewable.reload.rejected?).to eq(true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context "perform" do
|
context "perform" do
|
||||||
let(:reviewable) { Fabricate(:reviewable) }
|
let(:reviewable) { Fabricate(:reviewable) }
|
||||||
context "approve" do
|
context "approve" do
|
||||||
|
|
|
@ -2,15 +2,18 @@ require 'rails_helper'
|
||||||
|
|
||||||
describe ReviewableUserSerializer do
|
describe ReviewableUserSerializer do
|
||||||
|
|
||||||
let(:reviewable) { Fabricate(:reviewable) }
|
let(:user) { Fabricate(:user) }
|
||||||
let(:admin) { Fabricate(:admin) }
|
let(:admin) { Fabricate(:admin) }
|
||||||
|
|
||||||
it "includes the user fields for review" do
|
it "includes the user fields for review" do
|
||||||
|
Jobs::CreateUserReviewable.new.execute(user_id: user.id)
|
||||||
|
reviewable = Reviewable.find_by(target: user)
|
||||||
|
|
||||||
json = ReviewableUserSerializer.new(reviewable, scope: Guardian.new(admin), root: nil).as_json
|
json = ReviewableUserSerializer.new(reviewable, scope: Guardian.new(admin), root: nil).as_json
|
||||||
expect(json[:user_id]).to eq(reviewable.target_id)
|
expect(json[:user_id]).to eq(reviewable.target_id)
|
||||||
expect(json[:username]).to eq(reviewable.target.username)
|
expect(json[:payload]['username']).to eq(user.username)
|
||||||
expect(json[:email]).to eq(reviewable.target.email)
|
expect(json[:payload]['email']).to eq(user.email)
|
||||||
expect(json[:name]).to eq(reviewable.target.name)
|
expect(json[:payload]['name']).to eq(user.name)
|
||||||
expect(json[:topic_url]).to be_blank
|
expect(json[:topic_url]).to be_blank
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue