Files
danbooru/app/models/post_approval.rb
evazion acc4a21687 posts: allow admins to approve the same post twice.
This is so admins can overrule flags and always have the final say in whether a
post is approved, even in the event of coordinated or sockpuppet flagging.

Fixes #4980: Way to mark flags as invalid for admins
2022-06-05 15:51:58 -05:00

48 lines
1.3 KiB
Ruby

# frozen_string_literal: true
class PostApproval < ApplicationRecord
belongs_to :user
belongs_to :post, inverse_of: :approvals
validate :validate_approval
after_create :approve_post
def validate_approval
post.lock!
if post.is_active?
errors.add(:post, "is already active and cannot be approved")
end
if post.uploader == user
errors.add(:base, "You cannot approve a post you uploaded")
end
if (post.approver == user || post.approvals.exists?(user: user)) && !policy(user).can_bypass_approval_limits?
errors.add(:base, "You have previously approved this post and cannot approve it again")
end
end
def approve_post
is_pending = post.is_pending
is_undeletion = post.is_deleted
post.flags.pending.update!(status: :rejected)
post.appeals.pending.update!(status: :succeeded)
post.update(approver: user, is_flagged: false, is_pending: false, is_deleted: false)
ModAction.log("undeleted post ##{post_id}", :post_undelete, user) if is_undeletion
post.uploader.upload_limit.update_limit!(is_pending, true)
end
def self.search(params)
q = search_attributes(params, :id, :created_at, :updated_at, :user, :post)
q.apply_default_order(params)
end
def self.available_includes
[:user, :post]
end
end