Module: Sorcery::Controller::Submodules::External::Providers::Twitter::TwitterClient

Extended by:
Sorcery::Controller::Submodules::External::Protocols::Oauth1
Includes:
Base::BaseClient
Defined in:
lib/sorcery/controller/submodules/external/providers/twitter.rb

Class Attribute Summary collapse

Class Method Summary collapse

Methods included from Sorcery::Controller::Submodules::External::Protocols::Oauth1

authorize_url, get_access_token, get_request_token, oauth_version

Methods included from Base::BaseClient

included

Class Attribute Details

.access_tokenObject (readonly)

Returns the value of attribute access_token.



42
43
44
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 42

def access_token
  @access_token
end

.callback_urlObject

Returns the value of attribute callback_url.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def callback_url
  @callback_url
end

.keyObject

Returns the value of attribute key.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def key
  @key
end

.secretObject

Returns the value of attribute secret.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def secret
  @secret
end

.siteObject

Returns the value of attribute site.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def site
  @site
end

.stateObject

Returns the value of attribute state.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def state
  @state
end

.user_info_mappingObject

Returns the value of attribute user_info_mapping.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def 
  @user_info_mapping
end

.user_info_pathObject

Returns the value of attribute user_info_path.



35
36
37
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 35

def 
  @user_info_path
end

Class Method Details

.get_consumerObject

Override included get_consumer method to provide authorize_path



47
48
49
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 47

def get_consumer
  ::OAuth::Consumer.new(@key, @secret, :site => @site, :authorize_path => "/oauth/authenticate")
end

.get_user_hash(access_token) ⇒ Object



57
58
59
60
61
62
63
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 57

def get_user_hash(access_token)
  user_hash = {}
  response = access_token.get(@user_info_path)
  user_hash[:user_info] = JSON.parse(response.body)
  user_hash[:uid] = user_hash[:user_info]['id'].to_s
  user_hash
end

.has_callback?Boolean

Returns:

  • (Boolean)


65
66
67
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 65

def has_callback?
  true
end

.initObject



51
52
53
54
55
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 51

def init
  @site           = "https://api.twitter.com"
  @user_info_path = "/1.1/account/verify_credentials.json"
  @user_info_mapping = {}
end

.login_url(params, session) ⇒ Object

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



71
72
73
74
75
76
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 71

def (params, session)
  req_token = self.get_request_token
  session[:request_token]         = req_token.token
  session[:request_token_secret]  = req_token.secret
  self.authorize_url({:request_token => req_token.token, :request_token_secret => req_token.secret})
end

.process_callback(params, session) ⇒ Object

tries to login the user from access token



79
80
81
82
83
84
# File 'lib/sorcery/controller/submodules/external/providers/twitter.rb', line 79

def process_callback(params, session)
  args = {}
  args.merge!({:oauth_verifier => params[:oauth_verifier], :request_token => session[:request_token], :request_token_secret => session[:request_token_secret]})
  args.merge!({:code => params[:code]}) if params[:code]
  return self.get_access_token(args)
end