97 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class Api::V1::Notifications::RequestsController < Api::BaseController
 | |
|   include Redisable
 | |
| 
 | |
|   before_action -> { doorkeeper_authorize! :read, :'read:notifications' }, only: [:index, :show, :merged?]
 | |
|   before_action -> { doorkeeper_authorize! :write, :'write:notifications' }, except: [:index, :show, :merged?]
 | |
| 
 | |
|   before_action :require_user!
 | |
|   before_action :set_request, only: [:show, :accept, :dismiss]
 | |
|   before_action :set_requests, only: [:accept_bulk, :dismiss_bulk]
 | |
| 
 | |
|   after_action :insert_pagination_headers, only: :index
 | |
| 
 | |
|   def index
 | |
|     with_read_replica do
 | |
|       @requests = load_requests
 | |
|       @relationships = relationships
 | |
|     end
 | |
| 
 | |
|     render json: @requests, each_serializer: REST::NotificationRequestSerializer, relationships: @relationships
 | |
|   end
 | |
| 
 | |
|   def merged?
 | |
|     render json: { merged: redis.get("notification_unfilter_jobs:#{current_account.id}").to_i <= 0 }
 | |
|   end
 | |
| 
 | |
|   def show
 | |
|     render json: @request, serializer: REST::NotificationRequestSerializer
 | |
|   end
 | |
| 
 | |
|   def accept
 | |
|     AcceptNotificationRequestService.new.call(@request)
 | |
|     render_empty
 | |
|   end
 | |
| 
 | |
|   def dismiss
 | |
|     DismissNotificationRequestService.new.call(@request)
 | |
|     render_empty
 | |
|   end
 | |
| 
 | |
|   def accept_bulk
 | |
|     @requests.each { |request| AcceptNotificationRequestService.new.call(request) }
 | |
|     render_empty
 | |
|   end
 | |
| 
 | |
|   def dismiss_bulk
 | |
|     @requests.each(&:destroy!)
 | |
|     render_empty
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def load_requests
 | |
|     requests = NotificationRequest.where(account: current_account).without_suspended.includes(:last_status, from_account: [:account_stat, :user]).to_a_paginated_by_id(
 | |
|       limit_param(DEFAULT_ACCOUNTS_LIMIT),
 | |
|       params_slice(:max_id, :since_id, :min_id)
 | |
|     )
 | |
| 
 | |
|     NotificationRequest.preload_cache_collection(requests) do |statuses|
 | |
|       preload_collection(statuses, Status)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def relationships
 | |
|     StatusRelationshipsPresenter.new(@requests.map(&:last_status), current_user&.account_id)
 | |
|   end
 | |
| 
 | |
|   def set_request
 | |
|     @request = NotificationRequest.where(account: current_account).find(params[:id])
 | |
|   end
 | |
| 
 | |
|   def set_requests
 | |
|     @requests = NotificationRequest.where(account: current_account, id: Array(params[:id]).uniq.map(&:to_i))
 | |
|   end
 | |
| 
 | |
|   def next_path
 | |
|     api_v1_notifications_requests_url pagination_params(max_id: pagination_max_id) if records_continue?
 | |
|   end
 | |
| 
 | |
|   def prev_path
 | |
|     api_v1_notifications_requests_url pagination_params(min_id: pagination_since_id) unless @requests.empty?
 | |
|   end
 | |
| 
 | |
|   def records_continue?
 | |
|     @requests.size == limit_param(DEFAULT_ACCOUNTS_LIMIT)
 | |
|   end
 | |
| 
 | |
|   def pagination_max_id
 | |
|     @requests.last.id
 | |
|   end
 | |
| 
 | |
|   def pagination_since_id
 | |
|     @requests.first.id
 | |
|   end
 | |
| end
 |