Sha256: a76382d1460c2afcc6f49daea9968a69d10e9f5ab8f22ed1704411fa0189612f

Contents?: true

Size: 1.56 KB

Versions: 1

Compression:

Stored size: 1.56 KB

Contents

require 'omniauth-oauth2'

module OmniAuth
  module Strategies
    class DoorkeeperSso < OmniAuth::Strategies::OAuth2
      option :name, :doorkeeper_sso
      option :client_options, {
        site: 'https://sso.example.com',
        authorize_path: '/oauth/authorize',
        sso_sessions_path: '/sso/sessions',
        user_info_path: nil
      }

      option :fields, [:email, :name, :first_name, :last_name]
      option :uid_field, :id

      uid do
        user_info[options.uid_field.to_s]
      end

      info do
        options.fields.inject({}) do |hash, field|
          hash[field] = user_info[field.to_s]
          hash
        end
      end

      extra do
        {
          :passport_id     => passport_info["id"],
          :passport_secret => passport_info["secret"]
        }
      end

      def user_info
        @user_info ||=  if options.client_options.user_info_path
                          access_token.get(options.client_options.user_info_path).parsed["response"]
                        else
                          passport_info["owner"]
                        end
      end

      def passport_info
        params = { ip: request.ip, agent: request.user_agent }
        @passport_info ||= access_token.post(options.client_options.sso_sessions_path, params: params).parsed
      end

      def call_app!
        create_passport
        session[:passport_id] = passport_info["id"]
        super
      end

    protected
      def create_passport
        ::DoorkeeperSsoClient::Passport.create_from_omniauth(env['omniauth.auth'])
      end

    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
doorkeeper_sso_client-0.4.0 lib/omniauth/strategies/doorkeeper_sso.rb