mirror of
				https://github.com/mastodon/mastodon.git
				synced 2025-10-26 02:31:26 +00:00 
			
		
		
		
	 d9fbb071da
			
		
	
	
		d9fbb071da
		
			
		
	
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Check i18n / check-i18n (push) Waiting to run
				
			CodeQL / Analyze (javascript) (push) Waiting to run
				
			CodeQL / Analyze (ruby) (push) Waiting to run
				
			Check formatting / lint (push) Waiting to run
				
			CSS Linting / lint (push) Waiting to run
				
			Ruby Testing / build (production) (push) Waiting to run
				
			Ruby Testing / build (test) (push) Waiting to run
				
			Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
				
			Ruby Testing / test (3.1) (push) Blocked by required conditions
				
			Ruby Testing / test (3.2) (push) Blocked by required conditions
				
			Ruby Testing / Libvips tests (.ruby-version) (push) Blocked by required conditions
				
			Ruby Testing / Libvips tests (3.1) (push) Blocked by required conditions
				
			Ruby Testing / Libvips tests (3.2) (push) Blocked by required conditions
				
			Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
				
			Ruby Testing / End to End testing (3.1) (push) Blocked by required conditions
				
			Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (3.1, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
				
			JavaScript Linting / lint (push) Has been cancelled
				
			Ruby Linting / lint (push) Has been cancelled
				
			JavaScript Testing / test (push) Has been cancelled
				
			Historical data migration test / test (14-alpine) (push) Has been cancelled
				
			Historical data migration test / test (15-alpine) (push) Has been cancelled
				
			
		
			
				
	
	
		
			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
 |