Module: Sorcery::Controller::Submodules::External::Providers::Xing::XingClient

Extended by:
Sorcery::Controller::Submodules::External::Protocols::Oauth1
Includes:
Base::BaseClient
Defined in:
lib/sorcery/controller/submodules/external/providers/xing.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/xing.rb', line 42

def access_token
  @access_token
end

.access_token_pathObject

Returns the value of attribute access_token_path.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def access_token_path
  @access_token_path
end

.authorize_pathObject

Returns the value of attribute authorize_path.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def authorize_path
  @authorize_path
end

.callback_urlObject

Returns the value of attribute callback_url.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def callback_url
  @callback_url
end

.keyObject

Returns the value of attribute key.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def key
  @key
end

.request_token_pathObject

Returns the value of attribute request_token_path.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def request_token_path
  @request_token_path
end

.secretObject

Returns the value of attribute secret.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def secret
  @secret
end

.siteObject

Returns the value of attribute site.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def site
  @site
end

.stateObject

Returns the value of attribute state.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def state
  @state
end

.user_info_mappingObject

Returns the value of attribute user_info_mapping.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

def 
  @user_info_mapping
end

.user_info_pathObject

Returns the value of attribute user_info_path.



32
33
34
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 32

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/xing.rb', line 47

def get_consumer
  ::OAuth::Consumer.new(@key, @secret, @configuration)
end

.get_user_hash(access_token) ⇒ Object



61
62
63
64
65
66
67
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 61

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

.has_callback?Boolean

Returns:

  • (Boolean)


69
70
71
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 69

def has_callback?
  true
end

.initObject



51
52
53
54
55
56
57
58
59
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 51

def init
  @configuration = {
      site: "https://api.xing.com/v1",
      authorize_path: '/authorize',
      request_token_path: '/request_token',
      access_token_path: '/access_token'
  }
  @user_info_path = "/users/me"
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.



75
76
77
78
79
80
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 75

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



83
84
85
86
87
88
# File 'lib/sorcery/controller/submodules/external/providers/xing.rb', line 83

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