Files
gitlab-foss/lib/gitlab/auth/saml/config.rb
2023-11-28 18:11:25 +00:00

73 lines
2.2 KiB
Ruby

# frozen_string_literal: true
module Gitlab
module Auth
module Saml
class Config
DEFAULT_NICKNAME_ATTRS = %w[username nickname].freeze
DEFAULT_NAME_ATTRS = %w[
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/name
http://schemas.microsoft.com/ws/2008/06/identity/claims/name
].freeze
DEFAULT_EMAIL_ATTRS = %w[
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress
http://schemas.microsoft.com/ws/2008/06/identity/claims/emailaddress
].freeze
DEFAULT_FIRST_NAME_ATTRS = %w[
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/givenname
http://schemas.microsoft.com/ws/2008/06/identity/claims/givenname
].freeze
DEFAULT_LAST_NAME_ATTRS = %w[
http://schemas.xmlsoap.org/ws/2005/05/identity/claims/surname
http://schemas.microsoft.com/ws/2008/06/identity/claims/surname
].freeze
class << self
def enabled?
::AuthHelper.saml_providers.any?
end
def default_attribute_statements
defaults = OmniAuth::Strategies::SAML.default_options[:attribute_statements].to_hash.deep_symbolize_keys
defaults[:nickname] = DEFAULT_NICKNAME_ATTRS.dup
defaults[:name].concat(DEFAULT_NAME_ATTRS)
defaults[:email].concat(DEFAULT_EMAIL_ATTRS)
defaults[:first_name].concat(DEFAULT_FIRST_NAME_ATTRS)
defaults[:last_name].concat(DEFAULT_LAST_NAME_ATTRS)
defaults
end
end
DEFAULT_PROVIDER_NAME = 'saml'
def initialize(provider = DEFAULT_PROVIDER_NAME)
@provider = provider
end
def options
Gitlab::Auth::OAuth::Provider.config_for(@provider)
end
def upstream_two_factor_authn_contexts
options.args[:upstream_two_factor_authn_contexts]
end
def groups
options[:groups_attribute]
end
def external_groups
options[:external_groups]
end
def admin_groups
options[:admin_groups]
end
end
end
end
end
Gitlab::Auth::Saml::Config.prepend_mod_with('Gitlab::Auth::Saml::Config')