LDAP中的嵌套组通常如何实现?

时间:2011-01-05 17:48:11

标签: ldap nested-groups

我将LDAP作为在工作中管理访问服务器和源代码的可能工具,虽然我已经能够掌握基本概念,例如将用户和机器表示为实体,创建属性和定义哪些属性应该应用于基于应用于它们的objectClasses的实体,有一些错误对我来说仍然没有意义,我希望有人可以帮助解释它们是如何工作的。

嵌套组如何工作?

我可以理解ou(组织单位)是什么,我可以理解将人放入其中,并使用groupOfNames类充当成员的容器,例如来自{{3的LDIF片段}}:

    # create FIRST Level groups branch

    dn: ou=groups,dc=example,dc=com
    objectclass:organizationalunit
    ou: groups
    description: generic groups branch

    # create the itpeople entry under groups

    dn: cn=itpeople,ou=groups,dc=example,dc=com
    objectclass: groupofnames
    cn: itpeople
    description: IT security group
    member: cn=William Smith,ou=people,dc=example,dc=com

    # create the hrpeople entry under groups

    dn: cn=hrpeople,ou=groups,dc=example,dc=com
    objectclass: groupofnames
    cn: hrpeople
    description: Human Resources group
    member: cn=Robert Smith,ou=people,dc=example,dc=com

我如何添加更多嵌套级别?

我所追求的是这里的伪代码:

ou='Projects' /
description: This top level group has a few people in it that can create new groups, and control who's in them
member: cn=Robert Smith,ou=people,dc=example,dc=com

    -- somethingsomethingAbitrarilyNestedGroup='project-name'
        member: cn=Robert Smith,ou=people,dc=example,dc=com

        -- groupOfNames = 'project-name development'
            member: cn=Robert Smith,ou=people,dc=example,dc=com
            member: cn=Jane Doe,ou=people,dc=example,dc=com
            member: cn=server1$,ou=servers,dc=example,dc=com

        -- groupOfNames = 'project-name staging'
            member: cn=Jane Doe,ou=people,dc=example,dc=com
            member: cn=server2$,ou=servers,dc=example,dc=com

鉴于此层次结构,现在授予该组访问权限的最佳方式是什么?

我没有看到在这里进行任意组嵌套的简单方法 - 在可用的普通类中,不使用昂贵的闭源工具,但感觉它不应该是这么复杂。

如何通过OpenLDAP等工具正常完成,让其他ldap客户端在被认证为具有正确权限的用户后控制组成员身份? ?

2 个答案:

答案 0 :(得分:15)

您的问题有点困惑 - 我不确定您的意思是“现在授予访问此群组的最佳方式是什么”在最初的几段内容中。

嵌套组很简单。如果您正在使用groupOfNames objectClass,只需将另一个member属性添加到您的父组,其值为子组的DN。

来自您的伪代码:

# Assuming your "groups" OU already exists...
# First create the child groups

dn: cn=project-name development,ou=groups,dc=example,dc=com
objectclass: groupofnames
cn: project-name development
member: cn=Robert Smith,ou=people,dc=example,dc=com
member: cn=Jane Doe,ou=people,dc=example,dc=com
member: cn=server1$,ou=servers,dc=example,dc=com

dn: cn=project-name staging,ou=groups,dc=example,dc=com
objectclass: groupofnames
cn: project-name development
member: cn=Jane Doe,ou=people,dc=example,dc=com
member: cn=server2$,ou=servers,dc=example,dc=com

# Now create the parent group
dn: 'project-name,ou=groups,dc=example,dc=com'
objectclass: groupofnames
member: cn=Robert Smith,ou=people,dc=example,dc=com
member: cn=project-name staging,ou=groups,dc=example,dc=com
member: cn=project-name development,ou=groups,dc=example,dc=com

OU中的Hiearchy实际上只是根据组织的结构将LDAP树分成“逻辑”段。因此,举例来说,您可以将所有组织都放在自己的OU中管理“开发部门”,这样就可以清楚地了解它们的相关内容。通过使用适当的属性(在本例中为member)引用彼此,对象可以相互引用,并且非常愉快地嵌套。

答案 1 :(得分:6)

我相信在引用用户对象时,您应该使用uid=而不是cn=

我对嵌套组的问题是许多可以引用组的应用程序不熟悉如何搜索嵌套组中的成员对象。