* 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
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			48 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
 |