Commit 754bb9ac authored by Gabriel Mazetto's avatar Gabriel Mazetto

Fix logout on Gitlab Geo node

parent 6f546738
...@@ -93,7 +93,11 @@ class ApplicationController < ActionController::Base ...@@ -93,7 +93,11 @@ class ApplicationController < ActionController::Base
end end
def after_sign_out_path_for(resource) def after_sign_out_path_for(resource)
current_application_settings.after_sign_out_path || new_user_session_path if Gitlab::Geo.readonly?
Gitlab::Geo.primary_node.url
else
current_application_settings.after_sign_out_path || new_user_session_path
end
end end
def abilities def abilities
......
...@@ -4,7 +4,7 @@ class SessionsController < Devise::SessionsController ...@@ -4,7 +4,7 @@ class SessionsController < Devise::SessionsController
prepend_before_action :authenticate_with_two_factor, only: [:create] prepend_before_action :authenticate_with_two_factor, only: [:create]
prepend_before_action :store_redirect_path, only: [:new] prepend_before_action :store_redirect_path, only: [:new]
before_action :gitlab_geo_auth, only: [:new] before_action :gitlab_geo_login, only: [:new]
before_action :auto_sign_in_with_provider, only: [:new] before_action :auto_sign_in_with_provider, only: [:new]
before_action :load_recaptcha before_action :load_recaptcha
...@@ -57,7 +57,7 @@ class SessionsController < Devise::SessionsController ...@@ -57,7 +57,7 @@ class SessionsController < Devise::SessionsController
if redirect_uri.path == new_user_session_path if redirect_uri.path == new_user_session_path
redirect_to = root_url redirect_to = root_url
elsif Gitlab::Geo.geo_node?(host: redirect_uri.host, port: redirect_uri.port) elsif Gitlab::Geo.geo_node?(host: redirect_uri.host, port: redirect_uri.port)
redirect_to = redirect_url.to_s redirect_to = redirect_uri.to_s
end end
@redirect_to = redirect_to @redirect_to = redirect_to
...@@ -86,12 +86,12 @@ class SessionsController < Devise::SessionsController ...@@ -86,12 +86,12 @@ class SessionsController < Devise::SessionsController
end end
end end
def gitlab_geo_auth def gitlab_geo_login
if !signed_in? && Gitlab::Geo.enabled? && Gitlab::Geo.readonly? if !signed_in? && Gitlab::Geo.enabled? && Gitlab::Geo.readonly?
# share full url with primary node by shared session # share full url with primary node by shared session
session[:geo_node_return_to] = @redirect_to session[:geo_node_return_to] = @redirect_to
login_uri = URI.join(Gitlab::Geo.primary_node.uri, new_session_path(:user)).to_s login_uri = URI.join(Gitlab::Geo.primary_node.url, new_session_path(:user)).to_s
redirect_to login_uri redirect_to login_uri
end end
end end
......
...@@ -23,4 +23,8 @@ class GeoNode < ActiveRecord::Base ...@@ -23,4 +23,8 @@ class GeoNode < ActiveRecord::Base
def uri def uri
URI.parse("#{schema}://#{host}:#{port}/#{relative_url_root}") URI.parse("#{schema}://#{host}:#{port}/#{relative_url_root}")
end end
def url
uri.to_s
end
end end
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