summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJacob Vosmaer <contact@jacobvosmaer.nl>2016-03-11 13:47:49 +0100
committerJacob Vosmaer <contact@jacobvosmaer.nl>2016-03-11 13:47:49 +0100
commitbf253a10873af6b6fdb28f424e6f1db8c515be25 (patch)
treeef8fb0c44aa52dbbe02ca7d668372cc25ce0911a
parent73c777cf673345d39a17519e55005082bd70ee2e (diff)
downloadgitlab-ce-ldap-lease-8.5.tar.gz
Obtain lease before querying LDAPldap-lease-8.5
-rw-r--r--app/controllers/application_controller.rb2
-rw-r--r--app/models/user.rb7
-rw-r--r--lib/gitlab/user_access.rb2
3 files changed, 10 insertions, 1 deletions
diff --git a/app/controllers/application_controller.rb b/app/controllers/application_controller.rb
index fb74919ea23..1f55b18e0b1 100644
--- a/app/controllers/application_controller.rb
+++ b/app/controllers/application_controller.rb
@@ -246,6 +246,8 @@ class ApplicationController < ActionController::Base
def ldap_security_check
if current_user && current_user.requires_ldap_check?
+ return unless current_user.try_obtain_ldap_lease
+
unless Gitlab::LDAP::Access.allowed?(current_user)
sign_out current_user
flash[:alert] = "Access denied for your LDAP account."
diff --git a/app/models/user.rb b/app/models/user.rb
index 2ef8d851b26..b8d4841e659 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -603,6 +603,13 @@ class User < ActiveRecord::Base
end
end
+ def try_obtain_ldap_lease
+ # After obtaining this lease LDAP checks will be blocked for 600 seconds
+ # (10 minutes) for this user.
+ lease = Gitlab::ExclusiveLease.new("user_ldap_check:#{id}", timeout: 600)
+ lease.try_obtain
+ end
+
def solo_owned_groups
@solo_owned_groups ||= owned_groups.select do |group|
group.owners == [self]
diff --git a/lib/gitlab/user_access.rb b/lib/gitlab/user_access.rb
index 4885baf9526..d1b42c1f9b9 100644
--- a/lib/gitlab/user_access.rb
+++ b/lib/gitlab/user_access.rb
@@ -3,7 +3,7 @@ module Gitlab
def self.allowed?(user)
return false if user.blocked?
- if user.requires_ldap_check?
+ if user.requires_ldap_check? && user.try_obtain_ldap_lease
return false unless Gitlab::LDAP::Access.allowed?(user)
end