Fix multiple N+1s in ConversationsController (#25134)
This commit is contained in:
		
					parent
					
						
							
								675672feb6
							
						
					
				
			
			
				commit
				
					
						2b45fecde1
					
				
			
		
					 2 changed files with 43 additions and 12 deletions
				
			
		|  | @ -11,7 +11,7 @@ class Api::V1::ConversationsController < Api::BaseController | |||
| 
 | ||||
|   def index | ||||
|     @conversations = paginated_conversations | ||||
|     render json: @conversations, each_serializer: REST::ConversationSerializer | ||||
|     render json: @conversations, each_serializer: REST::ConversationSerializer, relationships: StatusRelationshipsPresenter.new(@conversations.map(&:last_status), current_user&.account_id) | ||||
|   end | ||||
| 
 | ||||
|   def read | ||||
|  | @ -32,7 +32,20 @@ class Api::V1::ConversationsController < Api::BaseController | |||
| 
 | ||||
|   def paginated_conversations | ||||
|     AccountConversation.where(account: current_account) | ||||
|                        .to_a_paginated_by_id(limit_param(LIMIT), params_slice(:max_id, :since_id, :min_id)) | ||||
|                        .includes( | ||||
|                          account: :account_stat, | ||||
|                          last_status: [ | ||||
|                            :media_attachments, | ||||
|                            :preview_cards, | ||||
|                            :status_stat, | ||||
|                            :tags, | ||||
|                            { | ||||
|                              active_mentions: [account: :account_stat], | ||||
|                              account: :account_stat, | ||||
|                            }, | ||||
|                          ] | ||||
|                        ) | ||||
|                        .to_a_paginated_by_id(limit_param(LIMIT), **params_slice(:max_id, :since_id, :min_id)) | ||||
|   end | ||||
| 
 | ||||
|   def insert_pagination_headers | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue