mirror of
https://git.kescher.at/CatCatNya/catstodon.git
synced 2024-12-22 01:33:42 +01:00
7bb8b0b2fc
* Add moderator role and add pundit policies for admin actions * Add rake task for turning user into mod and revoking it again * Fix handling of unauthorized exception * Deliver new report e-mails to staff, not just admins * Add promote/demote to admin UI, hide some actions conditionally * Fix unused i18n
44 lines
1 KiB
Ruby
44 lines
1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Api::V1::ReportsController < Api::BaseController
|
|
before_action -> { doorkeeper_authorize! :read }, except: [:create]
|
|
before_action -> { doorkeeper_authorize! :write }, only: [:create]
|
|
before_action :require_user!
|
|
|
|
respond_to :json
|
|
|
|
def index
|
|
@reports = current_account.reports
|
|
render json: @reports, each_serializer: REST::ReportSerializer
|
|
end
|
|
|
|
def create
|
|
@report = current_account.reports.create!(
|
|
target_account: reported_account,
|
|
status_ids: reported_status_ids,
|
|
comment: report_params[:comment]
|
|
)
|
|
|
|
User.staff.includes(:account).each { |u| AdminMailer.new_report(u.account, @report).deliver_later }
|
|
|
|
render json: @report, serializer: REST::ReportSerializer
|
|
end
|
|
|
|
private
|
|
|
|
def reported_status_ids
|
|
Status.find(status_ids).pluck(:id)
|
|
end
|
|
|
|
def status_ids
|
|
Array(report_params[:status_ids])
|
|
end
|
|
|
|
def reported_account
|
|
Account.find(report_params[:account_id])
|
|
end
|
|
|
|
def report_params
|
|
params.permit(:account_id, :comment, status_ids: [])
|
|
end
|
|
end
|