Commit 737bdc30 authored by Dmitriy Zaporozhets's avatar Dmitriy Zaporozhets

Merge branch 'refactor/ldap_access' of /home/git/repositories/gitlab/gitlab-ee

parents b1150883 61ba66c0
...@@ -12,27 +12,41 @@ module Gitlab ...@@ -12,27 +12,41 @@ module Gitlab
# if instance does not use group_base setting # if instance does not use group_base setting
return true unless Gitlab.config.ldap['group_base'].present? return true unless Gitlab.config.ldap['group_base'].present?
# Get LDAP user entry
ldap_user = Gitlab::LDAP::Person.find_by_dn(user.extern_uid) ldap_user = Gitlab::LDAP::Person.find_by_dn(user.extern_uid)
ldap_groups = ldap_user.groups
ldap_groups_cn = ldap_groups.map(&:name)
groups = ::Group.where(ldap_cn: ldap_groups_cn)
# First lets add user to new groups # Get all GitLab groups with activated LDAP
groups.each do |group| groups = ::Group.where('ldap_cn IS NOT NULL')
group.add_users([user.id], group.ldap_access) if group.ldap_access.present?
end # Get LDAP groups based on cn from GitLab groups
ldap_groups = groups.pluck(:ldap_cn).map { |cn| Gitlab::LDAP::Group.find_by_cn(cn) }
ldap_groups = ldap_groups.compact.uniq
# Remove groups with LDAP if user lost access to it # Iterate over ldap groups and check user membership
user.authorized_groups.where('ldap_cn IS NOT NULL').each do |group| ldap_groups.each do |ldap_group|
if ldap_groups_cn.include?(group.ldap_cn) if ldap_group.has_member?(ldap_user)
# ok user still in group # If user present in LDAP group -> add him to GitLab groups
add_user_to_groups(user.id, ldap_group.cn)
else else
# user lost access to this group in ldap # If not - remove him from GitLab groups
membership = group.users_groups.where(user_id: user.id).last remove_user_from_groups(user.id, ldap_group.cn)
membership.destroy if membership
end end
end end
end end
def add_user_to_groups(user_id, group_cn)
groups = ::Group.where(ldap_cn: group_cn)
groups.each do |group|
group.add_users([user_id], group.ldap_access) if group.ldap_access.present?
end
end
def remove_user_from_groups(user_id, group_cn)
groups = ::Group.where(ldap_cn: group_cn)
groups.each do |group|
group.users_groups.where(user_id: user_id).destroy_all
end
end
end end
end end
end end
...@@ -51,6 +51,10 @@ module Gitlab ...@@ -51,6 +51,10 @@ module Gitlab
end end
end end
def group(*args)
groups(*args).first
end
def users(field, value) def users(field, value)
if field.to_sym == :dn if field.to_sym == :dn
options = { options = {
......
...@@ -7,14 +7,22 @@ ...@@ -7,14 +7,22 @@
module Gitlab module Gitlab
module LDAP module LDAP
class Group class Group
def self.find_by_cn(cn)
Gitlab::LDAP::Adapter.new.group(cn)
end
def initialize(entry) def initialize(entry)
@entry = entry @entry = entry
end end
def name def cn
entry.cn.join(" ") entry.cn.join(" ")
end end
def name
cn
end
def path def path
name.parameterize name.parameterize
end end
...@@ -27,6 +35,14 @@ module Gitlab ...@@ -27,6 +35,14 @@ module Gitlab
entry.memberuid entry.memberuid
end end
def has_member?(user)
if memberuid?
member_uids.include?(user.uid)
else
member_dns.include?(user.dn)
end
end
def member_dns def member_dns
if entry.respond_to? :member if entry.respond_to? :member
entry.member entry.member
......
...@@ -35,16 +35,6 @@ module Gitlab ...@@ -35,16 +35,6 @@ module Gitlab
entry.dn entry.dn
end end
def groups
adapter.groups.select do |group|
if group.memberuid?
group.member_uids.include?(uid)
else
group.member_dns.include?(dn)
end
end
end
private private
def entry def entry
......
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