# 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 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