|
|
- # frozen_string_literal: true
-
- class Api::V1::ReportsController < ApiController
- 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
- end
-
- def create
- @report = current_account.reports.create!(
- target_account: reported_account,
- status_ids: reported_status_ids,
- comment: report_params[:comment]
- )
- render :show
- 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
|