1
0
Fork 0
mirror of https://github.com/heartcombo/devise.git synced 2022-11-09 12:18:31 -05:00
heartcombo--devise/app/controllers/devise/passwords_controller.rb

66 lines
2.1 KiB
Ruby
Raw Normal View History

class Devise::PasswordsController < DeviseController
prepend_before_filter :require_no_authentication
# Render the #edit only if coming from a reset password email link
append_before_filter :assert_reset_token_passed, :only => :edit
2010-02-08 13:07:24 -05:00
# GET /resource/password/new
def new
2010-07-13 13:46:44 -04:00
build_resource({})
2010-02-08 13:07:24 -05:00
end
# POST /resource/password
def create
self.resource = resource_class.send_reset_password_instructions(resource_params)
2011-05-20 18:49:53 -04:00
if successfully_sent?(resource)
2011-06-23 08:22:30 -04:00
respond_with({}, :location => after_sending_reset_password_instructions_path_for(resource_name))
2011-06-16 15:10:53 -04:00
else
respond_with(resource)
2010-02-08 13:07:24 -05:00
end
end
2009-11-10 15:55:13 -05:00
# GET /resource/password/edit?reset_password_token=abcdef
def edit
self.resource = resource_class.new
resource.reset_password_token = params[:reset_password_token]
end
2009-10-17 11:10:15 -04:00
# PUT /resource/password
def update
self.resource = resource_class.reset_password_by_token(resource_params)
2009-10-17 11:10:15 -04:00
2009-10-10 08:32:51 -04:00
if resource.errors.empty?
resource.unlock_access! if unlockable?(resource)
flash_message = resource.active_for_authentication? ? :updated : :updated_not_active
set_flash_message(:notice, flash_message) if is_navigational_format?
sign_in(resource_name, resource)
respond_with resource, :location => after_sign_in_path_for(resource)
else
respond_with resource
end
end
2011-05-20 18:49:53 -04:00
protected
# The path used after sending reset password instructions
def after_sending_reset_password_instructions_path_for(resource_name)
new_session_path(resource_name)
end
2011-05-20 18:49:53 -04:00
# Check if a reset_password_token is provided in the request
def assert_reset_token_passed
if params[:reset_password_token].blank?
set_flash_message(:error, :no_token)
redirect_to new_session_path(resource_name)
end
end
# Check if proper Lockable module methods are present & unlock strategy
# allows to unlock resource on password reset
def unlockable?(resource)
resource.respond_to?(:unlock_access!) &&
resource.respond_to?(:unlock_strategy_enabled?) &&
resource.unlock_strategy_enabled?(:email)
end
end