mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
1404 lines
45 KiB
Plaintext
1404 lines
45 KiB
Plaintext
|
||
|
||
|
||
|
||
|
||
|
||
INTERNET-DRAFT Kurt D. Zeilenga
|
||
Intended Category: Standard Track OpenLDAP Foundation
|
||
Expires in six months 18 July 2005
|
||
Obsoletes: RFC 2252, RFC 2256, RFC 2587
|
||
|
||
|
||
Lightweight Directory Access Protocol (LDAP) schema
|
||
definitions for X.509 Certificates
|
||
<draft-zeilenga-ldap-x509-02.txt>
|
||
|
||
|
||
Status of this Memo
|
||
|
||
This document is intended to be, after appropriate review and
|
||
revision, submitted to the RFC Editor as an Standard Track document.
|
||
Distribution of this memo is unlimited. Technical discussion of this
|
||
document will take place on the IETF LDAP Extensions mailing list
|
||
<ldapext@ietf.org>. Please send editorial comments directly to the
|
||
author <Kurt@OpenLDAP.org>.
|
||
|
||
This document is intended to be published in conjunction to the
|
||
revised LDAP TS [Roadmap]. Together, this document and the revised
|
||
LDAP TS obsoletes RFC 2252 and RFC 2256 in their entirety.
|
||
|
||
By submitting this Internet-Draft, each author represents that any
|
||
applicable patent or other IPR claims of which he or she is aware have
|
||
been or will be disclosed, and any of which he or she becomes aware
|
||
will be disclosed, in accordance with Section 6 of BCP 79.
|
||
|
||
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/1id-abstracts.html
|
||
|
||
The list of Internet-Draft Shadow Directories can be accessed at
|
||
http://www.ietf.org/shadow.html
|
||
|
||
|
||
Copyright (C) The Internet Society (2005). All Rights Reserved.
|
||
|
||
Please see the Full Copyright section near the end of this document
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 1]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
for more information.
|
||
|
||
|
||
Abstract
|
||
|
||
This document describes schema for representing X.509 certificates,
|
||
X.521 security information, and related elements in directories
|
||
accessible using the Lightweight Directory Access Protocol (LDAP).
|
||
The LDAP definitions for these X.509 and X.521 schema elements
|
||
replaces those provided in RFC 2252 and RFC 2256.
|
||
|
||
|
||
1. Background and Intended Use
|
||
|
||
This document provides LDAP [Roadmap] schema definitions [Models] for
|
||
a subset of elements specified in X.509 [X.509] and X.521 [X.521],
|
||
including attribute types for certificates, cross certificate pairs,
|
||
and certificate revocation lists; matching rules to be used with these
|
||
attribute types; and related object classes. LDAP syntax definitions
|
||
are also provided for associated assertion and attribute values.
|
||
|
||
As the semantics of these elements are as defined in X.509 and X.521,
|
||
knowledge of X.509 and X.521 is necessary to make use of the LDAP
|
||
schema definitions provided herein.
|
||
|
||
This document, together with [Roadmap], obsoletes RFC 2252 and RFC
|
||
2256 in their entirety. The changes (in this document) made since RFC
|
||
2252 and RFC 2256 include:
|
||
- addition of pkiUser, pkiCA, and deltaCRL classes;
|
||
- update of attribute types to include equality matching rules in
|
||
accordance with their X.500 specifications;
|
||
- addition of certificate, certificate pair, certificate list, and
|
||
algorithm identifer matching rules; and
|
||
- addition of LDAP syntax for assertion syntaxes for these matching
|
||
rules.
|
||
|
||
This document obsoletes RFC 2587. The X.509 schema descriptions for
|
||
LDAPv2 [RFC1777] are Historic, as is LDAPv2 [RFC3494].
|
||
|
||
|
||
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].
|
||
|
||
Schema definitions are provided using LDAP description formats
|
||
[Models]. Definitions provided here are formatted (line wrapped) for
|
||
readability.
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 2]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
2. Syntaxes
|
||
|
||
This section describes various syntaxes used in LDAP to transfer
|
||
certificates and related data types.
|
||
|
||
|
||
2.1. Certificate
|
||
|
||
( 1.3.6.1.4.1.1466.115.121.1.8 DESC 'X.509 Certificate' )
|
||
|
||
A value of this syntax is an X.509 Certificate [X.509, clause 7].
|
||
|
||
Due to changes made to the definition of a Certificate made through
|
||
time, no LDAP-specific encoding is defined for this syntax. Values of
|
||
this syntax SHOULD be encoded using Distinguished Encoding Rules (DER)
|
||
[X.690] and MUST only be transferred using the ;binary transfer option
|
||
[Binary]. That is, by requesting and returning values using attribute
|
||
descriptions such as "userCertificate;binary".
|
||
|
||
As values of this syntax contain digitally-signed data, values of this
|
||
syntax, and the form of the value, MUST be preserved as presented.
|
||
|
||
|
||
2.2. CertificateList
|
||
|
||
( 1.3.6.1.4.1.1466.115.121.1.9 DESC 'X.509 Certificate List' )
|
||
|
||
A value of this syntax is an X.509 CertificateList [X.509, clause
|
||
7.3].
|
||
|
||
Due to changes made to the definition of a CertificateList made
|
||
through time, no LDAP-specific encoding is defined for this syntax.
|
||
Values of this syntax SHOULD be encoded using DER [X.690] and MUST
|
||
only be transferred using the ;binary transfer option [Binary]. That
|
||
is, by requesting and returning values using attribute descriptions
|
||
such as "certificateRevocationList;binary".
|
||
|
||
As values of this syntax contain digitally-signed data, values of this
|
||
syntax, and the form of the value, MUST be preserved as presented.
|
||
|
||
|
||
2.3. CertificatePair
|
||
|
||
( 1.3.6.1.4.1.1466.115.121.1.10 DESC 'X.509 Certificate Pair' )
|
||
|
||
A value of this syntax is an X.509 CertificatePair [X.509, clause
|
||
11.2.3].
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 3]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
Due to changes made to the definition of an X.509 CertificatePair made
|
||
through time, no LDAP-specific encoding is defined for this syntax.
|
||
Values of this syntax SHOULD be encoded using DER [X.690] and MUST
|
||
only be transferred using the ;binary transfer option [Binary]. That
|
||
is, by requesting and returning values using attribute descriptions
|
||
such as "crossCertificatePair;binary".
|
||
|
||
As values of this syntax contain digitally-signed data, values of this
|
||
syntax, and the form of the value, MUST be preserved as presented.
|
||
|
||
2.4 SupportedAlgorithm
|
||
|
||
( 1.3.6.1.4.1.1466.115.121.1.49
|
||
DESC 'X.509 Supported Algorithm' )
|
||
|
||
A value of this syntax is an X.509 SupportedAlgorithm [X.509, clause
|
||
11.2.7].
|
||
|
||
Due to changes made to the definition of an X.509 SupportedAlgorithm
|
||
made through time, no LDAP-specific encoding is defined for this
|
||
syntax. Values of this syntax SHOULD be encoded using DER [X.690] and
|
||
MUST only be transferred using the ;binary transfer option [Binary].
|
||
That is, by requesting and returning values using attribute
|
||
descriptions such as "supportedAlgorithms;binary".
|
||
|
||
As values of this syntax contain digitally-signed data, values of this
|
||
syntax, and the form of the value, MUST be preserved as presented.
|
||
|
||
|
||
2.5. CertificateExactAssertion
|
||
|
||
( IANA-ASSIGNED-OID.1 DESC 'X.509 Certificate Exact Assertion' )
|
||
|
||
A value of this syntax is an X.509 CertificateExactAssertion [X.509,
|
||
clause 11.3.1]. Values of this syntax MUST be encoded using the
|
||
Generic String Encoding Rules (GSER) [RFC3641]. Appendix A.1 provides
|
||
an equivalent Augmented Backus-Naur Form (ABNF) [ABNF] grammar for
|
||
this syntax.
|
||
|
||
|
||
2.6. CertificateAssertion
|
||
|
||
( IANA-ASSIGNED-OID.2 DESC 'X.509 Certificate Assertion' )
|
||
|
||
A value of this syntax is an X.509 CertificateAssertion [X.509, clause
|
||
11.3.2]. Values of this syntax MUST be encoded using GSER [RFC3641].
|
||
Appendix A.2 provides an equivalent ABNF [ABNF] grammar for this
|
||
syntax.
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 4]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
2.7. CertificatePairExactAssertion
|
||
|
||
( IANA-ASSIGNED-OID.3
|
||
DESC 'X.509 Certificate Pair Exact Assertion' )
|
||
|
||
A value of this syntax is an X.509 CertificatePairExactAssertion
|
||
[X.509, clause 11.3.3]. Values of this syntax MUST be encoded using
|
||
GSER [RFC3641]. Appendix A.3 provides an equivalent ABNF [ABNF]
|
||
grammar for this syntax.
|
||
|
||
|
||
2.8. CertificatePairAssertion
|
||
|
||
( IANA-ASSIGNED-OID.4 DESC 'X.509 Certificate Pair Assertion' )
|
||
|
||
A value of this syntax is an X.509 CertificatePairAssertion [X.509,
|
||
clause 11.3.4]. Values of this syntax MUST be encoded using GSER
|
||
[RFC3641]. Appendix A.4 provides an equivalent ABNF [ABNF] grammar
|
||
for this syntax.
|
||
|
||
|
||
2.9. CertificateListExactAssertion
|
||
|
||
( IANA-ASSIGNED-OID.5
|
||
DESC 'X.509 Certificate List Exact Assertion' )
|
||
|
||
A value of this syntax is an X.509 CertificateListExactAssertion
|
||
[X.509, clause 11.3.5]. Values of this syntax MUST be encoded using
|
||
GSER [RFC3641]. Appendix A.5 provides an equivalent ABNF grammar for
|
||
this syntax.
|
||
|
||
|
||
2.10. CertificateListAssertion
|
||
|
||
( IANA-ASSIGNED-OID.6 DESC 'X.509 Certificate List Assertion' )
|
||
|
||
A value of this syntax is an X.509 CertificateListAssertion [X.509,
|
||
clause 11.3.6]. Values of this syntax MUST be encoded using GSER
|
||
[RFC3641]. Appendix A.6 provides an equivalent ABNF [ABNF] grammar
|
||
for this syntax.
|
||
|
||
|
||
2.11 AlgorithmIdentifier
|
||
|
||
( IANA-ASSIGNED-OID.7 DESC 'X.509 Algorithm Identifier' )
|
||
|
||
A value of this syntax is an X.509 AlgorithmIdentifier [X.509, Clause
|
||
7]. Values of this syntax MUST be encoded using GSER [RFC3641].
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 5]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
Appendix A.7 provides an equivalent ABNF [ABNF] grammar for this
|
||
syntax.
|
||
|
||
|
||
3. Matching Rules
|
||
|
||
This section introduces a set of certificate and related matching
|
||
rules for use in LDAP. These rules are intended to act in accordance
|
||
with their X.500 counterparts.
|
||
|
||
|
||
3.1. certificateExactMatch
|
||
|
||
The certificateExactMatch matching rule compares the presented
|
||
certificate exact assertion value with an attribute value of the
|
||
certificate syntax as described in clause 11.3.1 of [X.509].
|
||
|
||
( 2.5.13.34 NAME 'certificateExactMatch'
|
||
DESC 'X.509 Certificate Exact Match'
|
||
SYNTAX IANA-ASSIGNED-OID.1 )
|
||
|
||
|
||
3.2. certificateMatch
|
||
|
||
The certificateMatch matching rule compares the presented certificate
|
||
assertion value with an attribute value of the certificate syntax as
|
||
described in clause 11.3.2 of [X.509].
|
||
|
||
( 2.5.13.35 NAME 'certificateMatch'
|
||
DESC 'X.509 Certificate Match'
|
||
SYNTAX IANA-ASSIGNED-OID.2 )
|
||
|
||
|
||
3.3. certificatePairExactMatch
|
||
|
||
The certificatePairExactMatch matching rule compares the presented
|
||
certificate pair exact assertion value with an attribute value of the
|
||
certificate pair syntax as described in clause 11.3.3 of [X.509].
|
||
|
||
( 2.5.13.36 NAME 'certificatePairExactMatch'
|
||
DESC 'X.509 Certificate Pair Exact Match'
|
||
SYNTAX IANA-ASSIGNED-OID.3 )
|
||
|
||
|
||
3.4. certificatePairMatch
|
||
|
||
The certificatePairMatch matching rule compares the presented
|
||
certificate pair assertion value with an attribute value of the
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 6]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
certificate pair syntax as described in clause 11.3.4 of [X.509].
|
||
|
||
( 2.5.13.37 NAME 'certificatePairMatch'
|
||
DESC 'X.509 Certificate Pair Match'
|
||
SYNTAX IANA-ASSIGNED-OID.4 )
|
||
|
||
|
||
3.5. certificateListExactMatch
|
||
|
||
The certificateListExactMatch matching rule compares the presented
|
||
certificate list exact assertion value with an attribute value of the
|
||
certificate pair syntax as described in clause 11.3.5 of [X.509].
|
||
|
||
( 2.5.13.38 NAME 'certificateListExactMatch'
|
||
DESC 'X.509 Certificate List Exact Match'
|
||
SYNTAX IANA-ASSIGNED-OID.5 )
|
||
|
||
|
||
3.6. certificateListMatch
|
||
|
||
The certificateListMatch matching rule compares the presented
|
||
certificate list assertion value with an attribute value of the
|
||
certificate pair syntax as described in clause 11.3.6 of [X.509].
|
||
|
||
( 2.5.13.39 NAME 'certificateListMatch'
|
||
DESC 'X.509 Certificate List Match'
|
||
SYNTAX IANA-ASSIGNED-OID.6 )
|
||
|
||
|
||
3.7. algorithmIdentifierMatch
|
||
|
||
The algorithmIdentifierMatch mating rule compares a presented
|
||
algorithm identifier with an attribute value of supported algorithm as
|
||
described in clause 11.3.7 of [X.509].
|
||
|
||
( 2.5.13.40 NAME 'algorithmIdentifier'
|
||
DESC 'X.509 Algorithm Identifier Match'
|
||
SYNTAX IANA-ASSIGNED-OID.7 )
|
||
|
||
|
||
4. Attribute Types
|
||
|
||
This section details a set of certificate and related attribute types
|
||
for use in LDAP.
|
||
|
||
|
||
4.1. userCertificate
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 7]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
The userCertificate attribute holds the X.509 certificates issued to
|
||
the user by one or more certificate authorities, as discussed in
|
||
clause 11.2.1 of [X.509].
|
||
|
||
( 2.5.4.36 NAME 'userCertificate'
|
||
DESC 'X.509 user certificate'
|
||
EQUALITY certificateExactMatch
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.8 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
are requested and transferred using the attribute description
|
||
"userCertificate;binary".
|
||
|
||
|
||
4.2. cACertificate
|
||
|
||
The cACertificate attribute holds the X.509 certificates issued to the
|
||
certificate authority (CA), as discussed in clause 11.2.2 of [X.509].
|
||
|
||
( 2.5.4.37 NAME 'cACertificate'
|
||
DESC 'X.509 CA certificate'
|
||
EQUALITY certificateExactMatch
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.8 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
are requested and transferred using the attribute description
|
||
"cACertificate;binary".
|
||
|
||
|
||
4.3. crossCertificatePair
|
||
|
||
The crossCertificatePair attribute holds an X.509 certificate pair, as
|
||
discussed in clause 11.2.3 of [X.509].
|
||
|
||
( 2.5.4.40 NAME 'crossCertificatePair'
|
||
DESC 'X.509 cross certificate pair'
|
||
EQUALITY certificatePairExactMatch
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.10 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
are requested and transferred using the attribute description
|
||
"crossCertificatePair;binary".
|
||
|
||
|
||
4.4. certificateRevocationList
|
||
|
||
The certificateRevocationList attribute holds certificate lists, as
|
||
discussed in 11.2.4 of [X.509].
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 8]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
( 2.5.4.39 NAME 'certificateRevocationList'
|
||
DESC 'X.509 certificate revocation list'
|
||
EQUALITY certificateListExactMatch
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.9 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
are requested and transferred using the attribute description
|
||
"certificateRevocationList;binary".
|
||
|
||
|
||
4.5. authorityRevocationList
|
||
|
||
The authorityRevocationList attribute holds certificate lists, as
|
||
discussed in 11.2.5 of [X.509].
|
||
|
||
( 2.5.4.38 NAME 'authorityRevocationList'
|
||
DESC 'X.509 authority revocation list'
|
||
EQUALITY certificateListExactMatch
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.9 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
are requested and transferred using the attribute description
|
||
"authorityRevocationList;binary".
|
||
|
||
|
||
4.6. deltaRevocationList
|
||
|
||
The deltaRevocationList attribute holds certificate lists, as
|
||
discussed in 11.2.6 of [X.509].
|
||
|
||
( 2.5.4.53 NAME 'deltaRevocationList'
|
||
DESC 'X.509 delta revocation list'
|
||
EQUALITY certificateListExactMatch
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.9 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
MUST be requested and transferred using the attribute description
|
||
"deltaRevocationList;binary".
|
||
|
||
|
||
4.7. supportedAlgorithms
|
||
|
||
The supportedAlgorithms attribute holds supported algorithms, as
|
||
discussed in 11.2.7 of [X.509].
|
||
|
||
( 2.5.4.52 NAME 'supportedAlgorithms'
|
||
DESC 'X.509 supported algorithms'
|
||
EQUALITY algorithmIdentifierMatch
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 9]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
SYNTAX 1.3.6.1.4.1.1466.115.121.1.49 )
|
||
|
||
As required by this attribute type's syntax, values of this attribute
|
||
MUST be requested and transferred using the attribute description
|
||
"supportedAlgorithms;binary".
|
||
|
||
|
||
5. Object Classes
|
||
|
||
This section details a set of certificate-related object classes for
|
||
use in LDAP.
|
||
|
||
|
||
5.1. pkiUser
|
||
|
||
This object class is used in augment entries for objects that may be
|
||
subject to certificates, as defined in clause 11.1.1 of [X.509].
|
||
|
||
( 2.5.6.21 NAME 'pkiUser'
|
||
DESC 'X.509 PKI User'
|
||
SUP top AUXILIARY
|
||
MAY userCertificate )
|
||
|
||
|
||
5.2. pkiCA
|
||
|
||
This object class is used to augment entries for objects which act as
|
||
certificate authorities, as defined in clause 11.1.2 of [X.509]
|
||
|
||
( 2.5.6.22 NAME 'pkiCA'
|
||
DESC 'X.509 PKI Certificate Authority'
|
||
SUP top AUXILIARY
|
||
MAY ( cACertificate $ certificateRevocationList $
|
||
authorityRevocationList $ crossCertificatePair ) )
|
||
|
||
|
||
5.3. cRLDistributionPoint
|
||
|
||
This class is used to represent objects which act as CRL distribution
|
||
points, as discussed in clause 11.1.3 of [X.509].
|
||
|
||
( 2.5.6.19 NAME 'cRLDistributionPoint'
|
||
DESC 'X.509 CRL distribution point'
|
||
SUP top STRUCTURAL
|
||
MUST cn
|
||
MAY ( certificateRevocationList $
|
||
authorityRevocationList $ deltaRevocationList ) )
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 10]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
5.4 deltaCRL
|
||
|
||
The deltaCRL object class is used to augment entries to hold delta
|
||
revocation lists, as discussed in clause 11.1.4 of [X.509].
|
||
|
||
( 2.5.6.23 NAME 'deltaCRL'
|
||
DESC 'X.509 delta CRL'
|
||
SUP top AUXILIARY
|
||
MAY deltaRevocationList )
|
||
|
||
|
||
5.5. strongAuthenticationUser
|
||
|
||
This object class is used to augment entries for objects participating
|
||
in certificate-based authentication, as defined in clause 6.15 of
|
||
[X.521]. This object class is deprecated in favor of pkiUser.
|
||
|
||
( 2.5.6.15 NAME 'strongAuthenticationUser'
|
||
DESC 'X.521 strong authentication user'
|
||
SUP top AUXILIARY
|
||
MUST userCertificate )
|
||
|
||
|
||
5.6. userSecurityInformation
|
||
|
||
This object class is used to augment entries with needed additional
|
||
associated security information, as defined in clause 6.16 of [X.521].
|
||
|
||
( 2.5.6.18 NAME 'userSecurityInformation'
|
||
DESC 'X.521 user security information'
|
||
SUP top AUXILIARY
|
||
MAY ( supportedAlgorithms ) )
|
||
|
||
|
||
5.7. certificationAuthority
|
||
|
||
This object class is used to augment entries for objects which act as
|
||
certificate authorities, as defined in clause 6.17 of [X.521]. This
|
||
object class is deprecated in favor of pkiCA.
|
||
|
||
( 2.5.6.16 NAME 'certificationAuthority'
|
||
DESC 'X.509 certificate authority'
|
||
SUP top AUXILIARY
|
||
MUST ( authorityRevocationList $
|
||
certificateRevocationList $ cACertificate )
|
||
MAY crossCertificatePair )
|
||
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 11]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
5.8. certificationAuthority-V2
|
||
|
||
This object class is used to augment entries for objects which act as
|
||
certificate authorities, as defined in clause 6.18 of [X.521]. This
|
||
object class is deprecated in favor of pkiCA.
|
||
|
||
( 2.5.6.16.2 NAME 'certificationAuthority-V2'
|
||
DESC 'X.509 certificate authority, version 2'
|
||
SUP certificationAuthority AUXILIARY
|
||
MAY deltaRevocationList )
|
||
|
||
|
||
6. Security Considerations
|
||
|
||
General certificate considerations [RFC3280] apply to LDAP-aware
|
||
certificate applications. General LDAP security considerations
|
||
[Roadmap] apply as well.
|
||
|
||
While elements of certificate information are commonly signed, these
|
||
signatures only protect the integrity of the signed information. In
|
||
the absence of a data integrity protections in LDAP (or lower layer,
|
||
e.g. IPsec), a server is not assured that client certificate request
|
||
(or other request) was unaltered in transit. Likewise, a client
|
||
cannot be assured that the results of the query were unaltered in
|
||
transit. Hence, it is generally recommended implementations make use
|
||
of authentication and data integrity services in LDAP
|
||
[AuthMeth][Protocol].
|
||
|
||
|
||
7. IANA Considerations
|
||
|
||
7.1. Object Identifier Registration
|
||
|
||
It is requested that IANA register upon Standards Action an LDAP
|
||
Object Identifier for use in this technical specification.
|
||
|
||
Subject: Request for LDAP OID Registration
|
||
Person & email address to contact for further information:
|
||
Kurt Zeilenga <kurt@OpenLDAP.org>
|
||
Specification: RFC XXXX
|
||
Author/Change Controller: IESG
|
||
Comments:
|
||
Identifies the LDAP X.509 Certificate schema elements
|
||
introduced in this document.
|
||
|
||
|
||
7.2. Registration of the descriptor
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 12]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
It is requested that IANA update upon Standards Action the LDAP
|
||
Descriptor registry as indicated below.
|
||
|
||
Subject: Request for LDAP Descriptor Registration
|
||
Descriptor (short name): see table
|
||
Object Identifier: see table
|
||
Person & email address to contact for further information:
|
||
Kurt Zeilenga <kurt@OpenLDAP.org>
|
||
Usage: see table
|
||
Specification: RFC XXXX
|
||
Author/Change Controller: IESG
|
||
|
||
algorithmIdentifierMatch R 2.5.13.40
|
||
authorityRevocationList A 2.5.4.38 *
|
||
cACertificate A 2.5.4.37 *
|
||
cRLDistributionPoint O 2.5.6.19 *
|
||
certificateExactMatch R 2.5.13.34
|
||
certificateListExactMatch R 2.5.13.38
|
||
certificateListMatch R 2.5.13.39
|
||
certificateMatch R 2.5.13.35
|
||
certificatePairExactMatch R 2.5.13.36
|
||
certificatePairMatch R 2.5.13.37
|
||
certificateRevocationList A 2.5.4.39 *
|
||
certificationAuthority O 2.5.6.16 *
|
||
certificationAuthority-V2 O 2.5.6.16.2 *
|
||
crossCertificatePair A 2.5.4.40 *
|
||
deltaCRL O 2.5.6.23 *
|
||
deltaRevocationList A 2.5.4.53 *
|
||
pkiCA O 2.5.6.22 *
|
||
pkiUser O 2.5.6.21 *
|
||
strongAuthenticationUser O 2.5.6.15 *
|
||
supportedAlgorithms A 2.5.4.52 *
|
||
userCertificate A 2.5.4.36 *
|
||
userSecurityInformation O 2.5.6.18 *
|
||
|
||
* Updates previous registration
|
||
|
||
|
||
8. Acknowledgments
|
||
|
||
This document is based upon X.509, a product of the ITU-T. A number
|
||
of LDAP schema definitions were based on those found in RFC 2252 and
|
||
RFC 2256, both products of the IETF ASID WG. The ABNF productions in
|
||
Appendix A were provided by Steven Legg. Additional material was
|
||
borrowed from prior works by David Chadwick and Steven Legg to refine
|
||
the LDAP X.509 schema.
|
||
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 13]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
9. Author's Address
|
||
|
||
Kurt D. Zeilenga
|
||
OpenLDAP Foundation
|
||
|
||
Email: Kurt@OpenLDAP.org
|
||
|
||
|
||
10. References
|
||
|
||
[[Note to the RFC Editor: please replace the citation tags used in
|
||
referencing Internet-Drafts with tags of the form RFCnnnn where
|
||
possible.]]
|
||
|
||
|
||
10.1. Normative References
|
||
|
||
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate
|
||
Requirement Levels", BCP 14 (also RFC 2119), March 1997.
|
||
|
||
[RFC3641] Legg, S., "Generic String Encoding Rules for ASN.1
|
||
Types", RFC 3641, October 2003.
|
||
|
||
[Roadmap] Zeilenga, K. (editor), "LDAP: Technical Specification
|
||
Road Map", draft-ietf-ldapbis-roadmap-xx.txt, a work in
|
||
progress.
|
||
|
||
[Models] Zeilenga, K. (editor), "LDAP: Directory Information
|
||
Models", draft-ietf-ldapbis-models-xx.txt, a work in
|
||
progress.
|
||
|
||
[Binary] Legg, S., "Lightweight Directory Access Protocol (LDAP):
|
||
The Binary Encoding Option",
|
||
draft-legg-ldap-binary-xx.txt, a work in progress.
|
||
|
||
[X.509] International Telecommunication Union -
|
||
Telecommunication Standardization Sector, "The
|
||
Directory: Authentication Framework", X.509(2000).
|
||
|
||
[X.521] International Telecommunication Union -
|
||
Telecommunication Standardization Sector, "The
|
||
Directory: Selected Object Classes", X.521(2000).
|
||
|
||
[X.680] International Telecommunication Union -
|
||
Telecommunication Standardization Sector, "Abstract
|
||
Syntax Notation One (ASN.1) - Specification of Basic
|
||
Notation", X.680(2002) (also ISO/IEC 8824-1:2002).
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 14]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
[X.690] International Telecommunication Union -
|
||
Telecommunication Standardization Sector, "Specification
|
||
of ASN.1 encoding rules: Basic Encoding Rules (BER),
|
||
Canonical Encoding Rules (CER), and Distinguished
|
||
Encoding Rules (DER)", X.690(2002) (also ISO/IEC
|
||
8825-1:2002).
|
||
|
||
|
||
11.2. Informative References
|
||
|
||
[ABNF] Crocker, D. and P. Overell, "Augmented BNF for Syntax
|
||
Specifications: ABNF", draft-crocker-abnf-rfc2234bis, a
|
||
work in progress.
|
||
|
||
[AuthMeth] Harrison, R. (editor), "LDAP: Authentication Methods and
|
||
Connection Level Security Mechanisms",
|
||
draft-ietf-ldapbis-authmeth-xx.txt, a work in progress.
|
||
|
||
[Protocol] Sermersheim, J. (editor), "LDAP: The Protocol",
|
||
draft-ietf-ldapbis-protocol-xx.txt, a work in progress.
|
||
|
||
[RFC2156] Kille, S., "MIXER (Mime Internet X.400 Enhanced Relay):
|
||
Mapping between X.400 and RFC 822/MIME", RFC 2156,
|
||
January 1998.
|
||
|
||
[RFC3280] Housley, R., Polk, W., Ford, W., and D. Solo, "Internet
|
||
X.509 Public Key Infrastructure Certificate and
|
||
Certificate Revocation List (CRL) Profile", RFC 3280,
|
||
April 2002.
|
||
|
||
[RFC3383] Zeilenga, K., "IANA Considerations for LDAP", BCP 64
|
||
(also RFC 3383), September 2002.
|
||
|
||
[RFC3642] Legg, S., "Common Elements of GSER Encodings", RFC 3642,
|
||
October 2003.
|
||
|
||
[RFC3687] Legg, S., "Lightweight Directory Access Protocol (LDAP)
|
||
and X.500 Component Matching Rules", RFC 3687, February
|
||
2004.
|
||
|
||
[BCP64bis] Zeilenga, K., "IANA Considerations for LDAP",
|
||
draft-ietf-ldapbis-bcp64-xx.txt, a work in progress.
|
||
|
||
|
||
Appendix A.
|
||
|
||
This appendix is informative.
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 15]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
This appendix provides ABNF [ABNF] grammars for GSER-based [RFC3687]
|
||
LDAP-specific encodings specified in this document. These grammars
|
||
where produced using, and relying on, Common Elements for GSER
|
||
Encodings [RFC3342].
|
||
|
||
|
||
A.1. CertificateExactAssertion
|
||
|
||
CertificateExactAssertion = "{" sp cea-serialNumber ","
|
||
sp cea-issuer sp "}"
|
||
|
||
cea-serialNumber = id-serialNumber msp CertificateSerialNumber
|
||
cea-issuer = id-issuer msp Name
|
||
|
||
id-serialNumber =
|
||
%x73.65.72.69.61.6C.4E.75.6D.62.65.72 ; 'serialNumber'
|
||
id-issuer = %x69.73.73.75.65.72 ; 'issuer'
|
||
|
||
Name = id-rdnSequence ":" RDNSequence
|
||
id-rdnSequence = %x72.64.6E.53.65.71.75.65.6E.63.65 ; 'rdnSequence'
|
||
|
||
CertificateSerialNumber = INTEGER
|
||
|
||
|
||
A.2. CertificateAssertion
|
||
|
||
CertificateAssertion = "{" [ sp ca-serialNumber ]
|
||
[ sep sp ca-issuer ]
|
||
[ sep sp ca-subjectKeyIdentifier ]
|
||
[ sep sp ca-authorityKeyIdentifier ]
|
||
[ sep sp ca-certificateValid ]
|
||
[ sep sp ca-privateKeyValid ]
|
||
[ sep sp ca-subjectPublicKeyAlgID ]
|
||
[ sep sp ca-keyUsage ]
|
||
[ sep sp ca-subjectAltName ]
|
||
[ sep sp ca-policy ]
|
||
[ sep sp ca-pathToName ]
|
||
[ sep sp ca-subject ]
|
||
[ sep sp ca-nameConstraints ] sp "}"
|
||
|
||
ca-serialNumber = id-serialNumber msp CertificateSerialNumber
|
||
ca-issuer = id-issuer msp Name
|
||
ca-subjectKeyIdentifier = id-subjectKeyIdentifier msp
|
||
SubjectKeyIdentifier
|
||
ca-authorityKeyIdentifier = id-authorityKeyIdentifier msp
|
||
AuthorityKeyIdentifier
|
||
ca-certificateValid = certificateValid msp Time
|
||
ca-privateKeyValid = id-privateKeyValid msp GeneralizedTime
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 16]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
ca-subjectPublicKeyAlgID = id-subjectPublicKeyAlgID msp
|
||
OBJECT-IDENTIFIER
|
||
ca-keyUsage = id-keyUsage msp KeyUsage
|
||
ca-subjectAltName = id-subjectAltName msp AltNameType
|
||
ca-policy = id-policy msp CertPolicySet
|
||
ca-pathToName = id-pathToName msp Name
|
||
ca-subject = id-subject msp Name
|
||
ca-nameConstraints = id-nameConstraints msp NameConstraintsSyntax
|
||
|
||
id-subjectKeyIdentifier =
|
||
%x73.75.62.6A.65.63.74.4B.65.79.49.64.65.6E.74.69.66.69.65.72
|
||
; 'subjectKeyIdentifier'
|
||
id-authorityKeyIdentifier =
|
||
%x61.75.74.68.6F.72.69.74.79.4B.65.79.49.64.65.6E.74.69.66.69.65.72
|
||
; 'authorityKeyIdentifier'
|
||
id-certificateValid = %x63.65.72.74.69.66.69.63.61.74.65.56.61.6C.69.64
|
||
; 'certificateValid'
|
||
id-privateKeyValid = %x70.72.69.76.61.74.65.4B.65.79.56.61.6C.69.64
|
||
; 'privateKeyValid'
|
||
id-subjectPublicKeyAlgID =
|
||
%x73.75.62.6A.65.63.74.50.75.62.6C.69.63.4B.65.79.41.6C.67.49.44
|
||
; 'subjectPublicKeyAlgID'
|
||
id-keyUsage = %x6B.65.79.55.73.61.67.65 ; 'keyUsage'
|
||
id-subjectAltName = %x73.75.62.6A.65.63.74.41.6C.74.4E.61.6D.65
|
||
; 'subjectAltName'
|
||
id-policy = %x70.6F.6C.69.63.79 ; 'policy'
|
||
id-pathToName = %x70.61.74.68.54.6F.4E.61.6D.65 ; 'pathToName'
|
||
id-subject = %x73.75.62.6A.65.63.74 ; 'subject'
|
||
id-nameConstraints = %x6E.61.6D.65.43.6F.6E.73.74.72.61.69.6E.74.73
|
||
; 'nameConstraints'
|
||
|
||
SubjectKeyIdentifier = KeyIdentifier
|
||
|
||
KeyIdentifier = OCTET-STRING
|
||
|
||
AuthorityKeyIdentifier = "{" [ sp aki-keyIdentifier ]
|
||
[ sep sp aki-authorityCertIssuer ]
|
||
[ sep sp aki-authorityCertSerialNumber ] sp "}"
|
||
|
||
aki-keyIdentifier = id-keyIdentifier msp KeyIdentifier
|
||
aki-authorityCertIssuer = id-authorityCertIssuer msp GeneralNames
|
||
|
||
GeneralNames = "{" sp GeneralName *( "," sp GeneralName ) sp "}"
|
||
GeneralName = gn-otherName
|
||
/ gn-rfc822Name
|
||
/ gn-dNSName
|
||
/ gn-x400Address
|
||
/ gn-directoryName
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 17]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
/ gn-ediPartyName
|
||
/ gn-uniformResourceIdentifier
|
||
/ gn-iPAddress
|
||
/ gn-registeredID
|
||
|
||
gn-otherName = id-otherName ":" OtherName
|
||
gn-rfc822Name = id-rfc822Name ":" IA5String
|
||
gn-dNSName = id-dNSName ":" IA5String
|
||
gn-x400Address = id-x400Address ":" ORAddress
|
||
gn-directoryName = id-directoryName ":" Name
|
||
gn-ediPartyName = id-ediPartyName ":" EDIPartyName
|
||
gn-iPAddress = id-iPAddress ":" OCTET-STRING
|
||
gn-registeredID = gn-id-registeredID ":" OBJECT-IDENTIFIER
|
||
|
||
gn-uniformResourceIdentifier = id-uniformResourceIdentifier
|
||
":" IA5String
|
||
|
||
id-otherName = %x6F.74.68.65.72.4E.61.6D.65 ; 'otherName'
|
||
gn-id-registeredID = %x72.65.67.69.73.74.65.72.65.64.49.44
|
||
; 'registeredID'
|
||
|
||
OtherName = "{" sp on-type-id "," sp on-value sp "}"
|
||
on-type-id = id-type-id msp OBJECT-IDENTIFIER
|
||
on-value = id-value msp Value
|
||
;; <Value> as defined in Section 8 of [RFC3786]
|
||
|
||
id-type-id = %x74.79.70.65.2D.69.64 ; 'type-id'
|
||
id-value = %x76.61.6C.75.65 ; 'value'
|
||
|
||
ORAddress = dquote *SafeIA5Character dquote
|
||
SafeIA5Character = %x01-21 / %x23-7F / ; ASCII minus dquote
|
||
dquote dquote ; escaped double quote
|
||
dquote = %x22 ; '"' (double quote)
|
||
|
||
;; Note: The <ORAddress> rule encodes the x400Address component
|
||
;; of a GeneralName as a character string between double quotes.
|
||
;; The character string is first derived according to Section 4.1
|
||
;; of [RFC2156], and then any embedded double quotes are escaped
|
||
;; by being repeated. This resulting string is output between
|
||
;; double quotes.
|
||
|
||
EDIPartyName = "{" [ sp nameAssigner "," ] sp partyName sp "}"
|
||
nameAssigner = id-nameAssigner msp DirectoryString
|
||
partyName = id-partyName msp DirectoryString
|
||
id-nameAssigner = %x6E.61.6D.65.41.73.73.69.67.6E.65.72
|
||
; 'nameAssigner'
|
||
id-partyName = %x70.61.72.74.79.4E.61.6D.65 ; 'partyName'
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 18]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
aki-authorityCertSerialNumber = id-authorityCertSerialNumber
|
||
msp CertificateSerialNumber
|
||
|
||
id-keyIdentifier = %x6B.65.79.49.64.65.6E.74.69.66.69.65.72
|
||
; 'keyIdentifier'
|
||
id-authorityCertIssuer =
|
||
%x61.75.74.68.6F.72.69.74.79.43.65.72.74.49.73.73.75.65.72
|
||
; 'authorityCertIssuer'
|
||
|
||
id-authorityCertSerialNumber = %x61.75.74.68.6F.72.69.74.79.43
|
||
%x65.72.74.53.65.72.69.61.6C.4E.75.6D.62.65.72
|
||
; 'authorityCertSerialNumber'
|
||
|
||
Time = time-utcTime / time-generalizedTime
|
||
time-utcTime = id-utcTime ":" UTCTime
|
||
time-generalizedTime = id-generalizedTime ":" GeneralizedTime
|
||
id-utcTime = %x75.74.63.54.69.6D.65 ; 'utcTime'
|
||
id-generalizedTime = %x67.65.6E.65.72.61.6C.69.7A.65.64.54.69.6D.65
|
||
; 'generalizedTime'
|
||
|
||
KeyUsage = BIT-STRING / key-usage-bit-list
|
||
key-usage-bit-list = "{" [ sp key-usage *( "," sp key-usage ) ] sp "}"
|
||
|
||
;; Note: The <key-usage-bit-list> rule encodes the one bits in
|
||
;; a KeyUsage value as a comma separated list of identifiers.
|
||
|
||
key-usage = id-digitalSignature
|
||
/ id-nonRepudiation
|
||
/ id-keyEncipherment
|
||
/ id-dataEncipherment
|
||
/ id-keyAgreement
|
||
/ id-keyCertSign
|
||
/ id-cRLSign
|
||
/ id-encipherOnly
|
||
/ id-decipherOnly
|
||
|
||
id-digitalSignature = %x64.69.67.69.74.61.6C.53.69.67.6E.61.74
|
||
%x75.72.65 ; 'digitalSignature'
|
||
id-nonRepudiation = %x6E.6F.6E.52.65.70.75.64.69.61.74.69.6F.6E
|
||
; 'nonRepudiation'
|
||
id-keyEncipherment = %x6B.65.79.45.6E.63.69.70.68.65.72.6D.65.6E.74
|
||
; 'keyEncipherment'
|
||
id-dataEncipherment = %x64.61.74.61.45.6E.63.69.70.68.65.72.6D.65.6E
|
||
%x74 ; "dataEncipherment'
|
||
id-keyAgreement = %x6B.65.79.41.67.72.65.65.6D.65.6E.74
|
||
; 'keyAgreement'
|
||
id-keyCertSign = %x6B.65.79.43.65.72.74.53.69.67.6E
|
||
; 'keyCertSign'
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 19]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
id-cRLSign = %x63.52.4C.53.69.67.6E ; "cRLSign"
|
||
id-encipherOnly = %x65.6E.63.69.70.68.65.72.4F.6E.6C.79
|
||
; 'encipherOnly'
|
||
id-decipherOnly = %x64.65.63.69.70.68.65.72.4F.6E.6C.79
|
||
; 'decipherOnly'
|
||
|
||
AltNameType = ant-builtinNameForm / ant-otherNameForm
|
||
|
||
ant-builtinNameForm = id-builtinNameForm ":" BuiltinNameForm
|
||
ant-otherNameForm = id-otherNameForm ":" OBJECT-IDENTIFIER
|
||
|
||
id-builtinNameForm = %x62.75.69.6C.74.69.6E.4E.61.6D.65.46.6F.72.6D
|
||
; 'builtinNameForm'
|
||
id-otherNameForm = %x6F.74.68.65.72.4E.61.6D.65.46.6F.72.6D
|
||
; 'otherNameForm'
|
||
|
||
BuiltinNameForm = id-rfc822Name
|
||
/ id-dNSName
|
||
/ id-x400Address
|
||
/ id-directoryName
|
||
/ id-ediPartyName
|
||
/ id-uniformResourceIdentifier
|
||
/ id-iPAddress
|
||
/ id-registeredId
|
||
|
||
id-rfc822Name = %x72.66.63.38.32.32.4E.61.6D.65 ; 'rfc822Name'
|
||
id-dNSName = %x64.4E.53.4E.61.6D.65 ; 'dNSName'
|
||
id-x400Address = %x78.34.30.30.41.64.64.72.65.73.73 ; 'x400Address'
|
||
id-directoryName = %x64.69.72.65.63.74.6F.72.79.4E.61.6D.65
|
||
; 'directoryName'
|
||
id-ediPartyName = %x65.64.69.50.61.72.74.79.4E.61.6D.65
|
||
; 'ediPartyName'
|
||
id-iPAddress = %x69.50.41.64.64.72.65.73.73 ; 'iPAddress'
|
||
id-registeredId = %x72.65.67.69.73.74.65.72.65.64.49.64
|
||
; 'registeredId'
|
||
|
||
id-uniformResourceIdentifier = %x75.6E.69.66.6F.72.6D.52.65.73.6F.75
|
||
%x72.63.65.49.64.65.6E.74.69.66.69.65.72
|
||
; 'uniformResourceIdentifier'
|
||
|
||
CertPolicySet = "{" sp CertPolicyId *( "," sp CertPolicyId ) sp "}"
|
||
CertPolicyId = OBJECT-IDENTIFIER
|
||
|
||
NameConstraintsSyntax = "{" [ sp ncs-permittedSubtrees ]
|
||
[ sep sp ncs-excludedSubtrees ] sp "}"
|
||
|
||
ncs-permittedSubtrees = id-permittedSubtrees msp GeneralSubtrees
|
||
ncs-excludedSubtrees = id-excludedSubtrees msp GeneralSubtrees
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 20]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
id-permittedSubtrees =
|
||
%x70.65.72.6D.69.74.74.65.64.53.75.62.74.72.65.65.73
|
||
; 'permittedSubtrees'
|
||
id-excludedSubtrees =
|
||
%x65.78.63.6C.75.64.65.64.53.75.62.74.72.65.65.73
|
||
; 'excludedSubtrees'
|
||
|
||
GeneralSubtrees = "{" sp GeneralSubtree
|
||
*( "," sp GeneralSubtree ) sp "}"
|
||
GeneralSubtree = "{" sp gs-base
|
||
[ "," sp gs-minimum ]
|
||
[ "," sp gs-maximum ] sp "}"
|
||
|
||
gs-base = id-base msp GeneralName
|
||
gs-minimum = id-minimum msp BaseDistance
|
||
gs-maximum = id-maximum msp BaseDistance
|
||
|
||
id-base = %x62.61.73.65 ; 'base'
|
||
id-minimum = %x6D.69.6E.69.6D.75.6D ; 'minimum'
|
||
id-maximum = %x6D.61.78.69.6D.75.6D ; 'maximum'
|
||
|
||
BaseDistance = INTEGER-0-MAX
|
||
|
||
|
||
A.3. CertificatePairExactAssertion
|
||
|
||
CertificatePairExactAssertion = "{" [ sp cpea-issuedTo ]
|
||
[sep sp cpea-issuedBy ] sp "}"
|
||
;; At least one of <cpea-issuedTo> or <cpea-issuedBy> MUST be present.
|
||
|
||
cpea-issuedTo = id-issuedToThisCAAssertion msp
|
||
CertificateExactAssertion
|
||
cpea-issuedBy = id-issuedByThisCAAssertion msp
|
||
CertificateExactAssertion
|
||
|
||
id-issuedToThisCAAssertion = %x69.73.73.75.65.64.54.6F.54.68.69.73
|
||
%x43.41.41.73.73.65.72.74.69.6F.6E ; 'issuedToThisCAAssertion'
|
||
id-issuedByThisCAAssertion = %x69.73.73.75.65.64.42.79.54.68.69.73
|
||
%x43.41.41.73.73.65.72.74.69.6F.6E ; 'issuedByThisCAAssertion'
|
||
|
||
|
||
A.4. CertificatePairAssertion
|
||
|
||
CertificatePairAssertion = "{" [ sp cpa-issuedTo ]
|
||
[sep sp cpa-issuedBy ] sp "}"
|
||
;; At least one of <cpa-issuedTo> and <cpa-issuedBy> MUST be present.
|
||
|
||
cpa-issuedTo = id-issuedToThisCAAssertion msp CertificateAssertion
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 21]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
cpa-issuedBy = id-issuedByThisCAAssertion msp CertificateAssertion
|
||
|
||
|
||
A.5. CertificateListExactAssertion
|
||
|
||
CertificateListExactAssertion = "{" sp clea-issuer ","
|
||
sp clea-thisUpdate
|
||
[ "," sp clea-distributionPoint ] sp "}"
|
||
|
||
clea-issuer = id-issuer msp Name
|
||
clea-thisUpdate = id-thisUpdate msp Time
|
||
clea-distributionPoint = id-distributionPoint msp
|
||
DistributionPointName
|
||
|
||
id-thisUpdate = %x74.68.69.73.55.70.64.61.74.65 ; 'thisUpdate'
|
||
id-distributionPoint =
|
||
%x64.69.73.74.72.69.62.75.74.69.6F.6E.50.6F.69.6E.74
|
||
; 'distributionPoint'
|
||
|
||
DistributionPointName = dpn-fullName / dpn-nameRelativeToCRLIssuer
|
||
|
||
dpn-fullName = id-fullName ":" GeneralNames
|
||
dpn-nameRelativeToCRLIssuer = id-nameRelativeToCRLIssuer ":"
|
||
RelativeDistinguishedName
|
||
|
||
id-fullName = %x66.75.6C.6C.4E.61.6D.65 ; 'fullName'
|
||
id-nameRelativeToCRLIssuer = %x6E.61.6D.65.52.65.6C.61.74.69.76.65
|
||
%x54.6F.43.52.4C.49.73.73.75.65.72 ; 'nameRelativeToCRLIssuer'
|
||
|
||
|
||
A.6. CertificateListAssertion
|
||
|
||
CertificateListAssertion = "{" [ sp cla-issuer ]
|
||
[ sep sp cla-minCRLNumber ]
|
||
[ sep sp cla-maxCRLNumber ]
|
||
[ sep sp cla-reasonFlags ]
|
||
[ sep sp cla-dateAndTime ]
|
||
[ sep sp cla-distributionPoint ]
|
||
[ sep sp cla-authorityKeyIdentifier ] sp "}"
|
||
|
||
cla-issuer = id-issuer msp Name
|
||
cla-minCRLNumber = id-minCRLNumber msp CRLNumber
|
||
cla-maxCRLNumber = id-maxCRLNumber msp CRLNumber
|
||
cla-reasonFlags = id-reasonFlags msp ReasonFlags
|
||
cla-dateAndTime = id-dateAndTime msp Time
|
||
|
||
cla-distributionPoint = id-distributionPoint msp
|
||
DistributionPointName
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 22]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
cla-authorityKeyIdentifier = id-authorityKeyIdentifier msp
|
||
AuthorityKeyIdentifier
|
||
|
||
id-minCRLNumber = %x6D.69.6E.43.52.4C.4E.75.6D.62.65.72
|
||
; 'minCRLNumber'
|
||
id-maxCRLNumber = %x6D.61.78.43.52.4C.4E.75.6D.62.65.72
|
||
; 'maxCRLNumber'
|
||
id-reasonFlags = %x72.65.61.73.6F.6E.46.6C.61.67.73 ; 'reasonFlags'
|
||
id-dateAndTime = %x64.61.74.65.41.6E.64.54.69.6D.65 ; 'dateAndTime'
|
||
|
||
CRLNumber = INTEGER-0-MAX
|
||
|
||
ReasonFlags = BIT-STRING
|
||
/ "{" [ sp reason-flag *( "," sp reason-flag ) ] sp "}"
|
||
|
||
reason-flag = id-unused
|
||
/ id-keyCompromise
|
||
/ id-cACompromise
|
||
/ id-affiliationChanged
|
||
/ id-superseded
|
||
/ id-cessationOfOperation
|
||
/ id-certificateHold
|
||
/ id-privilegeWithdrawn
|
||
/ id-aACompromise
|
||
|
||
id-unused = %x75.6E.75.73.65.64 ; 'unused'
|
||
id-keyCompromise = %x6B.65.79.43.6F.6D.70.72.6F.6D.69.73.65
|
||
; 'keyCompromise'
|
||
id-cACompromise = %x63.41.43.6F.6D.70.72.6F.6D.69.73.65
|
||
; 'cACompromise'
|
||
id-affiliationChanged =
|
||
%x61.66.66.69.6C.69.61.74.69.6F.6E.43.68.61.6E.67.65.64
|
||
; 'affiliationChanged'
|
||
id-superseded = %x73.75.70.65.72.73.65.64.65.64 ; 'superseded'
|
||
id-cessationOfOperation =
|
||
%x63.65.73.73.61.74.69.6F.6E.4F.66.4F.70.65.72.61.74.69.6F.6E
|
||
; 'cessationOfOperation'
|
||
id-certificateHold = %x63.65.72.74.69.66.69.63.61.74.65.48.6F.6C.64
|
||
; 'certificateHold'
|
||
id-privilegeWithdrawn =
|
||
%x70.72.69.76.69.6C.65.67.65.57.69.74.68.64.72.61.77.6E
|
||
; 'privilegeWithdrawn'
|
||
id-aACompromise = %x61.41.43.6F.6D.70.72.6F.6D.69.73.65
|
||
; 'aACompromise'
|
||
|
||
|
||
A.7. AlgorithmIdentifier
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 23]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
AlgorithmIdentifier = "{" sp ai-algorithm
|
||
[ "," sp ai-parameters ] sp "}"
|
||
|
||
ai-algorithm = id-algorithm msp OBJECT-IDENTIFIER
|
||
ai-parameters = id-parameters msp Value
|
||
id-algorithm = %x61.6C.67.6F.72.69.74.68.6D ; 'algorithm'
|
||
id-parameters = %x70.61.72.61.6D.65.74.65.72.73 ; 'parameters'
|
||
|
||
|
||
|
||
Intellectual Property Rights
|
||
|
||
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.
|
||
|
||
|
||
|
||
Full Copyright
|
||
|
||
Copyright (C) The Internet Society (2005).
|
||
|
||
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,
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 24]
|
||
|
||
INTERNET-DRAFT LDAP X.509 Schema 18 July 2005
|
||
|
||
|
||
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.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Zeilenga draft-zeilenga-ldap-x509-02 [Page 25]
|
||
|