Commit 5da80d12 authored by Imre Farkas's avatar Imre Farkas

Merge branch 'refactor/admin-mode-single-session' into 'master'

Disable lookup of other ActiveSessions to determine admin mode status

Closes #35718

See merge request gitlab-org/gitlab!27318
parents 5d17a264 36cfd946
---
title: Disable lookup of other ActiveSessions to determine admin mode status
merge_request: 27318
author: Diego Louzán
type: changed
...@@ -77,7 +77,7 @@ module Gitlab ...@@ -77,7 +77,7 @@ module Gitlab
return false unless user return false unless user
Gitlab::SafeRequestStore.fetch(admin_mode_rs_key) do Gitlab::SafeRequestStore.fetch(admin_mode_rs_key) do
user.admin? && any_session_with_admin_mode? user.admin? && session_with_admin_mode?
end end
end end
...@@ -136,19 +136,10 @@ module Gitlab ...@@ -136,19 +136,10 @@ module Gitlab
@current_session ||= Gitlab::NamespacedSessionStore.new(SESSION_STORE_KEY) @current_session ||= Gitlab::NamespacedSessionStore.new(SESSION_STORE_KEY)
end end
def any_session_with_admin_mode? def session_with_admin_mode?
return true if bypass_session? return true if bypass_session?
return true if current_session_data.initiated? && current_session_data[ADMIN_MODE_START_TIME_KEY].to_i > MAX_ADMIN_MODE_TIME.ago.to_i
all_sessions.any? do |session| current_session_data.initiated? && current_session_data[ADMIN_MODE_START_TIME_KEY].to_i > MAX_ADMIN_MODE_TIME.ago.to_i
session[ADMIN_MODE_START_TIME_KEY].to_i > MAX_ADMIN_MODE_TIME.ago.to_i
end
end
def all_sessions
@all_sessions ||= ActiveSession.list_sessions(user).lazy.map do |session|
Gitlab::NamespacedSessionStore.new(SESSION_STORE_KEY, session.with_indifferent_access )
end
end end
def admin_mode_requested_in_grace_period? def admin_mode_requested_in_grace_period?
......
...@@ -151,13 +151,13 @@ describe Gitlab::Auth::CurrentUserMode, :do_not_mock_admin_mode, :request_store ...@@ -151,13 +151,13 @@ describe Gitlab::Auth::CurrentUserMode, :do_not_mock_admin_mode, :request_store
allow(ActiveSession).to receive(:list_sessions).with(user).and_return([session, another_session]) allow(ActiveSession).to receive(:list_sessions).with(user).and_return([session, another_session])
end end
it 'can be enabled in one and seen in the other' do it 'cannot be enabled in one and seen in the other' do
Gitlab::Session.with_session(another_session) do Gitlab::Session.with_session(another_session) do
another_subject.request_admin_mode! another_subject.request_admin_mode!
another_subject.enable_admin_mode!(password: user.password) another_subject.enable_admin_mode!(password: user.password)
end end
expect(subject.admin_mode?).to be(true) expect(subject.admin_mode?).to be(false)
end end
end 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