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
47 lines
1.1 KiB
Ruby
47 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Admin
|
|
class ReportedStatusesController < BaseController
|
|
before_action :set_report
|
|
before_action :set_status, only: [:update, :destroy]
|
|
|
|
def create
|
|
authorize :status, :update?
|
|
|
|
@form = Form::StatusBatch.new(form_status_batch_params)
|
|
flash[:alert] = I18n.t('admin.statuses.failed_to_execute') unless @form.save
|
|
|
|
redirect_to admin_report_path(@report)
|
|
end
|
|
|
|
def update
|
|
authorize @status, :update?
|
|
@status.update(status_params)
|
|
redirect_to admin_report_path(@report)
|
|
end
|
|
|
|
def destroy
|
|
authorize @status, :destroy?
|
|
RemovalWorker.perform_async(@status.id)
|
|
render json: @status
|
|
end
|
|
|
|
private
|
|
|
|
def status_params
|
|
params.require(:status).permit(:sensitive)
|
|
end
|
|
|
|
def form_status_batch_params
|
|
params.require(:form_status_batch).permit(:action, status_ids: [])
|
|
end
|
|
|
|
def set_report
|
|
@report = Report.find(params[:report_id])
|
|
end
|
|
|
|
def set_status
|
|
@status = @report.statuses.find(params[:id])
|
|
end
|
|
end
|
|
end
|