mirror of
https://git.openldap.org/openldap/openldap.git
synced 2024-12-15 03:01:09 +08:00
564 lines
18 KiB
Plaintext
564 lines
18 KiB
Plaintext
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Network Working Group K. Zeilenga
|
|||
|
Request for Comments: 3671 OpenLDAP Foundation
|
|||
|
Category: Standards Track December 2003
|
|||
|
|
|||
|
|
|||
|
Collective Attributes in
|
|||
|
the Lightweight Directory Access Protocol (LDAP)
|
|||
|
|
|||
|
Status of this Memo
|
|||
|
|
|||
|
This document specifies an Internet standards track protocol for the
|
|||
|
Internet community, and requests discussion and suggestions for
|
|||
|
improvements. Please refer to the current edition of the "Internet
|
|||
|
Official Protocol Standards" (STD 1) for the standardization state
|
|||
|
and status of this protocol. Distribution of this memo is unlimited.
|
|||
|
|
|||
|
Copyright Notice
|
|||
|
|
|||
|
Copyright (C) The Internet Society (2003). All Rights Reserved.
|
|||
|
|
|||
|
Abstract
|
|||
|
|
|||
|
X.500 collective attributes allow common characteristics to be shared
|
|||
|
between collections of entries. This document summarizes the X.500
|
|||
|
information model for collective attributes and describes use of
|
|||
|
collective attributes in LDAP (Lightweight Directory Access
|
|||
|
Protocol). This document provides schema definitions for collective
|
|||
|
attributes for use in LDAP.
|
|||
|
|
|||
|
1. Introduction
|
|||
|
|
|||
|
In X.500 [X.500], a collective attribute is "a user attribute whose
|
|||
|
values are the same for each member of an entry collection" [X.501].
|
|||
|
This document details their use in the Lightweight Directory Access
|
|||
|
Protocol (LDAP) [RFC3377].
|
|||
|
|
|||
|
1.1. Entry Collections
|
|||
|
|
|||
|
A collection of entries is a grouping of object and alias entries
|
|||
|
based upon common properties or shared relationship between the
|
|||
|
corresponding entries which share certain attributes. An entry
|
|||
|
collection consists of all entries within scope of a collective
|
|||
|
attributes subentry [RFC3672]. An entry can belong to several entry
|
|||
|
collections.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 1]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
1.2. Collective Attributes
|
|||
|
|
|||
|
Attributes shared by the entries comprising an entry collection are
|
|||
|
called collective attributes. Values of collective attributes are
|
|||
|
visible but not updateable to clients accessing entries within the
|
|||
|
collection. Collective attributes are updated (i.e., modified) via
|
|||
|
their associated collective attributes subentry.
|
|||
|
|
|||
|
When an entry belongs to multiple entry collections, the entry's
|
|||
|
values of each collective attribute are combined such that
|
|||
|
independent sources of these values are not manifested to clients.
|
|||
|
|
|||
|
Entries can specifically exclude a particular collective attribute by
|
|||
|
listing the attribute as a value of the collectiveExclusions
|
|||
|
attribute. Like other user attributes, collective attributes are
|
|||
|
subject to a variety of controls including access, administrative,
|
|||
|
and content controls.
|
|||
|
|
|||
|
1.3. Conventions
|
|||
|
|
|||
|
Schema definitions are provided using LDAPv3 [RFC2251] description
|
|||
|
formats [RFC2252]. Definitions provided here are formatted (line
|
|||
|
wrapped) for readability.
|
|||
|
|
|||
|
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
|
|||
|
"SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
|
|||
|
document are to be interpreted as described in BCP 14 [RFC2119].
|
|||
|
|
|||
|
2. System Schema for Collective Attributes
|
|||
|
|
|||
|
The following operational attributes are used to manage Collective
|
|||
|
Attributes. LDAP servers [RFC3377] MUST act in accordance with the
|
|||
|
X.500 Directory Models [X.501] when providing this service.
|
|||
|
|
|||
|
2.1. collectiveAttributeSubentry
|
|||
|
|
|||
|
Subentries of this object class are used to administer collective
|
|||
|
attributes and are referred to as collective attribute subentries.
|
|||
|
|
|||
|
( 2.5.17.2 NAME 'collectiveAttributeSubentry' AUXILIARY )
|
|||
|
|
|||
|
A collective attribute subentry SHOULD contain at least one
|
|||
|
collective attribute. The collective attributes contained within a
|
|||
|
collective attribute subentry are available for finding, searching,
|
|||
|
and comparison at every entry within the scope of the subentry. The
|
|||
|
collective attributes, however, are administered (e.g., modified) via
|
|||
|
the subentry.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 2]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
Implementations of this specification SHOULD support collective
|
|||
|
attribute subentries in both collectiveAttributeSpecificArea
|
|||
|
(2.5.23.5) and collectiveAttributeInnerArea (2.5.23.6) administrative
|
|||
|
areas [RFC3672][X.501].
|
|||
|
|
|||
|
2.2. collectiveAttributeSubentries
|
|||
|
|
|||
|
The collectiveAttributeSubentries operational attribute identifies
|
|||
|
all collective attribute subentries that affect the entry.
|
|||
|
|
|||
|
( 2.5.18.12 NAME 'collectiveAttributeSubentries'
|
|||
|
EQUALITY distinguishedNameMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.12
|
|||
|
USAGE directoryOperation NO-USER-MODIFICATION )
|
|||
|
|
|||
|
2.3. collectiveExclusions
|
|||
|
|
|||
|
The collectiveExclusions operational attribute allows particular
|
|||
|
collective attributes to be excluded from an entry. It MAY appear in
|
|||
|
any entry and MAY have multiple values.
|
|||
|
|
|||
|
( 2.5.18.7 NAME 'collectiveExclusions'
|
|||
|
EQUALITY objectIdentifierMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.38
|
|||
|
USAGE directoryOperation )
|
|||
|
|
|||
|
The descriptor excludeAllCollectiveAttributes is associated with the
|
|||
|
OID 2.5.18.0. When this descriptor or OID is present as a value of
|
|||
|
the collectiveExclusions attribute, all collective attributes are
|
|||
|
excluded from an entry.
|
|||
|
|
|||
|
3. Collective Attribute Types
|
|||
|
|
|||
|
A userApplications attribute type can be defined to be COLLECTIVE
|
|||
|
[RFC2252]. This indicates that the same attribute values will appear
|
|||
|
in the entries of an entry collection subject to the use of the
|
|||
|
collectiveExclusions attribute and other administrative controls.
|
|||
|
These administrative controls MAY include DIT Content Rules, if
|
|||
|
implemented.
|
|||
|
|
|||
|
Collective attribute types are commonly defined as subtypes of non-
|
|||
|
collective attribute types. By convention, collective attributes are
|
|||
|
named by prefixing the name of their non-collective supertype with
|
|||
|
"c-". For example, the collective telephone attribute is named
|
|||
|
c-TelephoneNumber after its non-collective supertype telephoneNumber.
|
|||
|
|
|||
|
Non-collective attributes types SHALL NOT subtype collective
|
|||
|
attributes.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 3]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
Collective attributes SHALL NOT be SINGLE-VALUED. Collective
|
|||
|
attribute types SHALL NOT appear in the attribute types of an object
|
|||
|
class definition.
|
|||
|
|
|||
|
Operational attributes SHALL NOT be defined to be collective.
|
|||
|
|
|||
|
The remainder of section provides a summary of collective attributes
|
|||
|
derived from those defined in [X.520]. The SUPerior attribute types
|
|||
|
are described in [RFC 2256] for use with LDAP.
|
|||
|
|
|||
|
Implementations of this specification SHOULD support the following
|
|||
|
collective attributes and MAY support additional collective
|
|||
|
attributes.
|
|||
|
|
|||
|
3.1. Collective Locality Name
|
|||
|
|
|||
|
The c-l attribute type specifies a locality name for a collection of
|
|||
|
entries.
|
|||
|
|
|||
|
( 2.5.4.7.1 NAME 'c-l'
|
|||
|
SUP l COLLECTIVE )
|
|||
|
|
|||
|
3.2. Collective State or Province Name
|
|||
|
|
|||
|
The c-st attribute type specifies a state or province name for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.8.1 NAME 'c-st'
|
|||
|
SUP st COLLECTIVE )
|
|||
|
|
|||
|
3.3. Collective Street Address
|
|||
|
|
|||
|
The c-street attribute type specifies a street address for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.9.1 NAME 'c-street'
|
|||
|
SUP street COLLECTIVE )
|
|||
|
|
|||
|
3.4. Collective Organization Name
|
|||
|
|
|||
|
The c-o attribute type specifies an organization name for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.10.1 NAME 'c-o'
|
|||
|
SUP o COLLECTIVE )
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 4]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
3.5. Collective Organizational Unit Name
|
|||
|
|
|||
|
The c-ou attribute type specifies an organizational unit name for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.11.1 NAME 'c-ou'
|
|||
|
SUP ou COLLECTIVE )
|
|||
|
|
|||
|
3.6. Collective Postal Address
|
|||
|
|
|||
|
The c-PostalAddress attribute type specifies a postal address for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.16.1 NAME 'c-PostalAddress'
|
|||
|
SUP postalAddress COLLECTIVE )
|
|||
|
|
|||
|
3.7. Collective Postal Code
|
|||
|
|
|||
|
The c-PostalCode attribute type specifies a postal code for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.17.1 NAME 'c-PostalCode'
|
|||
|
SUP postalCode COLLECTIVE )
|
|||
|
|
|||
|
3.8. Collective Post Office Box
|
|||
|
|
|||
|
The c-PostOfficeBox attribute type specifies a post office box for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.18.1 NAME 'c-PostOfficeBox'
|
|||
|
SUP postOfficeBox COLLECTIVE )
|
|||
|
|
|||
|
3.9. Collective Physical Delivery Office Name
|
|||
|
|
|||
|
The c-PhysicalDeliveryOfficeName attribute type specifies a physical
|
|||
|
delivery office name for a collection of entries.
|
|||
|
|
|||
|
( 2.5.4.19.1 NAME 'c-PhysicalDeliveryOfficeName'
|
|||
|
SUP physicalDeliveryOfficeName COLLECTIVE )
|
|||
|
|
|||
|
3.10. Collective Telephone Number
|
|||
|
|
|||
|
The c-TelephoneNumber attribute type specifies a telephone number for
|
|||
|
a collection of entries.
|
|||
|
|
|||
|
( 2.5.4.20.1 NAME 'c-TelephoneNumber'
|
|||
|
SUP telephoneNumber COLLECTIVE )
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 5]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
3.11. Collective Telex Number
|
|||
|
|
|||
|
The c-TelexNumber attribute type specifies a telex number for a
|
|||
|
collection of entries.
|
|||
|
|
|||
|
( 2.5.4.21.1 NAME 'c-TelexNumber'
|
|||
|
SUP telexNumber COLLECTIVE )
|
|||
|
|
|||
|
3.13. Collective Facsimile Telephone Number
|
|||
|
|
|||
|
The c-FacsimileTelephoneNumber attribute type specifies a facsimile
|
|||
|
telephone number for a collection of entries.
|
|||
|
|
|||
|
( 2.5.4.23.1 NAME 'c-FacsimileTelephoneNumber'
|
|||
|
|
|||
|
SUP facsimileTelephoneNumber COLLECTIVE )
|
|||
|
|
|||
|
3.14. Collective International ISDN Number
|
|||
|
|
|||
|
The c-InternationalISDNNumber attribute type specifies an
|
|||
|
international ISDN number for a collection of entries.
|
|||
|
|
|||
|
( 2.5.4.25.1 NAME 'c-InternationalISDNNumber'
|
|||
|
SUP internationalISDNNumber COLLECTIVE )
|
|||
|
|
|||
|
4. Security Considerations
|
|||
|
|
|||
|
Collective attributes, like other attributes, are subject to access
|
|||
|
control restrictions and other administrative policy. Generally
|
|||
|
speaking, collective attributes accessed via an entry in a collection
|
|||
|
are governed by rules restricting access to attributes of that entry.
|
|||
|
And collective attributes access via a subentry are governed by rules
|
|||
|
restricting access to attributes of that subentry. However, as LDAP
|
|||
|
does not have a standard access model, the particulars of each
|
|||
|
server's access control system may differ.
|
|||
|
|
|||
|
General LDAP security considerations [RFC3377] also apply.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 6]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
5. IANA Considerations
|
|||
|
|
|||
|
The IANA has registered the LDAP descriptors [RFC3383] defined in
|
|||
|
this technical specification. The following registration template is
|
|||
|
suggested:
|
|||
|
|
|||
|
Subject: Request for LDAP Descriptor Registration
|
|||
|
Descriptor see comments
|
|||
|
Object Identifier: see comment
|
|||
|
Person & email address to contact for further information:
|
|||
|
Kurt Zeilenga <kurt@OpenLDAP.org>
|
|||
|
Usage: see comment
|
|||
|
Specification: RFC3671
|
|||
|
Author/Change Controller: IESG
|
|||
|
Comments:
|
|||
|
|
|||
|
NAME Type OID
|
|||
|
------------------------ ---- -----------------
|
|||
|
c-FacsimileTelephoneNumber A 2.5.4.23.1
|
|||
|
c-InternationalISDNNumber A 2.5.4.25.1
|
|||
|
c-PhysicalDeliveryOffice A 2.5.4.19.1
|
|||
|
c-PostOfficeBox A 2.5.4.18.1
|
|||
|
c-PostalAddress A 2.5.4.16.1
|
|||
|
c-PostalCode A 2.5.4.17.1
|
|||
|
c-TelephoneNumber A 2.5.4.20.1
|
|||
|
c-TelexNumber A 2.5.4.21.1
|
|||
|
c-l A 2.5.4.7.1
|
|||
|
c-o A 2.5.4.10.1
|
|||
|
c-ou A 2.5.4.11.1
|
|||
|
c-st A 2.5.4.8.1
|
|||
|
c-street A 2.5.4.9.1
|
|||
|
collectiveAttributeSubentries A 2.5.18.12
|
|||
|
collectiveAttributeSubentry O 2.5.17.2
|
|||
|
collectiveExclusions A 2.5.18.7
|
|||
|
|
|||
|
where Type A is Attribute and Type O is ObjectClass.
|
|||
|
|
|||
|
The Object Identifiers used in this document were assigned by the
|
|||
|
ISO/IEC Joint Technical Committee 1 - Subcommittee 6 to identify
|
|||
|
elements of X.500 schema [X.520]. This document make no OID
|
|||
|
assignments, it only provides LDAP schema descriptions with existing
|
|||
|
elements of X.500 schema.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 7]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
6. Intellectual Property Statement
|
|||
|
|
|||
|
The IETF takes no position regarding the validity or scope of any
|
|||
|
intellectual property or other rights that might be claimed to
|
|||
|
pertain to the implementation or use of the technology described in
|
|||
|
this document or the extent to which any license under such rights
|
|||
|
might or might not be available; neither does it represent that it
|
|||
|
has made any effort to identify any such rights. Information on the
|
|||
|
IETF's procedures with respect to rights in standards-track and
|
|||
|
standards-related documentation can be found in BCP-11. Copies of
|
|||
|
claims of rights made available for publication and any assurances of
|
|||
|
licenses to be made available, or the result of an attempt made to
|
|||
|
obtain a general license or permission for the use of such
|
|||
|
proprietary rights by implementors or users of this specification can
|
|||
|
be obtained from the IETF Secretariat.
|
|||
|
|
|||
|
The IETF invites any interested party to bring to its attention any
|
|||
|
copyrights, patents or patent applications, or other proprietary
|
|||
|
rights which may cover technology that may be required to practice
|
|||
|
this standard. Please address the information to the IETF Executive
|
|||
|
Director.
|
|||
|
|
|||
|
7. Acknowledgments
|
|||
|
|
|||
|
This document is based upon the ITU Recommendations for the Directory
|
|||
|
[X.501][X.520].
|
|||
|
|
|||
|
8. References
|
|||
|
|
|||
|
8.1. Normative References
|
|||
|
|
|||
|
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
|
|||
|
Requirement Levels", BCP 14, RFC 2119, March 1997.
|
|||
|
|
|||
|
[RFC2251] Wahl, M., Howes, T. and S. Kille, "Lightweight Directory
|
|||
|
Access Protocol (v3)", RFC 2251, December 1997.
|
|||
|
|
|||
|
[RFC2252] Wahl, M., Coulbeck, A., Howes, T. and S. Kille,
|
|||
|
"Lightweight Directory Access Protocol (v3): Attribute
|
|||
|
Syntax Definitions", RFC 2252, December 1997.
|
|||
|
|
|||
|
[RFC2256] Wahl, M., "A Summary of the X.500(96) User Schema for use
|
|||
|
with LDAPv3", RFC 2256, December 1997.
|
|||
|
|
|||
|
[RFC3377] Hodges, J. and R. L. Morgan, "Lightweight Directory Access
|
|||
|
Protocol (v3): Technical Specification", RFC 3377,
|
|||
|
September 2002.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 8]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
[RFC3383] Zeilenga, K., "Internet Assigned Numbers Authority (IANA)
|
|||
|
Considerations for the Lightweight Directory Access
|
|||
|
Protocol (LDAP)", BCP 64, RFC 3383, September 2002.
|
|||
|
|
|||
|
[RFC3672] Zeilenga, K. and S. Legg, "Subentries in Lightweight
|
|||
|
Directory Access Protocol (LDAP)", RFC 3672, December
|
|||
|
2003.
|
|||
|
|
|||
|
[X.501] "The Directory: Models", ITU-T Recommendation X.501, 1993.
|
|||
|
|
|||
|
8.2. Informative References
|
|||
|
|
|||
|
[X.500] "The Directory: Overview of Concepts, Models", ITU-T
|
|||
|
Recommendation X.500, 1993.
|
|||
|
|
|||
|
[X.520] "The Directory: Selected Attribute Types", ITU-T
|
|||
|
Recommendation X.520, 1993.
|
|||
|
|
|||
|
9. Author's Address
|
|||
|
|
|||
|
Kurt D. Zeilenga
|
|||
|
OpenLDAP Foundation
|
|||
|
|
|||
|
EMail: Kurt@OpenLDAP.org
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 9]
|
|||
|
|
|||
|
RFC 3671 Collective Attributes in LDAP December 2003
|
|||
|
|
|||
|
|
|||
|
10. Full Copyright Statement
|
|||
|
|
|||
|
Copyright (C) The Internet Society (2003). All Rights Reserved.
|
|||
|
|
|||
|
This document and translations of it may be copied and furnished to
|
|||
|
others, and derivative works that comment on or otherwise explain it
|
|||
|
or assist in its implementation may be prepared, copied, published
|
|||
|
and distributed, in whole or in part, without restriction of any
|
|||
|
kind, provided that the above copyright notice and this paragraph are
|
|||
|
included on all such copies and derivative works. However, this
|
|||
|
document itself may not be modified in any way, such as by removing
|
|||
|
the copyright notice or references to the Internet Society or other
|
|||
|
Internet organizations, except as needed for the purpose of
|
|||
|
developing Internet standards in which case the procedures for
|
|||
|
copyrights defined in the Internet Standards process must be
|
|||
|
followed, or as required to translate it into languages other than
|
|||
|
English.
|
|||
|
|
|||
|
The limited permissions granted above are perpetual and will not be
|
|||
|
revoked by the Internet Society or its successors or assignees.
|
|||
|
|
|||
|
This document and the information contained herein is provided on an
|
|||
|
"AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
|
|||
|
TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
|
|||
|
BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
|
|||
|
HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
|
|||
|
MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
|
|||
|
|
|||
|
Acknowledgement
|
|||
|
|
|||
|
Funding for the RFC Editor function is currently provided by the
|
|||
|
Internet Society.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Zeilenga Standards Track [Page 10]
|
|||
|
|