class OmniAuth::Strategies::OAuth
Attributes
access_token[R]
Public Instance Methods
callback_phase()
click to toggle source
Calls superclass method
# File lib/omniauth/strategies/oauth.rb, line 44 def callback_phase # rubocop:disable MethodLength fail(OmniAuth::NoSessionError, "Session Expired") if session["oauth"].nil? 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"] else opts[:oauth_callback] = callback_url end @access_token = request_token.get_access_token(opts) super rescue ::Timeout::Error => e fail!(:timeout, e) rescue ::Net::HTTPFatalError, ::OpenSSL::SSL::SSLError => e fail!(:service_unavailable, e) rescue ::OAuth::Unauthorized => e fail!(:invalid_credentials, e) rescue ::OmniAuth::NoSessionError => e fail!(:session_expired, e) end
consumer()
click to toggle source
# File lib/omniauth/strategies/oauth.rb, line 20 def consumer consumer = ::OAuth::Consumer.new(options.consumer_key, options.consumer_secret, options.client_options) consumer.http.open_timeout = options.open_timeout if options.open_timeout consumer.http.read_timeout = options.read_timeout if options.read_timeout consumer end
request_phase()
click to toggle source
# File lib/omniauth/strategies/oauth.rb, line 27 def request_phase # rubocop:disable MethodLength request_token = consumer.get_request_token({:oauth_callback => callback_url}, options.request_params) session["oauth"] ||= {} session["oauth"][name.to_s] = {"callback_confirmed" => request_token.callback_confirmed?, "request_token" => request_token.token, "request_secret" => request_token.secret} if request_token.callback_confirmed? redirect request_token.authorize_url(options[:authorize_params]) else redirect request_token.authorize_url(options[:authorize_params].merge(:oauth_callback => callback_url)) end rescue ::Timeout::Error => e fail!(:timeout, e) rescue ::Net::HTTPFatalError, ::OpenSSL::SSL::SSLError => e fail!(:service_unavailable, e) end