heartcombo--devise/app/controllers/devise/passwords_controller.rb

51 lines
1.5 KiB
Ruby
Raw Normal View History

class Devise::PasswordsController < ApplicationController
prepend_before_filter :require_no_authentication
2010-01-13 17:12:13 +00:00
include Devise::Controllers::InternalHelpers
2010-02-08 18:07:24 +00:00
# GET /resource/password/new
def new
2010-07-13 17:46:44 +00:00
build_resource({})
2010-02-08 18:07:24 +00:00
render_with_scope :new
end
# POST /resource/password
def create
self.resource = resource_class.send_reset_password_instructions(params[resource_name])
2011-05-20 22:49:53 +00:00
if successfully_sent?(resource)
2011-06-23 12:22:30 +00:00
respond_with({}, :location => after_sending_reset_password_instructions_path_for(resource_name))
2011-06-16 19:10:53 +00:00
else
respond_with_navigational(resource){ render_with_scope :new }
2010-02-08 18:07:24 +00:00
end
end
2009-11-10 20:55:13 +00:00
# GET /resource/password/edit?reset_password_token=abcdef
def edit
self.resource = resource_class.new
resource.reset_password_token = params[:reset_password_token]
render_with_scope :edit
end
2009-10-17 15:10:15 +00:00
# PUT /resource/password
def update
self.resource = resource_class.reset_password_by_token(params[resource_name])
2009-10-17 15:10:15 +00:00
2009-10-10 12:32:51 +00:00
if resource.errors.empty?
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_navigational(resource){ render_with_scope :edit }
end
end
2011-05-20 22:49:53 +00: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 22:49:53 +00:00
end