Commit b59f528b authored by Catalin Irimie's avatar Catalin Irimie

Allow SSO callbacks through maintenance mode

When using other authentication methods, like SSO, LDAP,
the path and controllers are slightly different, as they
redirect back to a callback handled by Omniauth.

This adds the specific routes and controller to the allowlist
in the read-only middleware to allow them to go through.

Changelog: fixed
EE: true
parent e1d2685e
...@@ -33,6 +33,11 @@ module EE ...@@ -33,6 +33,11 @@ module EE
'oauth/tokens' => %w{create} 'oauth/tokens' => %w{create}
}.freeze }.freeze
ALLOWLISTED_SSO_SIGN_IN_CONTROLLERS = [
'omniauth_callbacks',
'ldap/omniauth_callbacks'
].freeze
private private
override :allowlisted_routes override :allowlisted_routes
...@@ -115,10 +120,14 @@ module EE ...@@ -115,10 +120,14 @@ module EE
end end
def sign_in_route? def sign_in_route?
return unless request.post? && request.path.start_with?('/users/sign_in', '/oauth/token', return unless request.post?
'/users/auth/geo/sign_in')
is_regular_sign_in_route = request.path.start_with?('/users/sign_in', '/oauth/token', '/users/auth/geo/sign_in') &&
ALLOWLISTED_SIGN_IN_ROUTES[route_hash[:controller]]&.include?(route_hash[:action]) ALLOWLISTED_SIGN_IN_ROUTES[route_hash[:controller]]&.include?(route_hash[:action])
is_sso_callback_route = request.path.start_with?('/users/auth/') &&
ALLOWLISTED_SSO_SIGN_IN_CONTROLLERS.include?(route_hash[:controller])
is_regular_sign_in_route || is_sso_callback_route
end end
def lfs_locks_route? def lfs_locks_route?
......
...@@ -30,10 +30,29 @@ RSpec.shared_examples 'write access for a read-only GitLab (EE) instance in main ...@@ -30,10 +30,29 @@ RSpec.shared_examples 'write access for a read-only GitLab (EE) instance in main
end end
shared_examples_for 'sign in/out and OAuth are allowed' do shared_examples_for 'sign in/out and OAuth are allowed' do
include LdapHelpers
include LoginHelpers
before do
stub_ldap_setting({ enabled: true })
Rails.application.reload_routes!
# SAML draws a custom route, LDAP doesn't, so the reload needs to happen before this
# to prevent overwriting the SAML route.
stub_omniauth_saml_config(enabled: true, auto_link_saml_user: true, allow_single_sign_on: ['saml'])
end
after(:all) do
Rails.application.reload_routes!
end
where(:description, :path) do where(:description, :path) do
'sign in route' | '/users/sign_in' 'sign in route' | '/users/sign_in'
'sign out route' | '/users/sign_out' 'sign out route' | '/users/sign_out'
'oauth token route' | '/oauth/token' 'oauth token route' | '/oauth/token'
'SSO callback route' | '/users/auth/gitlab/callback'
'LDAP callback route' | '/users/auth/ldapmain/callback'
'SAML regular route' | '/users/auth/saml'
end end
with_them do with_them do
......
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