Refactor `Api::V1::ProfilesController` into two separate controllers (#26573)
parent
1cdcd9dc08
commit
191d302b7f
5 changed files with 31 additions and 44 deletions
@ -0,0 +1,13 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class Api::V1::Profile::AvatarsController < Api::BaseController |
||||
before_action -> { doorkeeper_authorize! :write, :'write:accounts' } |
||||
before_action :require_user! |
||||
|
||||
def destroy |
||||
@account = current_account |
||||
UpdateAccountService.new.call(@account, { avatar: nil }, raise_error: true) |
||||
ActivityPub::UpdateDistributionWorker.perform_async(@account.id) |
||||
render json: @account, serializer: REST::CredentialAccountSerializer |
||||
end |
||||
end |
@ -0,0 +1,13 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class Api::V1::Profile::HeadersController < Api::BaseController |
||||
before_action -> { doorkeeper_authorize! :write, :'write:accounts' } |
||||
before_action :require_user! |
||||
|
||||
def destroy |
||||
@account = current_account |
||||
UpdateAccountService.new.call(@account, { header: nil }, raise_error: true) |
||||
ActivityPub::UpdateDistributionWorker.perform_async(@account.id) |
||||
render json: @account, serializer: REST::CredentialAccountSerializer |
||||
end |
||||
end |
@ -1,29 +0,0 @@ |
||||
# frozen_string_literal: true |
||||
|
||||
class Api::V1::ProfilesController < Api::BaseController |
||||
before_action -> { doorkeeper_authorize! :write, :'write:accounts' } |
||||
before_action :require_user! |
||||
before_action :set_image |
||||
before_action :validate_image_param |
||||
|
||||
def destroy |
||||
@account = current_account |
||||
UpdateAccountService.new.call(@account, { @image => nil }, raise_error: true) |
||||
ActivityPub::UpdateDistributionWorker.perform_async(@account.id) |
||||
render json: @account, serializer: REST::CredentialAccountSerializer |
||||
end |
||||
|
||||
private |
||||
|
||||
def set_image |
||||
@image = params[:image] |
||||
end |
||||
|
||||
def validate_image_param |
||||
raise(Mastodon::InvalidParameterError, 'Image must be either "avatar" or "header"') unless valid_image? |
||||
end |
||||
|
||||
def valid_image? |
||||
%w(avatar header).include?(@image) |
||||
end |
||||
end |
Loading…
Reference in new issue