2017-05-31 12:36:24 -07:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-06-07 11:09:25 -07:00
|
|
|
class Api::V1::Accounts::CredentialsController < Api::BaseController
|
2017-08-20 15:41:08 -07:00
|
|
|
before_action -> { doorkeeper_authorize! :read }, except: [:update]
|
2017-05-31 12:36:24 -07:00
|
|
|
before_action -> { doorkeeper_authorize! :write }, only: [:update]
|
|
|
|
before_action :require_user!
|
|
|
|
|
|
|
|
def show
|
|
|
|
@account = current_account
|
2017-07-09 18:29:34 -07:00
|
|
|
render json: @account, serializer: REST::CredentialAccountSerializer
|
2017-05-31 12:36:24 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
@account = current_account
|
2017-08-26 03:40:03 -07:00
|
|
|
UpdateAccountService.new.call(@account, account_params, raise_error: true)
|
2018-04-08 04:43:10 -07:00
|
|
|
UserSettingsDecorator.new(current_user).update(user_settings_params) if user_settings_params
|
2017-08-12 15:44:41 -07:00
|
|
|
ActivityPub::UpdateDistributionWorker.perform_async(@account.id)
|
2017-07-09 18:29:34 -07:00
|
|
|
render json: @account, serializer: REST::CredentialAccountSerializer
|
2017-05-31 12:36:24 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def account_params
|
2018-02-18 13:57:53 -08:00
|
|
|
params.permit(:display_name, :note, :avatar, :header, :locked)
|
2017-05-31 12:36:24 -07:00
|
|
|
end
|
2018-04-08 04:43:10 -07:00
|
|
|
|
|
|
|
def user_settings_params
|
|
|
|
return nil unless params.key?(:source)
|
|
|
|
|
|
|
|
source_params = params.require(:source)
|
|
|
|
|
|
|
|
{
|
|
|
|
'setting_default_privacy' => source_params.fetch(:privacy, @account.user.setting_default_privacy),
|
|
|
|
'setting_default_sensitive' => source_params.fetch(:sensitive, @account.user.setting_default_sensitive),
|
|
|
|
}
|
|
|
|
end
|
2017-05-31 12:36:24 -07:00
|
|
|
end
|