Class: OmniAuth::Strategies::Salesforce
- Defined in:
- lib/omniauth/strategies/oauth2/salesforce.rb
Instance Attribute Summary
Attributes inherited from OAuth2
#client_id, #client_options, #client_secret, #options
Instance Method Summary collapse
- #auth_hash ⇒ Object
-
#initialize(app, client_id = nil, client_secret = nil, options = {}, &block) ⇒ Salesforce
constructor
A new instance of Salesforce.
- #user_data ⇒ Object
Methods inherited from OAuth2
Constructor Details
#initialize(app, client_id = nil, client_secret = nil, options = {}, &block) ⇒ Salesforce
Returns a new instance of Salesforce.
6 7 8 9 10 11 12 13 |
# File 'lib/omniauth/strategies/oauth2/salesforce.rb', line 6 def initialize(app, client_id=nil, client_secret=nil, ={}, &block) = { :authorize_url => 'https://login.salesforce.com/services/oauth2/authorize', :token_url => 'https://login.salesforce.com/services/oauth2/token', } .merge!(:response_type => 'code', :grant_type => 'authorization_code') super(app, :salesforce, client_id, client_secret, , , &block) end |
Instance Method Details
#auth_hash ⇒ Object
15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/omniauth/strategies/oauth2/salesforce.rb', line 15 def auth_hash data = user_data OmniAuth::Utils.deep_merge( super, { 'uid' => @access_token['id'], 'credentials' => { 'issued_at' => @access_token['issued_at'], 'refresh_token' => @access_token.refresh_token, 'instance_url' => @access_token['instance_url'], 'signature' => @access_token['signature'], }, 'extra' => { 'user_hash' => data, }, 'user_info' => { 'email' => data['email'], 'name' => data['display_name'], }, } ) end |
#user_data ⇒ Object
37 38 39 40 41 42 43 44 45 |
# File 'lib/omniauth/strategies/oauth2/salesforce.rb', line 37 def user_data @data ||= MultiJson.decode(@access_token.get(@access_token['id'])) rescue ::OAuth2::Error => e if e.response.status == 302 @data ||= MultiJson.decode(@access_token.get(e.response.headers['location'])) else raise e end end |