diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-04-15 15:09:17 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-04-15 15:09:17 +0000 |
commit | 0d83264a7a24b33de933437355c77a4fe47e5419 (patch) | |
tree | ebf7a1d3274d918fb968d7056300cc388f2e91a4 /lib/constraints | |
parent | b7c735c8ac11b8182807070fc6f84f2606e15427 (diff) | |
download | gitlab-ce-0d83264a7a24b33de933437355c77a4fe47e5419.tar.gz |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/constraints')
-rw-r--r-- | lib/constraints/admin_constrainer.rb | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/lib/constraints/admin_constrainer.rb b/lib/constraints/admin_constrainer.rb new file mode 100644 index 00000000000..59c855a1b73 --- /dev/null +++ b/lib/constraints/admin_constrainer.rb @@ -0,0 +1,25 @@ +# frozen_string_literal: true + +module Constraints + class AdminConstrainer + def matches?(request) + if Feature.enabled?(:user_mode_in_session) + admin_mode_enabled?(request) + else + user_is_admin?(request) + end + end + + private + + def user_is_admin?(request) + request.env['warden'].authenticate? && request.env['warden'].user.admin? + end + + def admin_mode_enabled?(request) + Gitlab::Session.with_session(request.session) do + request.env['warden'].authenticate? && Gitlab::Auth::CurrentUserMode.new(request.env['warden'].user).admin_mode? + end + end + end +end |