Class: OAuth::Rack::OAuthFilter

Inherits:
Object
  • Object
show all
Defined in:
lib/oauth/rack/oauth_filter.rb

Overview

An OAuth 1.0a filter to be used together with the oauth-plugin for rails.T This is still experimental

Add it as middleware to your config/application.rb:

require ‘oauth/rack/oauth_filter’ config.middleware.use OAuth::Rack::OAuthFilter

Instance Method Summary collapse

Constructor Details

#initialize(app) ⇒ OAuthFilter

Returns a new instance of OAuthFilter.



18
19
20
# File 'lib/oauth/rack/oauth_filter.rb', line 18

def initialize(app)
  @app = app
end

Instance Method Details

#call(env) ⇒ Object



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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# File 'lib/oauth/rack/oauth_filter.rb', line 22

def call(env)
  request = ::Rack::Request.new(env)
  env["oauth_plugin"] = true
  strategies = []
  if token_string = oauth2_token(request)
    if token = Oauth2Token.where('invalidated_at IS NULL and authorized_at IS NOT NULL and token = ?', token_string).first
      env["oauth.token"]   = token
      env["oauth.version"] = 2
      strategies << :oauth20_token
      strategies << :token
    end

  elsif oauth1_verify(request) do |request_proxy|
    client_application = ClientApplication.find_by_key(request_proxy.consumer_key)
    env["oauth.client_application_candidate"] = client_application

    oauth_token = nil

    if client_application
      # Store this temporarily in client_application object for use in request token generation
      client_application.token_callback_url = request_proxy.oauth_callback if request_proxy.oauth_callback

      if request_proxy.token
        oauth_token = client_application.tokens.where('invalidated_at IS NULL AND authorized_at IS NOT NULL and token = ?', request_proxy.token).first
        if oauth_token.respond_to?(:provided_oauth_verifier=)
          oauth_token.provided_oauth_verifier = request_proxy.oauth_verifier
        end
        env["oauth.token_candidate"] = oauth_token
      end
    end

    # return the token secret and the consumer secret
    [(oauth_token.nil? ? nil : oauth_token.secret), (client_application.nil? ? nil : client_application.secret)]
  end
    if env["oauth.token_candidate"]
      env["oauth.token"] = env["oauth.token_candidate"]
      strategies << :oauth10_token
      if env["oauth.token"].is_a?(::RequestToken)
        strategies << :oauth10_request_token
      elsif env["oauth.token"].is_a?(::AccessToken)
        strategies << :token
        strategies << :oauth10_access_token
      end
    else
      strategies << :two_legged
    end
    env["oauth.client_application"] = env["oauth.client_application_candidate"]
    env["oauth.version"] = 1

  end
  env["oauth.strategies"] = strategies unless strategies.empty?
  env["oauth.client_application_candidate"] = nil
  env["oauth.token_candidate"] = nil
  @app.call(env)
end

#oauth1_verify(request, options = {}, &block) ⇒ Object



78
79
80
81
82
83
84
85
86
87
# File 'lib/oauth/rack/oauth_filter.rb', line 78

def oauth1_verify(request, options = {}, &block)
  begin
    signature = OAuth::Signature.build(request, options, &block)
    return false unless OauthNonce.remember(signature.request.nonce, signature.request.timestamp)
    value = signature.verify
    value
  rescue OAuth::Signature::UnknownSignatureMethod => e
    false
  end
end

#oauth2_token(request) ⇒ Object



89
90
91
92
93
94
# File 'lib/oauth/rack/oauth_filter.rb', line 89

def oauth2_token(request)
  request.params['bearer_token'] || request.params['access_token'] || (request.params["oauth_token"] && !request.params["oauth_signature"] ? request.params["oauth_token"] : nil )  ||
      request.env["HTTP_AUTHORIZATION"] &&
          !request.env["HTTP_AUTHORIZATION"][/(oauth_version="1.0")/] &&
          request.env["HTTP_AUTHORIZATION"][/^(Bearer|OAuth|Token) (token=)?([^\s]*)$/, 3]
end