mirror of
https://github.com/heartcombo/devise.git
synced 2022-11-09 12:18:31 -05:00
45 lines
No EOL
1.5 KiB
Ruby
45 lines
No EOL
1.5 KiB
Ruby
class Devise::SessionsController < ApplicationController
|
|
prepend_before_filter :require_no_authentication, :only => [ :new, :create ]
|
|
include Devise::Controllers::InternalHelpers
|
|
|
|
# GET /resource/sign_in
|
|
def new
|
|
resource = build_resource
|
|
clean_up_passwords(resource)
|
|
respond_with_navigational(resource, stub_options(resource)){ render_with_scope :new }
|
|
end
|
|
|
|
# POST /resource/sign_in
|
|
def create
|
|
resource = warden.authenticate!(:scope => resource_name, :recall => "#{controller_path}#new")
|
|
set_flash_message(:notice, :signed_in) if is_navigational_format?
|
|
sign_in(resource_name, resource)
|
|
respond_with resource, :location => redirect_location(resource_name, resource)
|
|
end
|
|
|
|
# GET /resource/sign_out
|
|
def destroy
|
|
signed_in = signed_in?(resource_name)
|
|
Devise.sign_out_all_scopes ? sign_out : sign_out(resource_name)
|
|
set_flash_message :notice, :signed_out if signed_in
|
|
|
|
# We actually need to hardcode this, as Rails default responder doesn't
|
|
# support returning empty response on GET request
|
|
respond_to do |format|
|
|
format.any(*navigational_formats) { redirect_to after_sign_out_path_for(resource_name) }
|
|
format.all do
|
|
method = "to_#{request_format}"
|
|
text = {}.respond_to?(method) ? {}.send(method) : ""
|
|
render :text => text, :status => :ok
|
|
end
|
|
end
|
|
end
|
|
|
|
protected
|
|
|
|
def stub_options(resource)
|
|
array = resource_class.authentication_keys.dup
|
|
array << :password if resource.respond_to?(:password)
|
|
{ :methods => array, :only => [:password] }
|
|
end
|
|
end |