mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-01-18 05:20:54 +08:00
53 lines
1.4 KiB
Ruby
53 lines
1.4 KiB
Ruby
class Users::PasswordsController < Devise::PasswordsController
|
|
# GET /resource/password/new
|
|
# def new
|
|
# super
|
|
# end
|
|
|
|
# POST /resource/password
|
|
# def create
|
|
# super
|
|
# end
|
|
|
|
# GET /resource/password/edit?reset_password_token=abcdef
|
|
# def edit
|
|
# super
|
|
# end
|
|
|
|
# PUT /resource/password
|
|
def update
|
|
self.resource = resource_class.reset_password_by_token(resource_params)
|
|
yield resource if block_given?
|
|
|
|
if resource.errors.blank?
|
|
resource.unlock_access! if unlockable?(resource)
|
|
if !two_factor_auth_enabled_for(resource)
|
|
flash_message = resource.active_for_authentication? ? :updated : :updated_not_active
|
|
set_flash_message!(:notice, flash_message)
|
|
resource.after_database_authentication
|
|
sign_in(resource_name, resource)
|
|
else
|
|
set_flash_message!(:notice, :updated_not_active)
|
|
end
|
|
respond_with resource, location: after_resetting_password_path_for(resource)
|
|
else
|
|
set_minimum_password_length
|
|
respond_with resource
|
|
end
|
|
end
|
|
|
|
protected
|
|
|
|
def after_resetting_password_path_for(resource)
|
|
two_factor_auth_enabled_for(resource) ? new_session_path(resource_name) : after_sign_in_path_for(resource)
|
|
end
|
|
|
|
def two_factor_auth_enabled_for(user)
|
|
user.two_factor_auth_enabled?
|
|
end
|
|
|
|
# The path used after sending reset password instructions
|
|
# def after_sending_reset_password_instructions_path_for(resource_name)
|
|
# super(resource_name)
|
|
# end
|
|
end
|