1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-20 09:52:19 +01:00
fab-manager/lib/omni_auth/strategies/sso_oauth2_provider.rb

79 lines
2.3 KiB
Ruby
Raw Normal View History

2019-01-31 17:15:26 +01:00
# frozen_string_literal: true
2016-03-23 18:39:41 +01:00
require 'omniauth-oauth2'
require 'jsonpath'
require 'sso_logger'
require_relative '../data_mapping/mapper'
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
# Authentication strategy provided trough oAuth 2.0
class OmniAuth::Strategies::SsoOauth2Provider < OmniAuth::Strategies::OAuth2
include OmniAuth::DataMapping::Mapper
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
def self.active_provider
active_provider = Rails.configuration.auth_provider
if active_provider.providable_type != 'OAuth2Provider'
raise "Trying to instantiate the wrong provider: Expected OAuth2Provider, received #{active_provider.providable_type}"
2019-01-31 17:15:26 +01:00
end
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
active_provider
end
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
# Strategy name.
option :name, active_provider.strategy_name
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
option :client_options,
site: active_provider.providable.base_url,
authorize_url: active_provider.providable.authorization_endpoint,
token_url: active_provider.providable.token_endpoint
2021-11-02 11:24:10 +01:00
2023-03-29 18:01:16 +02:00
def authorize_params
super.tap do |params|
params[:scope] = OmniAuth::Strategies::SsoOauth2Provider.active_provider.providable.scopes
end
2023-03-29 18:01:16 +02:00
end
def callback_url
url = Rails.application.config.action_controller.default_url_options
"#{url[:protocol]}://#{url[:host]}#{script_name}#{callback_path}"
end
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
uid { parsed_info[:'user.uid'] }
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
info do
{
mapping: parsed_info
}
end
2019-01-31 17:15:26 +01:00
2023-03-29 18:01:16 +02:00
extra do
{
raw_info: raw_info
}
end
2019-01-31 17:15:26 +01:00
2023-03-29 18:01:16 +02:00
# retrieve data from various url, querying each only once
def raw_info
logger = SsoLogger.new
2023-03-29 18:01:16 +02:00
@raw_info ||= {}
logger.debug "[raw_info] @raw_infos = #{@raw_info&.to_json}"
unless @raw_info.size.positive?
OmniAuth::Strategies::SsoOauth2Provider.active_provider.auth_provider_mappings.each do |mapping|
logger.debug "mapping = #{mapping&.to_json}"
next if @raw_info.key?(mapping.api_endpoint.to_sym)
2023-03-29 18:01:16 +02:00
logger.debug "api_endpoint = #{mapping.api_endpoint.to_sym}"
logger.debug "access_token = #{access_token&.to_json}"
logger.debug "token get = #{access_token.get(mapping.api_endpoint)}"
logger.debug "parsed = #{access_token.get(mapping.api_endpoint).parsed}"
@raw_info[mapping.api_endpoint.to_sym] = access_token.get(mapping.api_endpoint).parsed
2016-03-23 18:39:41 +01:00
end
2019-01-31 17:15:26 +01:00
end
2023-03-29 18:01:16 +02:00
@raw_info
end
2016-03-23 18:39:41 +01:00
2023-03-29 18:01:16 +02:00
def parsed_info
mapped_info(OmniAuth::Strategies::SsoOauth2Provider.active_provider.auth_provider_mappings, raw_info)
2016-03-23 18:39:41 +01:00
end
2019-01-31 17:15:26 +01:00
end