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.respond_to?(:params) ? request.params["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