class GraphqlDevise::Mutations::UpdatePassword

Public Instance Methods

resolve(current_password: nil, **attrs) { |current_resource| ... } click to toggle source
# File lib/graphql_devise/mutations/update_password.rb, line 10
def resolve(current_password: nil, **attrs)
  if current_resource.blank?
    raise_user_error(I18n.t('graphql_devise.not_authenticated'))
  elsif current_resource.provider != 'email'
    raise_user_error(
      I18n.t('graphql_devise.passwords.password_not_required', provider: current_resource.provider.humanize)
    )
  end

  if update_resource_password(current_password, attrs)
    current_resource.allow_password_change = false if recoverable_enabled?
    current_resource.save!

    yield current_resource if block_given?

    { authenticatable: current_resource }
  else
    raise_user_error_list(
      I18n.t('graphql_devise.passwords.update_password_error'),
      errors: current_resource.errors.full_messages
    )
  end
end

Private Instance Methods

update_resource_password(current_password, attrs) click to toggle source
# File lib/graphql_devise/mutations/update_password.rb, line 36
def update_resource_password(current_password, attrs)
  allow_password_change = recoverable_enabled? && current_resource.allow_password_change == true
  if DeviseTokenAuth.check_current_password_before_update == false || allow_password_change
    current_resource.public_send(:update, attrs)
  else
    current_resource.public_send(:update_with_password, attrs.merge(current_password: current_password))
  end
end