* optimize direct timeline * fix typo in class name * change filter condition for direct timeline * fix codestyle issue * revoke index_accounts_not_silenced because direct timeline does not use it. * revoke index_accounts_not_silenced because direct timeline does not use it. * fix rspec test condition. * fix rspec test condition. * fix rspec test condition. * revoke adding column and partial index * (direct timeline) move merging logic to model * fix pagination parameter * add method arguments that switches return array of status or cache_ids * fix order by * returns ActiveRecord.Relation in default behavor * fix codestyle issue
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class Api::V1::Timelines::DirectController < Api::BaseController
 | |
|   before_action -> { doorkeeper_authorize! :read }, only: [:show]
 | |
|   before_action :require_user!, only: [:show]
 | |
|   after_action :insert_pagination_headers, unless: -> { @statuses.empty? }
 | |
| 
 | |
|   respond_to :json
 | |
| 
 | |
|   def show
 | |
|     @statuses = load_statuses
 | |
|     render json: @statuses, each_serializer: REST::StatusSerializer, relationships: StatusRelationshipsPresenter.new(@statuses, current_user&.account_id)
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def load_statuses
 | |
|     cached_direct_statuses
 | |
|   end
 | |
| 
 | |
|   def cached_direct_statuses
 | |
|     cache_collection direct_statuses, Status
 | |
|   end
 | |
| 
 | |
|   def direct_statuses
 | |
|     direct_timeline_statuses
 | |
|   end
 | |
| 
 | |
|   def direct_timeline_statuses
 | |
|     # this query requires built in pagination.
 | |
|     Status.as_direct_timeline(
 | |
|       current_account,
 | |
|       limit_param(DEFAULT_STATUSES_LIMIT),
 | |
|       params[:max_id],
 | |
|       params[:since_id],
 | |
|       true # returns array of cache_ids object
 | |
|     )
 | |
|   end
 | |
| 
 | |
|   def insert_pagination_headers
 | |
|     set_pagination_headers(next_path, prev_path)
 | |
|   end
 | |
| 
 | |
|   def pagination_params(core_params)
 | |
|     params.permit(:local, :limit).merge(core_params)
 | |
|   end
 | |
| 
 | |
|   def next_path
 | |
|     api_v1_timelines_direct_url pagination_params(max_id: pagination_max_id)
 | |
|   end
 | |
| 
 | |
|   def prev_path
 | |
|     api_v1_timelines_direct_url pagination_params(since_id: pagination_since_id)
 | |
|   end
 | |
| 
 | |
|   def pagination_max_id
 | |
|     @statuses.last.id
 | |
|   end
 | |
| 
 | |
|   def pagination_since_id
 | |
|     @statuses.first.id
 | |
|   end
 | |
| end
 |