2011-06-24 15:34:13 -04:00
|
|
|
class Devise::PasswordsController < DeviseController
|
2010-03-26 07:26:51 -04:00
|
|
|
prepend_before_filter :require_no_authentication
|
2012-06-08 04:08:35 -04:00
|
|
|
# Render the #edit only if coming from a reset password email link
|
|
|
|
append_before_filter :assert_reset_token_passed, :only => :edit
|
2009-10-27 19:26:40 -04:00
|
|
|
|
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
|
2012-05-15 04:07:02 -04:00
|
|
|
self.resource = resource_class.send_reset_password_instructions(resource_params)
|
2011-05-20 18:49:53 -04:00
|
|
|
|
2011-10-12 17:12:20 -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
|
2012-01-02 16:12:09 -05:00
|
|
|
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
|
2009-10-07 20:46:40 -04:00
|
|
|
def edit
|
2009-10-10 10:05:56 -04:00
|
|
|
self.resource = resource_class.new
|
2009-10-18 07:14:52 -04:00
|
|
|
resource.reset_password_token = params[:reset_password_token]
|
2009-10-07 20:46:40 -04:00
|
|
|
end
|
|
|
|
|
2009-10-17 11:10:15 -04:00
|
|
|
# PUT /resource/password
|
2009-10-07 20:46:40 -04:00
|
|
|
def update
|
2012-05-15 04:07:02 -04:00
|
|
|
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?
|
2012-11-07 04:45:46 -05:00
|
|
|
resource.unlock_access! if unlockable?(resource)
|
2011-08-31 18:24:10 -04:00
|
|
|
flash_message = resource.active_for_authentication? ? :updated : :updated_not_active
|
|
|
|
set_flash_message(:notice, flash_message) if is_navigational_format?
|
2011-01-15 14:33:54 -05:00
|
|
|
sign_in(resource_name, resource)
|
2011-09-29 07:07:13 -04:00
|
|
|
respond_with resource, :location => after_sign_in_path_for(resource)
|
2009-10-07 20:46:40 -04:00
|
|
|
else
|
2012-01-02 16:12:09 -05:00
|
|
|
respond_with resource
|
2009-10-07 20:46:40 -04:00
|
|
|
end
|
|
|
|
end
|
2011-05-20 18:49:53 -04:00
|
|
|
|
2011-05-13 12:39:11 -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
|
|
|
|
2012-06-08 04:08:35 -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
|
2012-11-07 04:45:46 -05:00
|
|
|
|
|
|
|
# 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
|
2009-10-07 20:46:40 -04:00
|
|
|
end
|