Refactor api/v1/reports controller (#3469)
This commit is contained in:
		
							parent
							
								
									7f55430652
								
							
						
					
					
						commit
						7c6e02aaf3
					
				| @ -8,22 +8,32 @@ class Api::V1::ReportsController < ApiController | ||||
|   respond_to :json | ||||
| 
 | ||||
|   def index | ||||
|     @reports = Report.where(account: current_account) | ||||
|     @reports = current_account.reports | ||||
|   end | ||||
| 
 | ||||
|   def create | ||||
|     status_ids = report_params[:status_ids].is_a?(Enumerable) ? report_params[:status_ids] : [report_params[:status_ids]] | ||||
| 
 | ||||
|     @report = Report.create!(account: current_account, | ||||
|                              target_account: Account.find(report_params[:account_id]), | ||||
|                              status_ids: Status.find(status_ids).pluck(:id), | ||||
|                              comment: report_params[:comment]) | ||||
| 
 | ||||
|     @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 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user