lib/omniauth/strategies/oauth.rb in oa-oauth-0.2.0.beta4 vs lib/omniauth/strategies/oauth.rb in oa-oauth-0.2.0.beta5
- old
+ new
@@ -3,67 +3,69 @@
module OmniAuth
module Strategies
class OAuth
include OmniAuth::Strategy
-
+
def initialize(app, name, consumer_key = nil, consumer_secret = nil, consumer_options = {}, options = {}, &block)
self.consumer_key = consumer_key
self.consumer_secret = consumer_secret
self.consumer_options = consumer_options
super
end
-
+
def consumer
::OAuth::Consumer.new(consumer_key, consumer_secret, consumer_options.merge(options[:client_options] || options[:consumer_options] || {}))
end
attr_reader :name
attr_accessor :consumer_key, :consumer_secret, :consumer_options
-
+
def request_phase
request_token = consumer.get_request_token(:oauth_callback => callback_url)
(session['oauth']||={})[name.to_s] = {'callback_confirmed' => request_token.callback_confirmed?, 'request_token' => request_token.token, 'request_secret' => request_token.secret}
r = Rack::Response.new
-
+
if request_token.callback_confirmed?
r.redirect(request_token.authorize_url)
else
- r.redirect(request_token.authorize_url(:oauth_callback => callback_url))
+ r.redirect(request_token.authorize_url(:oauth_callback => callback_url))
end
-
+
r.finish
end
-
+
def callback_phase
request_token = ::OAuth::RequestToken.new(consumer, session['oauth'][name.to_s].delete('request_token'), session['oauth'][name.to_s].delete('request_secret'))
-
+
opts = {}
if session['oauth'][name.to_s]['callback_confirmed']
- opts[:oauth_verifier] = request['oauth_verifier']
+ opts[:oauth_verifier] = request['oauth_verifier']
else
- opts[:oauth_callback] = callback_url
+ opts[:oauth_callback] = callback_url
end
@access_token = request_token.get_access_token(opts)
super
+ rescue ::Net::HTTPFatalError => e
+ fail!(:service_unavailable, e)
rescue ::OAuth::Unauthorized => e
fail!(:invalid_credentials, e)
rescue ::MultiJson::DecodeError => e
fail!(:invalid_response, e)
end
-
+
def auth_hash
OmniAuth::Utils.deep_merge(super, {
'credentials' => {
- 'token' => @access_token.token,
+ 'token' => @access_token.token,
'secret' => @access_token.secret
}, 'extra' => {
'access_token' => @access_token
}
})
end
-
+
def unique_id
nil
end
end
end