mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-24 13:24:56 +08:00
449 lines
17 KiB
Plaintext
449 lines
17 KiB
Plaintext
|
||
|
||
INTERNET-DRAFT S. Legg
|
||
draft-legg-ldap-binary-01.txt Adacel Technologies
|
||
Intended Category: Standards Track 16 June 2004
|
||
Updates: RFC 2251bis
|
||
|
||
|
||
Lightweight Directory Access Protocol (LDAP):
|
||
The Binary Encoding Option
|
||
|
||
Copyright (C) The Internet Society (2004). All Rights Reserved.
|
||
|
||
Status of this Memo
|
||
|
||
|
||
This document is an Internet-Draft and is in full conformance with
|
||
all provisions of Section 10 of RFC2026.
|
||
|
||
Internet-Drafts are working documents of the Internet Engineering
|
||
Task Force (IETF), its areas, and its working groups. Note that
|
||
other groups may also distribute working documents as
|
||
Internet-Drafts.
|
||
|
||
Internet-Drafts are draft documents valid for a maximum of six months
|
||
and may be updated, replaced, or obsoleted by other documents at any
|
||
time. It is inappropriate to use Internet-Drafts as reference
|
||
material or to cite them other than as "work in progress".
|
||
|
||
The list of current Internet-Drafts can be accessed at
|
||
http://www.ietf.org/ietf/1id-abstracts.txt
|
||
|
||
The list of Internet-Draft Shadow Directories can be accessed at
|
||
http://www.ietf.org/shadow.html.
|
||
|
||
This document is intended to be, after appropriate review and
|
||
revision, submitted to the RFC Editor as a Standard Track document.
|
||
Distribution of this document is unlimited. Technical discussion of
|
||
this document should take place on the IETF LDAP Revision Working
|
||
Group (LDAPbis) mailing list <ietf-ldapbis@openldap.org>. Please
|
||
send editorial comments directly to the editor
|
||
<steven.legg@adacel.com.au>.
|
||
|
||
This Internet-Draft expires on 16 December 2004.
|
||
|
||
|
||
Abstract
|
||
|
||
Each attribute stored in a Lightweight Directory Access Protocol
|
||
(LDAP) directory has a defined syntax (i.e., data type). A syntax
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 1]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
definition specifies how attribute values conforming to the syntax
|
||
are normally represented when transferred in LDAP operations. This
|
||
representation is referred to as the LDAP-specific encoding to
|
||
distinguish it from other methods of encoding attribute values. This
|
||
document defines an attribute option, the binary option, which can be
|
||
used to specify that the associated attribute values are instead
|
||
encoded according to the Basic Encoding Rules (BER) used by X.500
|
||
directories.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 2]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
Table of Contents
|
||
|
||
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 3
|
||
2. Conventions. . . . . . . . . . . . . . . . . . . . . . . . . . 4
|
||
3. The binary Option. . . . . . . . . . . . . . . . . . . . . . . 4
|
||
4. Syntaxes Requiring Binary Transfer . . . . . . . . . . . . . . 4
|
||
5. Attributes Returned in a Search. . . . . . . . . . . . . . . . 5
|
||
6. All User Attributes. . . . . . . . . . . . . . . . . . . . . . 5
|
||
7. Conflicting Requests . . . . . . . . . . . . . . . . . . . . . 6
|
||
8. Security Considerations. . . . . . . . . . . . . . . . . . . . 6
|
||
9. IANA Considerations. . . . . . . . . . . . . . . . . . . . . . 6
|
||
10. References . . . . . . . . . . . . . . . . . . . . . . . . . . 6
|
||
10.1. Normative References. . . . . . . . . . . . . . . . . . 6
|
||
10.2. Informative References. . . . . . . . . . . . . . . . . 7
|
||
Author's Address . . . . . . . . . . . . . . . . . . . . . . . . . 7
|
||
Full Copyright Statement . . . . . . . . . . . . . . . . . . . . . 8
|
||
|
||
1. Introduction
|
||
|
||
Each attribute stored in a Lightweight Directory Access Protocol
|
||
(LDAP) directory [ROADMAP] has a defined syntax (i.e., data type)
|
||
which constrains the structure and format of its values.
|
||
|
||
The description of each syntax [SYNTAX] specifies how attribute or
|
||
assertion values [MODELS] conforming to the syntax are normally
|
||
represented when transferred in LDAP operations [PROT]. This
|
||
representation is referred to as the LDAP-specific encoding to
|
||
distinguish it from other methods of encoding attribute values.
|
||
|
||
This document defines an attribute option, the binary option, which
|
||
can be used in an attribute description [MODELS] in an LDAP operation
|
||
to specify that the associated attribute values or assertion value
|
||
are, or are requested to be, encoded according to the Basic Encoding
|
||
Rules (BER) [BER] as used by X.500 [X500] directories, instead of the
|
||
usual LDAP-specific encoding.
|
||
|
||
The binary option was originally defined in RFC 2251 [RFC2251]. The
|
||
LDAP technical specification [ROADMAP] has obsoleted the previously
|
||
defined LDAP technical specification [RFC3377], which included RFC
|
||
2251. However the binary option was not included in the newer LDAP
|
||
technical specification due to a lack of consistency in its
|
||
implementation. This document reintroduces the binary option.
|
||
However, except for the case of certain attribute syntaxes whose
|
||
values are required to BER encoded, no attempt is made here to
|
||
eliminate the known consistency problems. Rather the focus is on
|
||
capturing current behaviours. A more thorough solution is left for a
|
||
future specification.
|
||
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 3]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
2. Conventions
|
||
|
||
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, RFC 2119
|
||
[KEYWORD].
|
||
|
||
3. The binary Option
|
||
|
||
The binary option is indicated with the attribute option string
|
||
"binary" in an attribute description. Note that, like all attribute
|
||
options, the string representing the binary option is case
|
||
insensitive.
|
||
|
||
In terms of the protocol [PROT], the binary option specifies that the
|
||
contents octets of the associated AttributeValue or AssertionValue
|
||
OCTET STRING are a complete BER encoding of the relevant value.
|
||
|
||
Where the binary option is present in an attribute description the
|
||
associated attribute values or assertion value MUST be BER encoded.
|
||
Note that it is possible for a syntax to be defined such that its
|
||
LDAP-specific encoding is exactly the same as its BER encoding.
|
||
|
||
The binary option is not a tagging option [MODELS] so the presence of
|
||
the binary option does not specify an attribute subtype. An
|
||
attribute description containing the binary option references exactly
|
||
the same attribute as the same attribute description without the
|
||
binary option. The supertype/subtype relationships of attributes
|
||
with tagging options are not altered in any way by the presence or
|
||
absence of the binary option.
|
||
|
||
An attribute description SHALL be treated as unrecognized if it
|
||
contains the binary option and the syntax of the attribute does not
|
||
have an associated ASN.1 type [SYNTAX], or the BER encoding of that
|
||
type is not supported.
|
||
|
||
The presence or absence of the binary option only affects the
|
||
transfer of attribute and assertion values in protocol; servers store
|
||
any particular attribute value in a single format of their choosing.
|
||
|
||
4. Syntaxes Requiring Binary Transfer
|
||
|
||
Certain syntaxes are required to be transferred in the BER encoded
|
||
form. These syntaxes are said to have a binary transfer requirement.
|
||
The Certificate, Certificate List, Certificate Pair and Supported
|
||
Algorithm syntaxes [PKI] are examples of syntaxes with a binary
|
||
transfer requirement. These syntaxes also have an additional
|
||
requirement that the exact BER encoding must be preserved. Note that
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 4]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
this is a property of the syntaxes themselves, and not a property of
|
||
the binary option.
|
||
|
||
5. Attributes Returned in a Search
|
||
|
||
An LDAP search request [PROT] contains a list of the attributes (the
|
||
requested attributes list) to be returned from each entry matching
|
||
the search filter. An attribute description in the requested
|
||
attributes list also implicitly requests all subtypes of the
|
||
attribute type in the attribute description, whether through
|
||
attribute subtyping or attribute tagging option subtyping [MODELS].
|
||
|
||
The requested attributes list MAY contain attribute descriptions with
|
||
the binary option, but MUST NOT contain two attribute descriptions
|
||
with the same attribute type and the same tagging options (even if
|
||
only one of them has the binary option). The binary option in an
|
||
attribute description in the requested attributes list implicitly
|
||
applies to all the subtypes of the attribute type in the attribute
|
||
description (however, see Section 7).
|
||
|
||
Attributes of a syntax with the binary transfer requirement SHALL be
|
||
returned in the binary form, i.e., with the binary option in the
|
||
attribute description and the associated attribute values BER
|
||
encoded, regardless of whether the binary option was present in the
|
||
request (for the attribute or for one of its supertypes).
|
||
|
||
Attributes of a syntax without the binary transfer requirement SHOULD
|
||
be returned in the form explicitly requested. That is, if the
|
||
attribute description in the requested attributes list contains the
|
||
binary option then the corresponding attribute in the result SHOULD
|
||
be in the binary form. If the attribute description in the request
|
||
does not contain the binary option then the corresponding attribute
|
||
in the result SHOULD NOT be in the binary form. A server MAY omit an
|
||
attribute from the result if it does not support the requested
|
||
encoding.
|
||
|
||
Regardless of the encoding chosen, a particular attribute value is
|
||
returned at most once.
|
||
|
||
6. All User Attributes
|
||
|
||
If the list of attributes in a search request is empty, or contains
|
||
the special attribute description string "*", then all user
|
||
attributes are requested to be returned.
|
||
|
||
Attributes of a syntax with the binary transfer requirement SHALL be
|
||
returned in the binary form.
|
||
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 5]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
Attributes of a syntax without the binary transfer requirement and
|
||
having a defined LDAP-specific encoding SHOULD NOT be returned in the
|
||
binary form.
|
||
|
||
Attributes of a syntax without the binary transfer requirement and
|
||
without a defined LDAP-specific encoding may be returned in the
|
||
binary form or omitted from the result.
|
||
|
||
7. Conflicting Requests
|
||
|
||
A particular attribute could be explicitly requested by an attribute
|
||
description and/or implicitly requested by the attribute descriptions
|
||
of one or more of its supertypes, or by the special attribute
|
||
description string "*". If the binary option is not present in all
|
||
these attribute descriptions, nor absent in all these attribute
|
||
descriptions, then the server is free to choose whether to return the
|
||
attribute in the binary form.
|
||
|
||
8. Security Considerations
|
||
|
||
When interpreting security-sensitive fields, and in particular fields
|
||
used to grant or deny access, implementations MUST ensure that any
|
||
matching rule comparisons are done on the underlying abstract value,
|
||
regardless of the particular encoding used.
|
||
|
||
9. IANA Considerations
|
||
|
||
The Internet Assigned Numbers Authority (IANA) is requested to update
|
||
the LDAP attribute description option registry [BCP64] as indicated
|
||
by the following template:
|
||
|
||
Subject: Request for
|
||
LDAP Attribute Description Option Registration
|
||
Option Name: binary
|
||
Family of Options: NO
|
||
Person & email address to contact for further information:
|
||
Steven Legg <steven.legg@adacel.com.au>
|
||
Specification: RFC XXXX
|
||
Author/Change Controller: IESG
|
||
Comments: The existing registration for "binary"
|
||
should be updated to refer to RFC XXXX.
|
||
|
||
10. References
|
||
|
||
10.1. Normative References
|
||
|
||
[KEYWORD] Bradner, S., "Key words for use in RFCs to Indicate
|
||
Requirement Levels", BCP 14, RFC 2119, March 1997.
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 6]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
[BCP64] Zeilenga, K., "Internet Assigned Numbers Authority (IANA)
|
||
Considerations for the Lightweight Directory Access
|
||
Protcol (LDAP)", BCP 64, RFC 3383, September 2002.
|
||
|
||
[ROADMAP] Zeilenga, K., "Lightweight Directory Access Protocol
|
||
(LDAP): Technical Specification Road Map",
|
||
draft-ietf-ldapbis-roadmap-xx.txt, a work in progress,
|
||
June 2004.
|
||
|
||
[MODELS] Zeilenga, K., "LDAP: Directory Information Models",
|
||
draft-ietf-ldapbis-models-xx.txt, a work in progress, June
|
||
2004.
|
||
|
||
[PROT] Sermersheim, J., "LDAP: The Protocol",
|
||
draft-ietf-ldapbis-protocol-xx.txt, a work in progress,
|
||
May 2004.
|
||
|
||
[SYNTAX] Legg, S. and K. Dally, "Lightweight Directory Access
|
||
Protocol (LDAP): Syntaxes and Matching Rules",
|
||
draft-ietf-ldapbis-syntaxes-xx.txt, a work in progress,
|
||
May 2004.
|
||
|
||
[PKI] Chadwick, D. and S. Legg, "Internet X.509 Public Key
|
||
Infrastructure Additional LDAP Schema for PKIs and PMIs",
|
||
draft-pkix-ldap-schema-xx.txt, a work in progress, April
|
||
2002.
|
||
|
||
[BER] ITU-T Recommendation X.690 (07/02) | ISO/IEC 8825-1,
|
||
Information Technology - ASN.1 encoding rules:
|
||
Specification of Basic Encoding Rules (BER), Canonical
|
||
Encoding Rules (CER) and Distinguished Encoding Rules
|
||
(DER).
|
||
|
||
10.2. Informative References
|
||
|
||
[RFC2251] Wahl, M., Howes, T. and S. Kille, "Lightweight Directory
|
||
Access Protocol (v3)", RFC 2251, December 1997.
|
||
|
||
[RFC3377] Hodges, J. and R. Morgan, "Lightweight Directory Access
|
||
Protocol (v3): Technical Specification", RFC 3377,
|
||
September 2002.
|
||
|
||
[X500] ITU-T Recommendation X.500 (1993) | ISO/IEC 9594-1:1994,
|
||
"Information Technology - Open Systems Interconnection -
|
||
The Directory: Overview of concepts, models and services".
|
||
|
||
Author's Address
|
||
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 7]
|
||
|
||
INTERNET-DRAFT LDAP: The Binary Encoding Option June 16, 2004
|
||
|
||
|
||
Steven Legg
|
||
Adacel Technologies Ltd.
|
||
250 Bay Street
|
||
Brighton, Victoria 3186
|
||
AUSTRALIA
|
||
|
||
Phone: +61 3 8530 7710
|
||
Fax: +61 3 8530 7888
|
||
Email: steven.legg@adacel.com.au
|
||
|
||
Full Copyright Statement
|
||
|
||
Copyright (C) The Internet Society (2004). This document is subject
|
||
to the rights, licenses and restrictions contained in BCP 78, and
|
||
except as set forth therein, the authors retain all their rights.
|
||
|
||
This document and the information contained herein are provided on an
|
||
"AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS
|
||
OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY AND THE INTERNET
|
||
ENGINEERING TASK FORCE DISCLAIM 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.
|
||
|
||
Intellectual Property
|
||
|
||
The IETF takes no position regarding the validity or scope of any
|
||
Intellectual Property Rights 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; nor does it represent that it has
|
||
made any independent effort to identify any such rights. Information
|
||
on the procedures with respect to rights in RFC documents can be
|
||
found in BCP 78 and BCP 79.
|
||
|
||
Copies of IPR disclosures made to the IETF Secretariat 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 implementers or users of this
|
||
specification can be obtained from the IETF on-line IPR repository at
|
||
http://www.ietf.org/ipr.
|
||
|
||
The IETF invites any interested party to bring to its attention any
|
||
copyrights, patents or patent applications, or other proprietary
|
||
rights that may cover technology that may be required to implement
|
||
this standard. Please address the information to the IETF at
|
||
ietf-ipr@ietf.org.
|
||
|
||
|
||
|
||
|
||
Legg Expires 16 December 2004 [Page 8]
|
||
|
||
|