mirror of
https://github.com/discourse/discourse.git
synced 2025-06-05 14:07:30 +08:00
SECURITY: Update reviewable user serializer payload
Exclude email from reviewable user serializer based on user scope.
This commit is contained in:
@ -3,12 +3,15 @@
|
||||
RSpec.describe ReviewableUserSerializer do
|
||||
let(:user) { Fabricate(:user) }
|
||||
let(:admin) { Fabricate(:admin) }
|
||||
let(:moderator) { Fabricate(:moderator) }
|
||||
let(:reviewable) { Reviewable.find_by(target: user) }
|
||||
|
||||
it "includes the user fields for review" do
|
||||
before do
|
||||
SiteSetting.must_approve_users = true
|
||||
Jobs::CreateUserReviewable.new.execute(user_id: user.id)
|
||||
reviewable = Reviewable.find_by(target: user)
|
||||
end
|
||||
|
||||
it "includes the user fields for review" do
|
||||
json = ReviewableUserSerializer.new(reviewable, scope: Guardian.new(admin), root: nil).as_json
|
||||
expect(json[:user_id]).to eq(reviewable.target_id)
|
||||
expect(json[:payload]["username"]).to eq(user.username)
|
||||
@ -16,4 +19,26 @@ RSpec.describe ReviewableUserSerializer do
|
||||
expect(json[:payload]["name"]).to eq(user.name)
|
||||
expect(json[:topic_url]).to be_blank
|
||||
end
|
||||
|
||||
it "excludes the email user field for moderators" do
|
||||
json =
|
||||
ReviewableUserSerializer.new(reviewable, scope: Guardian.new(moderator), root: nil).as_json
|
||||
expect(json[:user_id]).to eq(reviewable.target_id)
|
||||
expect(json[:payload]["username"]).to eq(user.username)
|
||||
expect(json[:payload]["email"]).to eq(nil)
|
||||
expect(json[:payload]["name"]).to eq(user.name)
|
||||
expect(json[:topic_url]).to be_blank
|
||||
end
|
||||
|
||||
it "includes the email user field for moderators if enabled" do
|
||||
SiteSetting.moderators_view_emails = true
|
||||
|
||||
json =
|
||||
ReviewableUserSerializer.new(reviewable, scope: Guardian.new(moderator), root: nil).as_json
|
||||
expect(json[:user_id]).to eq(reviewable.target_id)
|
||||
expect(json[:payload]["username"]).to eq(user.username)
|
||||
expect(json[:payload]["email"]).to eq(user.email)
|
||||
expect(json[:payload]["name"]).to eq(user.name)
|
||||
expect(json[:topic_url]).to be_blank
|
||||
end
|
||||
end
|
||||
|
Reference in New Issue
Block a user