class OmniAuth::Strategies::Forcedotcom
Public Class Methods
new(app, consumer_key = nil, consumer_secret = nil, options = {}, &block)
click to toggle source
Calls superclass method
# File lib/Salesforce/oauth2/forcedotcom.rb, line 9 def initialize(app, consumer_key = nil, consumer_secret = nil, options = {}, &block) client_options = { :site => 'https://login.salesforce.com', :authorize_path => '/services/oauth2/authorize', :access_token_path => '/services/oauth2/token' } # 'code' locks you into one org; 'token' works across all orgs. options.merge!(:response_type => 'token', :grant_type => 'authorization_code') super(app, :forcedotcom, consumer_key, consumer_secret, client_options, options, &block) end
Public Instance Methods
auth_hash()
click to toggle source
Calls superclass method
# File lib/Salesforce/oauth2/forcedotcom.rb, line 22 def auth_hash data = user_data OmniAuth::Utils.deep_merge(super, { 'uid' => @access_token['id'], 'credentials' => { 'instance_url' => @access_token['instance_url'], 'credentials' => {"refresh_token" => @access_token.refresh_token, "consumer_key" => @access_token.client.id, "consumer_secret" => @access_token.client.secret } }, 'extra' => {'user_hash' => data}, 'user_info' => { 'email' => data['email'], 'name' => data['display_name'] } }) end
user_data()
click to toggle source
# File lib/Salesforce/oauth2/forcedotcom.rb, line 61 def user_data @data ||= MultiJson.decode(@access_token.get(@access_token['id'])) rescue ::OAuth2::HTTPError => e if e.response.status == 302 @data ||= MultiJson.decode(@access_token.get(e.response.headers['location'])) else raise e end end