Commit c10d067f authored by James Edwards-Jones's avatar James Edwards-Jones

Group SAML settings link to metadata URL

Also adds url_helper for use with paths from Rack middleware
parent c97bcc38
......@@ -38,5 +38,21 @@ module EE
def license_management_settings_path(project)
project_settings_ci_cd_path(project, anchor: 'js-license-management')
end
def self.url_helper(route_name)
define_method("#{route_name}_url") do |*args|
path = public_send(:"#{route_name}_path", *args) # rubocop:disable GitlabSecurity/PublicSend
options = Rails.application.routes.default_url_options.merge(path: path)
ActionDispatch::Http::URL.full_url_for(options)
end
end
url_helper :user_group_saml_omniauth_metadata
def user_group_saml_omniauth_metadata_path(group)
params = { group_path: group.path, token: group.saml_discovery_token }
path = '/users/auth/group_saml/metadata'
ActionDispatch::Http::URL.path_for(path: path, params: params)
end
end
end
......@@ -21,6 +21,11 @@
.well-segment.borderless
= render 'info_row', field: :issuer, label_text: 'Identifier'
.form-text.text-muted= _('Also called "Issuer" or "Relying party trust identifier"')
.well-segment.borderless
%label= _("GitLab metadata URL")
- metadata_url = user_group_saml_omniauth_metadata_url(@group)
%div= link_to metadata_url, metadata_url
.form-text.text-muted= _("Used to help configure your identity provider")
- if @saml_provider.persisted?
.well-segment.borderless
%label= _("GitLab single sign on URL")
......
......@@ -40,6 +40,17 @@ describe 'SAML provider settings' do
end
end
it 'provides metadata XML' do
visit group_saml_providers_path(group)
StrategyHelpers.without_test_mode do
click_link('metadata')
end
expect(page.body).to include(callback_path)
expect(response_headers['Content-Type']).to have_content("application/xml")
end
it 'allows creation of new provider' do
visit group_saml_providers_path(group)
......
......@@ -84,4 +84,32 @@ describe EE::GitlabRoutingHelper do
end
end
end
describe '#user_group_saml_omniauth_metadata_path' do
subject do
helper.user_group_saml_omniauth_metadata_path(group)
end
before do
group.update!(saml_discovery_token: 'sometoken')
end
it 'uses metadata path' do
expect(subject).to start_with('/users/auth/group_saml/metadata')
end
it 'appends group path and token' do
expect(subject).to end_with('?group_path=foo&token=sometoken')
end
end
describe '#user_group_saml_omniauth_metadata_url' do
subject do
helper.user_group_saml_omniauth_metadata_url(group)
end
it 'creates full metadata URL' do
expect(subject).to start_with 'http://localhost/users/auth/group_saml/metadata?group_path=foo&token='
end
end
end
......@@ -13,23 +13,27 @@ module StrategyHelpers
def auth_hash
last_request.env['omniauth.auth']
end
def self.without_test_mode
original_mode = OmniAuth.config.test_mode
original_on_failure = OmniAuth.config.on_failure
OmniAuth.config.test_mode = false
OmniAuth.config.on_failure = OmniAuth::FailureEndpoint
yield
ensure
OmniAuth.config.test_mode = original_mode
OmniAuth.config.on_failure = original_on_failure
end
end
RSpec.configure do |config|
config.include StrategyHelpers, type: :strategy
config.around(:all, type: :strategy) do |example|
begin
original_mode = OmniAuth.config.test_mode
original_on_failure = OmniAuth.config.on_failure
OmniAuth.config.test_mode = false
OmniAuth.config.on_failure = OmniAuth::FailureEndpoint
StrategyHelpers.without_test_mode do
example.run
ensure
OmniAuth.config.test_mode = original_mode
OmniAuth.config.on_failure = original_on_failure
end
end
end
......@@ -4108,6 +4108,9 @@ msgstr ""
msgid "GitLab User"
msgstr ""
msgid "GitLab metadata URL"
msgstr ""
msgid "GitLab project export"
msgstr ""
......@@ -9115,6 +9118,9 @@ msgstr ""
msgid "Used by members to sign in to your group in GitLab"
msgstr ""
msgid "Used to help configure your identity provider"
msgstr ""
msgid "User Cohorts are only shown when the %{usage_ping_link_start}usage ping%{usage_ping_link_end} is enabled."
msgstr ""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment