mirror of
https://git.openldap.org/openldap/openldap.git
synced 2024-12-09 02:52:04 +08:00
284 lines
8.6 KiB
Plaintext
284 lines
8.6 KiB
Plaintext
|
||
|
||
|
||
|
||
|
||
|
||
Network Working Group M. Smith
|
||
Request for Comments: 2079 Netscape Communications
|
||
Category: Standards Track January 1997
|
||
|
||
|
||
Definition of an X.500 Attribute Type and an Object Class to Hold
|
||
Uniform Resource Identifiers (URIs)
|
||
|
||
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.
|
||
|
||
Abstract
|
||
|
||
Uniform Resource Locators (URLs) are being widely used to specify the
|
||
location of Internet resources. There is an urgent need to be able
|
||
to include URLs in directories that conform to the LDAP and X.500
|
||
information models, and a desire to include other types of Uniform
|
||
Resource Identifiers (URIs) as they are defined. A number of
|
||
independent groups are already experimenting with the inclusion of
|
||
URLs in LDAP and X.500 directories. This document builds on the
|
||
experimentation to date and defines a new attribute type and an
|
||
auxiliary object class to allow URIs, including URLs, to be stored in
|
||
directory entries in a standard way.
|
||
|
||
Background and Intended Usage
|
||
|
||
Uniform Resource Locators (URLs) as defined by [1] are the first of
|
||
several types of Uniform Resource Identifiers (URIs) being defined by
|
||
the IETF. URIs are widely used on the Internet, most notably within
|
||
Hypertext Markup Language [2] documents. This document defines an
|
||
X.500 [3,4] attribute type called labeledURI and an auxiliary object
|
||
class called labeledURIObject to hold all types of URIs, including
|
||
URLs. These definitions are designed for use in LDAP and X.500
|
||
directories, and may be used in other contexts as well.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Smith Standards Track [Page 1]
|
||
|
||
RFC 2079 URI Attribute Type and Object Class January 1997
|
||
|
||
|
||
Schema Definition of the labeledURI Attribute Type
|
||
|
||
Name: labeledURI
|
||
ShortName: None
|
||
Description: Uniform Resource Identifier with optional label
|
||
OID: umichAttributeType.57 (1.3.6.1.4.1.250.1.57)
|
||
Syntax: caseExactString
|
||
SizeRestriction: None
|
||
SingleValued: False
|
||
|
||
Discussion of the labeledURI Attribute Type
|
||
|
||
The labeledURI attribute type has the caseExactString syntax (since
|
||
URIs are case-sensitive) and it is multivalued. Values placed in the
|
||
attribute should consist of a URI (at the present time, a URL)
|
||
optionally followed by one or more space characters and a label.
|
||
Since space characters are not allowed to appear un-encoded in URIs,
|
||
there is no ambiguity about where the label begins. At the present
|
||
time, the URI portion must comply with the URL specification [1].
|
||
Multiple labeledURI values will generally indicate different
|
||
resources that are all related to the X.500 object, but may indicate
|
||
different locations for the same resource.
|
||
|
||
The label is used to describe the resource to which the URI points,
|
||
and is intended as a friendly name fit for human consumption. This
|
||
document does not propose any specific syntax for the label part. In
|
||
some cases it may be helpful to include in the label some indication
|
||
of the kind and/or size of the resource referenced by the URI.
|
||
|
||
Note that the label may include any characters allowed by the
|
||
caseExactString syntax, but that the use of non-IA5 (non-ASCII)
|
||
characters is discouraged as not all directory clients may handle
|
||
them in the same manner. If non-IA5 characters are included, they
|
||
should be represented using the X.500 conventions, not the HTML
|
||
conventions (e.g., the character that is an "a" with a ring above it
|
||
should be encoded using the T.61 sequence 0xCA followed by an "a"
|
||
character; do not use the HTML escape sequence "å").
|
||
|
||
Examples of labeledURI Attribute Values
|
||
|
||
An example of a labeledURI attribute value that does not include a
|
||
label:
|
||
|
||
ftp://ds.internic.net/rfc/rfc822.txt
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Smith Standards Track [Page 2]
|
||
|
||
RFC 2079 URI Attribute Type and Object Class January 1997
|
||
|
||
|
||
An example of a labeledURI attribute value that contains a tilde
|
||
character in the URL (special characters in a URL must be encoded as
|
||
specified by the URL document [1]). The label is "LDAP Home Page":
|
||
|
||
http://www.umich.edu/%7Ersug/ldap/ LDAP Home Page
|
||
|
||
Another example. This one includes a hint in the label to help the
|
||
user realize that the URL points to a photo image.
|
||
|
||
http://champagne.inria.fr/Unites/rennes.gif Rennes [photo]
|
||
|
||
Schema Definition of the labeledURIObject Object Class
|
||
|
||
Name: labeledURIObject
|
||
Description: object that contains the URI attribute type
|
||
OID: umichObjectClass.15 (1.3.6.1.4.1.250.3.15)
|
||
SubclassOf: top
|
||
MustContain:
|
||
MayContain: labeledURI
|
||
|
||
Discussion of the labeledURIObject Object Class
|
||
|
||
The labeledURIObject class is a subclass of top and may contain the
|
||
labeledURI attribute. The intent is that this object class can be
|
||
added to existing directory objects to allow for inclusion of URI
|
||
values. This approach does not preclude including the labeledURI
|
||
attribute type directly in other object classes as appropriate.
|
||
|
||
Security Considerations
|
||
|
||
Security considerations are not discussed in this memo, except to
|
||
note that blindly inserting the label portion of a labeledURI
|
||
attribute value into an HTML document is not recommended, as this may
|
||
allow a malicious individual to include HTML tags in the label that
|
||
mislead viewers of the entire document in which the labeledURI value
|
||
was inserted.
|
||
|
||
Acknowledgments
|
||
|
||
Paul-Andre Pays, Martijn Koster, Tim Howes, Rakesh Patel, Russ
|
||
Wright, and Hallvard Furuseth provided invaluable assistance in the
|
||
creation of this document.
|
||
|
||
This material is based in part upon work supported by the National
|
||
Science Foundation under Grant No. NCR-9416667.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Smith Standards Track [Page 3]
|
||
|
||
RFC 2079 URI Attribute Type and Object Class January 1997
|
||
|
||
|
||
Appendix: The labeledURL Attribute Type (Deprecated)
|
||
|
||
An earlier draft of this document defined an additional attribute
|
||
type called labeledURL. This attribute type is deprecated, and
|
||
should not be used when adding new values to directory entries. The
|
||
original motivation for including a separate attribute type to hold
|
||
URLs was that this would better enable efficient progammatic access
|
||
to specific types of URIs. After some deliberation, the IETF-ASID
|
||
working group concluded that it was better to simply have one
|
||
attribute than two.
|
||
|
||
The schema definition for labeledURL is included here for historical
|
||
reference only. Directory client software may want to support this
|
||
schema definition (in addition to labeledURI) to ease the transition
|
||
away from labeledURL for those sites that are using it.
|
||
|
||
Name: labeledURL
|
||
ShortName: None
|
||
Description: Uniform Resource Locator with optional label
|
||
OID: umichAttributeType.41 (1.3.6.1.4.1.250.1.41)
|
||
Syntax: caseExactString
|
||
SizeRestriction: None
|
||
SingleValued: False
|
||
OID: umichAttributeType.41 (1.3.6.1.4.1.250.1.41)
|
||
|
||
References
|
||
|
||
[1] Berners-Lee, T., Masinter, L., and M. McCahill, "Uniform
|
||
Resource Locators (URL)", RFC 1738, CERN, Xerox Corporation,
|
||
University of Minnesota, December 1994.
|
||
<URL:ftp://ds.internic.net/rfc/rfc1738.txt>
|
||
|
||
[2] Berners-Lee, T., and D. Connolly, "Hypertext Markup Language -
|
||
2.0", RFC 1866, <URL:ftp://ds.internic.net/rfc/rfc1866.txt>
|
||
|
||
[3] The Directory: Overview of Concepts, Models and Service. CCITT
|
||
Recommendation X.500, 1988.
|
||
|
||
[4] Information Processing Systems -- Open Systems Interconnection --
|
||
The Directory: Overview of Concepts, Models and Service. ISO/IEC JTC
|
||
1/SC21; International Standard 9594-1, 1988.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Smith Standards Track [Page 4]
|
||
|
||
RFC 2079 URI Attribute Type and Object Class January 1997
|
||
|
||
|
||
Author's Address
|
||
|
||
Mark Smith
|
||
Netscape Communications Corp.
|
||
501 E. Middlefield Rd.
|
||
Mountain View, CA 94043, USA
|
||
|
||
Phone: +1 415 937-3477
|
||
EMail: mcs@netscape.com
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Smith Standards Track [Page 5]
|
||
|