Module: Padrino::Warden::Controller

Defined in:
lib/padrino/warden/controller.rb

Class Method Summary collapse

Class Method Details

.registered(app) ⇒ Object



4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/padrino/warden/controller.rb', line 4

def self.registered(app)
  app.controller :sessions do
    %w(get put post delete head options patch link unlink).each do |method|
      __send__ method, :unauthenticated, map: app.auth_unauthenticated_path do
        status 401
        warden.custom_failure! if warden.config.failure_app == self.class
        flash.now[:error] = settings.auth_error_message if flash
        render settings. , layout: settings.
      end
    end
    ## /sessions/login
    get :login , map: app.  do
      if settings.auth_use_oauth && !@auth_oauth_request_token.nil?
        session[:request_token] = @auth_oauth_request_token.token
        session[:request_token_secret] = @auth_oauth_request_token.secret
        redirect @auth_oauth_request_token.authorize_url
      else
        render settings. , layout: settings.
      end
    end

    post :login , map: app. do
      authenticate
      flash[:success] = settings.auth_success_message if flash
      redirect settings.auth_use_referrer && session[:return_to] ? session.delete(:return_to) : 
        settings.auth_success_path
    end

    get :logout ,map: app.auth_logout_path do
      logout
      flash[:success] = settings.deauth_success_message if flash
      redirect settings.auth_success_path
    end

    get :oauth_callback do
      if settings.auth_use_oauth
        authenticate
        flash[:success] = settings.auth_success_message if flash
        redirect settings.auth_success_path
      else
        redirect settings.auth_failure_path
      end
    end
  end
end