Add Api::V1::Statuses::BaseController base controller class (#27794)
		
	This commit is contained in:
		
					parent
					
						
							
								da59407520
							
						
					
				
			
			
				commit
				
					
						0945e25b8f
					
				
			
		
					 11 changed files with 29 additions and 104 deletions
				
			
		
							
								
								
									
										16
									
								
								app/controllers/api/v1/statuses/base_controller.rb
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								app/controllers/api/v1/statuses/base_controller.rb
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,16 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::BaseController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
|   before_action :set_status | ||||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| end | ||||
|  | @ -1,11 +1,9 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::BookmarksController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::BookmarksController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { doorkeeper_authorize! :write, :'write:bookmarks' } | ||||
|   before_action :require_user! | ||||
|   before_action :set_status, only: [:create] | ||||
|   skip_before_action :set_status, only: [:destroy] | ||||
| 
 | ||||
|   def create | ||||
|     current_account.bookmarks.find_or_create_by!(account: current_account, status: @status) | ||||
|  | @ -28,13 +26,4 @@ class Api::V1::Statuses::BookmarksController < Api::BaseController | |||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| end | ||||
|  |  | |||
|  | @ -1,10 +1,7 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::FavouritedByAccountsController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::FavouritedByAccountsController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { authorize_if_got_token! :read, :'read:accounts' } | ||||
|   before_action :set_status | ||||
|   after_action :insert_pagination_headers | ||||
| 
 | ||||
|   def index | ||||
|  | @ -61,13 +58,6 @@ class Api::V1::Statuses::FavouritedByAccountsController < Api::BaseController | |||
|     @accounts.size == limit_param(DEFAULT_ACCOUNTS_LIMIT) | ||||
|   end | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| 
 | ||||
|   def pagination_params(core_params) | ||||
|     params.slice(:limit).permit(:limit).merge(core_params) | ||||
|   end | ||||
|  |  | |||
|  | @ -1,11 +1,9 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::FavouritesController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::FavouritesController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { doorkeeper_authorize! :write, :'write:favourites' } | ||||
|   before_action :require_user! | ||||
|   before_action :set_status, only: [:create] | ||||
|   skip_before_action :set_status, only: [:destroy] | ||||
| 
 | ||||
|   def create | ||||
|     FavouriteService.new.call(current_account, @status) | ||||
|  | @ -30,13 +28,4 @@ class Api::V1::Statuses::FavouritesController < Api::BaseController | |||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| end | ||||
|  |  | |||
|  | @ -1,10 +1,7 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::HistoriesController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::HistoriesController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { authorize_if_got_token! :read, :'read:statuses' } | ||||
|   before_action :set_status | ||||
| 
 | ||||
|   def show | ||||
|     cache_if_unauthenticated! | ||||
|  | @ -16,11 +13,4 @@ class Api::V1::Statuses::HistoriesController < Api::BaseController | |||
|   def status_edits | ||||
|     @status.edits.includes(:account, status: [:account]).to_a.presence || [@status.build_snapshot(at_time: @status.edited_at || @status.created_at)] | ||||
|   end | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| end | ||||
|  |  | |||
|  | @ -1,11 +1,8 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::MutesController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::MutesController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { doorkeeper_authorize! :write, :'write:mutes' } | ||||
|   before_action :require_user! | ||||
|   before_action :set_status | ||||
|   before_action :set_conversation | ||||
| 
 | ||||
|   def create | ||||
|  | @ -24,13 +21,6 @@ class Api::V1::Statuses::MutesController < Api::BaseController | |||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| 
 | ||||
|   def set_conversation | ||||
|     @conversation = @status.conversation | ||||
|     raise Mastodon::ValidationError if @conversation.nil? | ||||
|  |  | |||
|  | @ -1,11 +1,8 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::PinsController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::PinsController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { doorkeeper_authorize! :write, :'write:accounts' } | ||||
|   before_action :require_user! | ||||
|   before_action :set_status | ||||
| 
 | ||||
|   def create | ||||
|     StatusPin.create!(account: current_account, status: @status) | ||||
|  | @ -26,10 +23,6 @@ class Api::V1::Statuses::PinsController < Api::BaseController | |||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|   end | ||||
| 
 | ||||
|   def distribute_add_activity! | ||||
|     json = ActiveModelSerializers::SerializableResource.new( | ||||
|       @status, | ||||
|  |  | |||
|  | @ -1,10 +1,7 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::RebloggedByAccountsController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::RebloggedByAccountsController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { authorize_if_got_token! :read, :'read:accounts' } | ||||
|   before_action :set_status | ||||
|   after_action :insert_pagination_headers | ||||
| 
 | ||||
|   def index | ||||
|  | @ -57,13 +54,6 @@ class Api::V1::Statuses::RebloggedByAccountsController < Api::BaseController | |||
|     @accounts.size == limit_param(DEFAULT_ACCOUNTS_LIMIT) | ||||
|   end | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| 
 | ||||
|   def pagination_params(core_params) | ||||
|     params.slice(:limit).permit(:limit).merge(core_params) | ||||
|   end | ||||
|  |  | |||
|  | @ -1,13 +1,13 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::ReblogsController < Api::BaseController | ||||
|   include Authorization | ||||
| class Api::V1::Statuses::ReblogsController < Api::V1::Statuses::BaseController | ||||
|   include Redisable | ||||
|   include Lockable | ||||
| 
 | ||||
|   before_action -> { doorkeeper_authorize! :write, :'write:statuses' } | ||||
|   before_action :require_user! | ||||
|   before_action :set_reblog, only: [:create] | ||||
|   skip_before_action :set_status | ||||
| 
 | ||||
|   override_rate_limit_headers :create, family: :statuses | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,21 +1,9 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::SourcesController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::SourcesController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { doorkeeper_authorize! :read, :'read:statuses' } | ||||
|   before_action :set_status | ||||
| 
 | ||||
|   def show | ||||
|     render json: @status, serializer: REST::StatusSourceSerializer | ||||
|   end | ||||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| end | ||||
|  |  | |||
|  | @ -1,10 +1,7 @@ | |||
| # frozen_string_literal: true | ||||
| 
 | ||||
| class Api::V1::Statuses::TranslationsController < Api::BaseController | ||||
|   include Authorization | ||||
| 
 | ||||
| class Api::V1::Statuses::TranslationsController < Api::V1::Statuses::BaseController | ||||
|   before_action -> { doorkeeper_authorize! :read, :'read:statuses' } | ||||
|   before_action :set_status | ||||
|   before_action :set_translation | ||||
| 
 | ||||
|   rescue_from TranslationService::NotConfiguredError, with: :not_found | ||||
|  | @ -24,13 +21,6 @@ class Api::V1::Statuses::TranslationsController < Api::BaseController | |||
| 
 | ||||
|   private | ||||
| 
 | ||||
|   def set_status | ||||
|     @status = Status.find(params[:status_id]) | ||||
|     authorize @status, :show? | ||||
|   rescue Mastodon::NotPermittedError | ||||
|     not_found | ||||
|   end | ||||
| 
 | ||||
|   def set_translation | ||||
|     @translation = TranslateStatusService.new.call(@status, content_locale) | ||||
|   end | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue