mirror of https://github.com/tootsuite/mastodon
50 lines
1.1 KiB
Ruby
50 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Admin
|
|
class ChangeEmailsController < BaseController
|
|
before_action :set_account
|
|
before_action :require_local_account!
|
|
|
|
def show
|
|
authorize @user, :change_email?
|
|
end
|
|
|
|
def update
|
|
authorize @user, :change_email?
|
|
|
|
new_email = resource_params.fetch(:unconfirmed_email)
|
|
|
|
if new_email != @user.email
|
|
@user.update!(
|
|
unconfirmed_email: new_email,
|
|
# Regenerate the confirmation token:
|
|
confirmation_token: nil
|
|
)
|
|
|
|
log_action :change_email, @user
|
|
|
|
@user.send_confirmation_instructions
|
|
end
|
|
|
|
redirect_to admin_account_path(@account.id), notice: I18n.t('admin.accounts.change_email.changed_msg')
|
|
end
|
|
|
|
private
|
|
|
|
def set_account
|
|
@account = Account.find(params[:account_id])
|
|
@user = @account.user
|
|
end
|
|
|
|
def require_local_account!
|
|
redirect_to admin_account_path(@account.id) unless @account.local? && @account.user.present?
|
|
end
|
|
|
|
def resource_params
|
|
params.require(:user).permit(
|
|
:unconfirmed_email
|
|
)
|
|
end
|
|
end
|
|
end
|