lib/omniauth/strategies/xauth.rb in oa-oauth-0.2.4 vs lib/omniauth/strategies/xauth.rb in oa-oauth-0.2.5
- old
+ new
@@ -3,65 +3,65 @@
module OmniAuth
module Strategies
class XAuth
include OmniAuth::Strategy
-
+
attr_reader :name
attr_accessor :consumer_key, :consumer_secret, :consumer_options
-
+
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 request_phase
session['oauth'] ||= {}
if env['REQUEST_METHOD'] == 'GET'
get_credentials
else
session['omniauth.xauth'] = { 'x_auth_mode' => 'client_auth', 'x_auth_username' => request['username'], 'x_auth_password' => request['password'] }
redirect callback_path
end
end
-
+
def get_credentials
OmniAuth::Form.build(consumer_options[:title] || "xAuth Credentials") do
text_field 'Username', 'username'
password_field 'Password', 'password'
end.to_response
end
-
+
def consumer
::OAuth::Consumer.new(consumer_key, consumer_secret, consumer_options.merge(options[:client_options] || options[:consumer_options] || {}))
end
-
+
def callback_phase
@access_token = consumer.get_access_token(nil, {}, session['omniauth.xauth'])
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)
ensure
- session['omniauth.xauth'] = nil
+ session['omniauth.xauth'] = nil
end
-
+
def auth_hash
OmniAuth::Utils.deep_merge(super, {
'credentials' => {
'token' => @access_token.token,
'secret' => @access_token.secret
}, 'extra' => {
'access_token' => @access_token
}
})
end
-
+
end
end
end