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