class Sorcery::Providers::Twitter

This class adds support for OAuth with Twitter.com.

config.twitter.key = <key>
config.twitter.secret = <secret>
...

Attributes

state[RW]
user_info_path[RW]

Public Class Methods

new() click to toggle source
Calls superclass method Sorcery::Providers::Base::new
# File lib/sorcery/providers/twitter.rb, line 14
def initialize
  super

  @site           = 'https://api.twitter.com'
  @user_info_path = '/1.1/account/verify_credentials.json'
end

Public Instance Methods

get_consumer() click to toggle source

Override included get_consumer method to provide authorize_path

# File lib/sorcery/providers/twitter.rb, line 22
def get_consumer
  ::OAuth::Consumer.new(@key, secret, site: site, authorize_path: '/oauth/authenticate')
end
get_user_hash(access_token) click to toggle source
# File lib/sorcery/providers/twitter.rb, line 26
def get_user_hash(access_token)
  response = access_token.get(user_info_path)

  auth_hash(access_token).tap do |h|
    h[:user_info] = JSON.parse(response.body)
    h[:uid] = h[:user_info]['id'].to_s
  end
end
login_url(_params, session) click to toggle source

calculates and returns the url to which the user should be redirected, to get authenticated at the external provider's site.

# File lib/sorcery/providers/twitter.rb, line 37
def login_url(_params, session)
  req_token = get_request_token
  session[:request_token]         = req_token.token
  session[:request_token_secret]  = req_token.secret
  authorize_url(request_token: req_token.token, request_token_secret: req_token.secret)
end
process_callback(params, session) click to toggle source

tries to login the user from access token

# File lib/sorcery/providers/twitter.rb, line 45
def process_callback(params, session)
  args = {
    oauth_verifier:       params[:oauth_verifier],
    request_token:        session[:request_token],
    request_token_secret: session[:request_token_secret]
  }

  args[:code] = params[:code] if params[:code]
  get_access_token(args)
end