flags: fix mods not being able to see the flagger on self-flagged posts.

Fix a bug where, when a mod searched for their own flags, they couldn't
see their own self-flagged uploads.

Fix a bug where, when a mod viewed their own flags, they couldn't see
the flagger name for their own self-flagged uploads.

This also makes it so you can do things like `/post_flags?search[creator][level]=20`
to search flags by user level.
This commit is contained in:
evazion
2022-09-21 16:22:42 -05:00
parent a35f49e905
commit a6e0872ce4
3 changed files with 31 additions and 11 deletions

View File

@@ -59,17 +59,9 @@ class PostFlag < ApplicationRecord
end end
def search(params) def search(params)
q = search_attributes(params, :id, :created_at, :updated_at, :reason, :status, :post) q = search_attributes(params, :id, :created_at, :updated_at, :reason, :status, :post, :creator)
q = q.text_attribute_matches(:reason, params[:reason_matches]) q = q.text_attribute_matches(:reason, params[:reason_matches])
if params[:creator_id].present?
flagger = User.find(params[:creator_id])
q = q.creator_matches(flagger, CurrentUser.user)
elsif params[:creator_name].present?
flagger = User.find_by_name(params[:creator_name])
q = q.creator_matches(flagger, CurrentUser.user)
end
if params[:category] if params[:category]
q = q.category_matches(params[:category]) q = q.category_matches(params[:category])
end end

View File

@@ -14,7 +14,7 @@ class PostFlagPolicy < ApplicationPolicy
end end
def can_view_flagger? def can_view_flagger?
(user.is_moderator? || record.creator_id == user.id) && (record.post&.uploader_id != user.id) record.creator_id == user.id || (user.is_moderator? && record.post&.uploader_id != user.id)
end end
def permitted_attributes_for_create def permitted_attributes_for_create
@@ -30,4 +30,15 @@ class PostFlagPolicy < ApplicationPolicy
attributes -= [:creator_id] unless can_view_flagger? attributes -= [:creator_id] unless can_view_flagger?
attributes attributes
end end
def visible_for_search(relation, attribute)
case attribute
in :creator | :creator_id if can_search_flagger?
relation.where(creator: user).or(relation.where.not(post: user.posts))
in :creator | :creator_id
relation.where(creator: user)
else
relation
end
end
end end

View File

@@ -6,7 +6,7 @@ class PostFlagsControllerTest < ActionDispatch::IntegrationTest
@user = create(:user) @user = create(:user)
@flagger = create(:gold_user, id: 999, created_at: 2.weeks.ago) @flagger = create(:gold_user, id: 999, created_at: 2.weeks.ago)
@uploader = create(:mod_user, name: "chen", created_at: 2.weeks.ago) @uploader = create(:mod_user, name: "chen", created_at: 2.weeks.ago)
@mod = create(:mod_user) @mod = create(:mod_user, name: "mod")
@post = create(:post, id: 101, is_flagged: true, uploader: @uploader) @post = create(:post, id: 101, is_flagged: true, uploader: @uploader)
@post_flag = create(:post_flag, reason: "xxx", post: @post, creator: @flagger) @post_flag = create(:post_flag, reason: "xxx", post: @post, creator: @flagger)
end end
@@ -65,6 +65,14 @@ class PostFlagsControllerTest < ActionDispatch::IntegrationTest
assert_select "tr#post-flag-#{@post_flag.id} .flagged-column a.user-gold", true assert_select "tr#post-flag-#{@post_flag.id} .flagged-column a.user-gold", true
end end
should "let mods see the flagger name on self-flagged posts" do
@post_flag = create(:post_flag, creator: @mod, post: build(:post, uploader: @mod))
get_auth post_flags_path, @mod
assert_response :success
assert_select "tr#post-flag-#{@post_flag.id} .flagged-column a.user-moderator", true
end
context "as a normal user" do context "as a normal user" do
setup do setup do
CurrentUser.user = @user CurrentUser.user = @user
@@ -99,6 +107,15 @@ class PostFlagsControllerTest < ActionDispatch::IntegrationTest
should respond_to_search(creator_id: 999).with { @post_flag } should respond_to_search(creator_id: 999).with { @post_flag }
end end
context "when the user is a mod and flags their own upload" do
setup do
CurrentUser.user = @mod
@post_flag = create(:post_flag, creator: @mod, post: build(:post, uploader: @mod))
end
should respond_to_search(creator_name: "mod").with { @post_flag }
end
context "when the user is the flagger" do context "when the user is the flagger" do
setup do setup do
CurrentUser.user = @flagger CurrentUser.user = @flagger