Sha256: bb863c2d7022b539dd7078c48f2a462d679ff41f9242523cdf7e8654c8c21fd8
Contents?: true
Size: 1.47 KB
Versions: 2
Compression:
Stored size: 1.47 KB
Contents
#require 'omniauth/oauth' #require 'multi_json' require 'omniauth/strategies/oauth2' module OmniAuth module Strategies class Forcedotcom < OmniAuth::Strategies::OAuth2 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 def auth_hash data = user_data OmniAuth::Utils.deep_merge(super, { 'uid' => @access_token['id'], 'credentials' => { 'instance_url' => @access_token['instance_url'] }, 'extra' => {'user_hash' => data}, 'user_info' => { 'email' => data['email'], 'name' => data['display_name'] } }) end 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 end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
asf-rest-adapter-0.4.5 | lib/Salesforce/oauth2/forcedotcom.rb |
asf-rest-adapter-0.4.4 | lib/Salesforce/oauth2/forcedotcom.rb |