mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
1516 lines
54 KiB
Plaintext
1516 lines
54 KiB
Plaintext
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Network Working Group J. Kempf
|
|||
|
Request for Comments: 2926 Sun Microsystems, Inc.
|
|||
|
Category: Informational R. Moats
|
|||
|
Coreon, Inc.
|
|||
|
P. St. Pierre
|
|||
|
Sun Microsystems, Inc.
|
|||
|
September 2000
|
|||
|
|
|||
|
|
|||
|
Conversion of LDAP Schemas to and from SLP Templates
|
|||
|
|
|||
|
Status of this Memo
|
|||
|
|
|||
|
This memo provides information for the Internet community. It does
|
|||
|
not specify an Internet standard of any kind. Distribution of this
|
|||
|
memo is unlimited.
|
|||
|
|
|||
|
Copyright Notice
|
|||
|
|
|||
|
Copyright (C) The Internet Society (2000). All Rights Reserved.
|
|||
|
|
|||
|
Abstract
|
|||
|
|
|||
|
This document describes a procedure for mapping between Service
|
|||
|
Location Protocol (SLP) service advertisements and lightweight
|
|||
|
directory access protocol (LDAP) descriptions of services. The
|
|||
|
document covers two aspects of the mapping. One aspect is mapping
|
|||
|
between SLP service type templates and LDAP directory schema.
|
|||
|
Because the SLP service type template grammar is relatively simple,
|
|||
|
mapping from service type templates to LDAP types is straightforward.
|
|||
|
Mapping in the other direction is straightforward if the attributes
|
|||
|
are restricted to use just a few of the syntaxes defined in RFC 2252.
|
|||
|
If arbitrary ASN.1 types occur in the schema, then the mapping is
|
|||
|
more complex and may even be impossible. The second aspect is
|
|||
|
representation of service information in an LDAP directory. The
|
|||
|
recommended representation simplifies interoperability with SLP by
|
|||
|
allowing SLP directory agents to backend into LDAP directory servers.
|
|||
|
The resulting system allows service advertisements to propagate
|
|||
|
easily between SLP and LDAP.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 1]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
Table of Contents
|
|||
|
|
|||
|
1.0 Introduction ................................................ 2
|
|||
|
2.0 Mapping SLP Templates to LDAP Schema ........................ 3
|
|||
|
2.1 Mapping from SLP Attribute Types to LDAP Attribute Types .. 8
|
|||
|
2.1.1 Integer ............................................... 8
|
|||
|
2.1.2 String ................................................ 8
|
|||
|
2.1.3 Boolean ............................................... 9
|
|||
|
2.1.4 Opaque ................................................ 9
|
|||
|
2.2 Keyword Attributes ........................................ 9
|
|||
|
2.3 Template Flags ............................................ 9
|
|||
|
2.3.1 Multi-valued .......................................... 9
|
|||
|
2.3.2 Optional .............................................. 10
|
|||
|
2.3.3 Literal ............................................... 10
|
|||
|
2.3.4 Explicit Matching ..................................... 10
|
|||
|
2.4 Default and Allowed Value Lists ........................... 10
|
|||
|
2.5 Descriptive Text .......................................... 11
|
|||
|
2.6 Generating LDAP Attribute OIDs ............................ 11
|
|||
|
2.7 Example ................................................... 11
|
|||
|
3.0 Attribute Name Conflicts .................................... 15
|
|||
|
4.0 Mapping from Schema to Templates ............................ 15
|
|||
|
4.1 Mapping LDAP Attribute Types to SLP Attribute Types ....... 16
|
|||
|
4.2 Mapping ASN.1 Types to SLP Types .......................... 17
|
|||
|
4.2.1 Integer ............................................... 18
|
|||
|
4.2.2 Boolean ............................................... 18
|
|||
|
4.2.3 Enumerated ............................................ 18
|
|||
|
4.2.4 Object Identifier ..................................... 19
|
|||
|
4.2.5 Octet String .......................................... 19
|
|||
|
4.2.6 Real .................................................. 19
|
|||
|
4.3 Example ASN.1 Schema ...................................... 19
|
|||
|
5.0 Representing SLP Service Advertisements in an LDAP DIT ...... 22
|
|||
|
6.0 Internationalization Considerations ......................... 24
|
|||
|
7.0 Security Considerations ..................................... 24
|
|||
|
8.0 References .................................................. 25
|
|||
|
9.0 Authors' Addresses .......................................... 26
|
|||
|
10.0 Full Copyright Statement ................................... 27
|
|||
|
|
|||
|
1.0 Introduction
|
|||
|
|
|||
|
SLP templates [1] are intended to create a simple encoding of the
|
|||
|
syntactic and semantic conventions for individual service types,
|
|||
|
their attributes, and conventions. They can easily be generated,
|
|||
|
transmitted, read by humans and parsed by programs, as it is a string
|
|||
|
based syntax with required comments. Directory schemas serve to
|
|||
|
formalize directory entry structures for use with LDAP [2] These
|
|||
|
directories serve to store information about many types of entities.
|
|||
|
Network services are an example of one such entity.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 2]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
Interoperability between SLP and LDAP is important so clients using
|
|||
|
one protocol derive benefit from services registered through the
|
|||
|
other. In addition, LDAP directory servers can serve as the backend
|
|||
|
for SLP directory agents (DAs) if interoperability is possible In
|
|||
|
order to facilitate interoperability, this document creates mappings
|
|||
|
between the SLP template grammar and LDAP directory schema, and
|
|||
|
establishes some conventions for representing service advertisements
|
|||
|
in LDAP directories. The goal of the translation is to allow SLPv2
|
|||
|
queries (which are syntactically and semantically equivalent to
|
|||
|
LDAPv3 string queries [7]) to be submitted to an LDAP directory
|
|||
|
server by an SLP DA backended into LDAP without extensive processing
|
|||
|
by the DA.
|
|||
|
|
|||
|
The simple notation and syntactic/semantic attribute capabilities of
|
|||
|
SLP templates map easily into directory schemas, and are easily
|
|||
|
converted into directory schemas, even by automated means. The
|
|||
|
reverse may not be true. If the LDAP schema contains attributes with
|
|||
|
unrecognized or complex syntaxes, the translation may be difficult or
|
|||
|
impossible. If, however, the LDAP schema only uses a few of the
|
|||
|
common syntaxes defined in RFC 2252 [8], then the translation is more
|
|||
|
straightforward. In addition, to foster complete bidirectionality,
|
|||
|
the mapping must follow a very specific representation in its DESC
|
|||
|
attributes.
|
|||
|
|
|||
|
This document outlines the correct mappings for SLP templates into
|
|||
|
the syntactic representation specified for LDAP directory schema by
|
|||
|
RFC 2252 [8]. This syntax is a subset of the ASN.1/BER described in
|
|||
|
the X.209 specification [9], and is used by the LDAPv3 [2] directory
|
|||
|
schema. Likewise, rules and guidelines are proposed to facilitate
|
|||
|
consistent mapping of ASN.1 based schemas to be translated in the SLP
|
|||
|
template grammar. Finally, a proposal for a representation of service
|
|||
|
advertisements in LDAP directory services is made that facilitates
|
|||
|
SLP interoperability.
|
|||
|
|
|||
|
Except when used as elements in the definition of LDAP schemas, 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 RFC 2119 [16].
|
|||
|
|
|||
|
2.0 Mapping SLP Templates to LDAP Schema
|
|||
|
|
|||
|
We define the following abstract object class as the parent class for
|
|||
|
all services. Any specific service type is a subclass of this, with
|
|||
|
its own attributes:
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 3]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.2.1
|
|||
|
NAME 'slpService'
|
|||
|
DESC 'parent superclass for SLP services'
|
|||
|
ABSTRACT
|
|||
|
SUP top
|
|||
|
MUST ( template-major-version-number $
|
|||
|
template-minor-version-number $
|
|||
|
description $
|
|||
|
template-url-syntax $
|
|||
|
service-advert-service-type $
|
|||
|
service-advert-scopes )
|
|||
|
MAY ( service-advert-url-authenticator $
|
|||
|
service-advert-attribute-authenticator ) )
|
|||
|
|
|||
|
The attributes correspond to various parts of the SLP service
|
|||
|
template and SLP service advertisement.
|
|||
|
|
|||
|
SLP service type templates begin with four definitions that set the
|
|||
|
context of the template:
|
|||
|
|
|||
|
template-type - This defines the service type of the template. The
|
|||
|
service type can be a simple service type, like "service:ftp", an
|
|||
|
abstract service type, like "service:printer" or a concrete
|
|||
|
service type, like "service:printer:lpr". The type name can
|
|||
|
additionally include a naming authority, for example
|
|||
|
"service:printer.sun:local". The name that appears in this field
|
|||
|
omits the "service:" prefix.
|
|||
|
|
|||
|
template-version - A string containing a major and minor version
|
|||
|
number, separated by a period.
|
|||
|
|
|||
|
template-description - A block of human readable text describing
|
|||
|
what the service type does.
|
|||
|
|
|||
|
template-url-syntax - An ABNF [6] grammar describing the service
|
|||
|
type specific part of the service URL.
|
|||
|
|
|||
|
The SLP template-type definition is used as the name of the LDAP
|
|||
|
object class for the template, a subclass of the "slpService" class,
|
|||
|
together with the "service" prefix to indicate that the name is for a
|
|||
|
service. In the translating service type name, colons and the period
|
|||
|
separating the naming authority are converted into hyphens. If the
|
|||
|
template defines an SLP concrete type, the concrete type name is
|
|||
|
used; the abstract type name is never used. For example, the
|
|||
|
template for "service:printer:lpr" is translated into an LDAP object
|
|||
|
class called "service-printer-lpr". Furthermore, if the type name
|
|||
|
contains a naming authority, the naming authority name must be
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 4]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
included. For example, the service type name
|
|||
|
"service:printer.sun:local" becomes "service-printer-sun-local". The
|
|||
|
LDAP object class is always "STRUCTURAL".
|
|||
|
|
|||
|
The template-version definition is partitioned into two attributes,
|
|||
|
template-major-version-number and template-minor-version-number. The
|
|||
|
LDAP definition for these attributes is:
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.1
|
|||
|
NAME 'template-major-version-number'
|
|||
|
DESC 'The major version number of the service type template'
|
|||
|
EQUALITY integerMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.27
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.2
|
|||
|
NAME 'template-minor-version-number'
|
|||
|
DESC 'The minor version number of the service type template'
|
|||
|
EQUALITY integerMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.27
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
The template-url-syntax definition in the SLP template is described
|
|||
|
by the following attribute:
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.3
|
|||
|
NAME 'template-url-syntax'
|
|||
|
DESC 'An ABNF grammar describing the service type
|
|||
|
specific part of the service URL'
|
|||
|
EQUALITY caseExactIA5Match
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.26
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
The template-description attribute is translated into the X.520
|
|||
|
standard attribute "description" [3].
|
|||
|
|
|||
|
We further establish the convention that SLP template characteristics
|
|||
|
that can't be translated into LDAP are inserted into the DESC field
|
|||
|
of the object class definition. The items are separated by empty
|
|||
|
lines (consisting of two "LINE FEED" characters), are preceded by a
|
|||
|
LINE FEED character, and are tagged at the beginning of the line to
|
|||
|
indicate what they represent. This allows the template to be
|
|||
|
reconstructed from the schema by properly parsing the comments.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 5]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
The bulk of an SLP template consists of attribute definitions. There
|
|||
|
are four items in an SLP template attribute definition that need to
|
|||
|
be mapped into LDAP:
|
|||
|
|
|||
|
Attribute Name - Since SLPv2 attribute names are defined to be
|
|||
|
compatible with LDAPv3, SLP attributes map directly into LDAP
|
|||
|
attributes with no change. Similarly, LDAP attributes map directly
|
|||
|
to SLP attributes.
|
|||
|
|
|||
|
Attribute Type - The SLP attribute type is mapped into the LDAP
|
|||
|
attribute type.
|
|||
|
|
|||
|
Attribute Flags - The SLP attribute flags are mapped into
|
|||
|
characteristics of the LDAP attribute definition, or into the DESC
|
|||
|
field if no equivalent LDAP attribute definition characteristic
|
|||
|
occurs.
|
|||
|
|
|||
|
Default and Allowed Values - These must be handled by the client
|
|||
|
or a DA enabled to handle templates, as in SLP. For reference,
|
|||
|
however, they should be included in the DESC field of the LDAP
|
|||
|
attribute definition.
|
|||
|
|
|||
|
Descriptive Text - The SLP template descriptive text should be
|
|||
|
mapped into the DESC field.
|
|||
|
|
|||
|
We discuss mapping of types, flags, default and allowed values, and
|
|||
|
descriptive text in the subsections below.
|
|||
|
|
|||
|
OIDs for SLP template conversion schema elements are standardized
|
|||
|
under the enterprise number of SrvLoc.Org (6252) [18].
|
|||
|
|
|||
|
For purposes of representing an SLP entry, we also define two
|
|||
|
standardized LDAP syntaxes and attributes with standardized OIDs.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.2.2
|
|||
|
DESC 'SLP Service Type'
|
|||
|
)
|
|||
|
|
|||
|
Defines the syntax for the service type name. The syntax is defined
|
|||
|
in the BNF for the service URL in RFC 2609 Section 2.1 [1].
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.2.3
|
|||
|
DESC 'SLP Scope'
|
|||
|
)
|
|||
|
|
|||
|
Defines the syntax for the scope name. The syntax is defined in the
|
|||
|
BNF for scope names in RFC 2608 Section 6.4.1 [5].
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 6]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.4
|
|||
|
NAME 'service-advert-service-type'
|
|||
|
DESC 'The service type of the service advertisement, including
|
|||
|
the "service:" prefix.'
|
|||
|
EQUALITY caseExactIA5Match
|
|||
|
SYNTAX 1.3.6.1.4.1.6252.2.27.6.2.2
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
Defines an attribute for the service type name.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.5
|
|||
|
NAME 'service-advert-scopes'
|
|||
|
DESC 'A list of scopes for a service advertisement.'
|
|||
|
EQUALITY caseExactIA5Match
|
|||
|
SYNTAX 1.3.6.1.4.1.6252.2.27.6.2.3
|
|||
|
)
|
|||
|
|
|||
|
Defines a multivalued attribute for the scopes.
|
|||
|
|
|||
|
Searches for abstract types can be made with an LDAP query that
|
|||
|
wildcards the concrete type. For example, a search for all service
|
|||
|
advertisements of the printer abstract type can be made with the
|
|||
|
following query:
|
|||
|
|
|||
|
(service-advert-service-type=service:printer:*)
|
|||
|
|
|||
|
SLP specifies that service URLs and attribute lists can be
|
|||
|
accompanied by a structured authenticator consisting of a digital
|
|||
|
signature and information necessary to verify the signature. A
|
|||
|
syntax and two standardized SLP attributes are defined for this
|
|||
|
purpose:
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.2.3 DESC 'SLP Authenticator')
|
|||
|
|
|||
|
The syntax of an SLP authenticator is the bytes of the
|
|||
|
authenticator in network byte order, see RFC 2608, Section 9.2
|
|||
|
[5].
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.6
|
|||
|
NAME 'service-advert-url-authenticator'
|
|||
|
DESC 'The authenticator for the URL, null if none.'
|
|||
|
SYNTAX 1.3.6.1.4.1.6252.2.27.6.2.3
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
This attribute contains the SLP URL authenticator, as defined in
|
|||
|
RFC 2608, Section 9.2 [5].
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 7]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
( 1.3.6.1.4.1.6252.2.27.6.1.7
|
|||
|
NAME 'service-advert-attribute-authenticator'
|
|||
|
DESC 'The authenticator for the attribute list, null if none.'
|
|||
|
SYNTAX 1.3.6.1.4.1.6252.2.27.6.2.3
|
|||
|
SINGLE_VALUE
|
|||
|
)
|
|||
|
|
|||
|
This attribute contains the SLP attribute authenticator, as
|
|||
|
defined in RFC 2608, Section 9.2 [5].
|
|||
|
|
|||
|
2.1 Mapping from SLP Attribute Types to LDAP Attribute Types
|
|||
|
|
|||
|
We define the mapping from SLP attribute types to LDAP as follows:
|
|||
|
|
|||
|
SLP Type ASN.1 Type LDAP Type
|
|||
|
---------------------------------------------------
|
|||
|
Integer INTEGER INTEGER
|
|||
|
String DirectoryString Directory String
|
|||
|
Boolean BOOLEAN Boolean
|
|||
|
Opaque OCTET STRING Octet String
|
|||
|
Keyword (N/A) IA5 String
|
|||
|
|
|||
|
The following subsections discuss further details of the mapping.
|
|||
|
|
|||
|
2.1.1 Integer
|
|||
|
|
|||
|
SLP integers compare as integers when performing a query. LDAP
|
|||
|
integers behave similarly. Consequently, the mapping from the SLP
|
|||
|
integer type to LDAP is INTEGER, with the integerMatch matching rule.
|
|||
|
|
|||
|
2.1.2 String
|
|||
|
|
|||
|
SLP strings are encoded as described in the SLP protocol
|
|||
|
specification [5]. All value strings are considered case insensitive
|
|||
|
for matching operations. SLP strings are not null terminated and are
|
|||
|
encoded in UTF-8.
|
|||
|
|
|||
|
SLP strings are mapped to the LDAP Directory String type. The
|
|||
|
Directory String type exactly matches the SLP string type, i.e. it is
|
|||
|
a non-null terminated UTF-8 string. The caseIgnoreMatch equality
|
|||
|
rule, caseIgnoreOrderingMatch ordering rule, and
|
|||
|
caseIgnoreSubstringsMatch substring rule are used for comparing
|
|||
|
string attribute values.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 8]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
2.1.3 Boolean
|
|||
|
|
|||
|
Boolean attributes may have one of two possible values. In SLP,
|
|||
|
these values are represented as strings, TRUE and FALSE. In SLP's
|
|||
|
string encoding of a boolean value, case does not matter.
|
|||
|
|
|||
|
The SLP Boolean type maps directly into an LDAP BOOLEAN. The
|
|||
|
caseIgnoreMatch rule is used for equality matching.
|
|||
|
|
|||
|
2.1.4 Opaque
|
|||
|
|
|||
|
SLP attribute values of type Opaque are represented as OCTET STRING
|
|||
|
in LDAP, and the octetStringMatch matching rule is used to compare
|
|||
|
them.
|
|||
|
|
|||
|
2.2 Keyword Attributes
|
|||
|
|
|||
|
SLP service type templates allow the definition of keyword
|
|||
|
attributes. Keyword attributes are attributes whose only
|
|||
|
characteristic is their presence. Keyword attributes have no flag
|
|||
|
information, nor any default or allowed values (since, by definition,
|
|||
|
they have no values).
|
|||
|
|
|||
|
ASN.1 has no concept of keyword attributes. Keyword attributes are
|
|||
|
translated into a "May" clause in the ASN.1 class definition for the
|
|||
|
service type. If the keyword attribute is present, then its value is
|
|||
|
of no consequence, but for consistency we make it simply the NUL
|
|||
|
character, "\00".
|
|||
|
|
|||
|
2.3 Template Flags
|
|||
|
|
|||
|
SLP template flags can be handled as described in the following
|
|||
|
subsections.
|
|||
|
|
|||
|
2.3.1 Multi-valued
|
|||
|
|
|||
|
Multi-valued attributes are defined in an SLP template using the one
|
|||
|
value. All values for a given attribute must be of the same type.
|
|||
|
|
|||
|
LDAP attribute definitions require that a single valued attribute
|
|||
|
include the SINGLE-VALUE tag if the attribute is single valued.
|
|||
|
Otherwise, the attribute is assumed to be multivalued by default.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 9]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
2.3.2 Optional
|
|||
|
|
|||
|
SLP uses the 'O' flag to indicate an attribute may or may not be
|
|||
|
present. These optional attributes are defined using the "May"
|
|||
|
clause in the ASN.1 definition class definition for the service type.
|
|||
|
All other attributes must be defined as a "Must".
|
|||
|
|
|||
|
2.3.3 Literal
|
|||
|
|
|||
|
ASN.1 does not have a mechanism to indicate that the values of an
|
|||
|
attribute may not be translated from one language to another, since
|
|||
|
ASN.1 schema are not typically translated. This flag is dropped when
|
|||
|
translating a template, but presence of the flag should be noted in
|
|||
|
the DESC field. It should be placed on a separate line and tagged
|
|||
|
with "Literal:" so the template can be reconstructed from the schema.
|
|||
|
|
|||
|
2.3.4 Explicit Matching
|
|||
|
|
|||
|
The SLP template syntax uses a flag of 'X' to indicate that an
|
|||
|
attribute must be present in order for the query to be properly
|
|||
|
satisfied. There is no provision for requiring that particular
|
|||
|
attributes be in a query. Consequently, this flag is dropped when
|
|||
|
translating a template, but presence of the flag should be noted in
|
|||
|
the DESC field. It should be placed on a separate line and tagged
|
|||
|
with "Explicit:" so the template can be reconstructed from the
|
|||
|
schema.
|
|||
|
|
|||
|
2.4 Default and Allowed Value Lists
|
|||
|
|
|||
|
The SLP template grammar provides the capability to define default
|
|||
|
and allowed values for an attribute. The SLP protocol does not
|
|||
|
enforce these restrictions on registered attributes, however. The
|
|||
|
default and allowed values may be used by client side applications,
|
|||
|
or alternatively it may also be used by DAs to initialize
|
|||
|
registrations having no attributes and to limit attribute values to
|
|||
|
the template allowed values.
|
|||
|
|
|||
|
LDAP servers also do not support default and allowed values on
|
|||
|
attributes. Therefore, enforcement of default and allowed values in
|
|||
|
SLP templates is left up to the clients or a DA, if the DA is
|
|||
|
backending into LDAP. The default and allowed values should be
|
|||
|
included in the DESC field. The comments should be placed on separate
|
|||
|
lines and labeled with the "Default:" and "Allowed:" tags to allow
|
|||
|
reconstruction of the template.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 10]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
2.5 Descriptive Text
|
|||
|
|
|||
|
The descriptive text associated with an attribute definition should
|
|||
|
be included in the DESC field. It should start on a separate line and
|
|||
|
begin with the "Description:" tag.
|
|||
|
|
|||
|
2.6 Generating LDAP Attribute OIDs
|
|||
|
|
|||
|
LDAP attributes require an OID. In general, there is no a priori way
|
|||
|
that an algorithm can be defined for generating OIDs, because it will
|
|||
|
depend on the conventions used by the organization developing the
|
|||
|
template. In some cases, an organization's procedure for generating
|
|||
|
OIDs may be regular enough that a template developer can
|
|||
|
algorithmically generate OIDs off of an assigned root. Whatever means
|
|||
|
is used, the template developer should assure that unique OIDs are
|
|||
|
assigned to each SLP attribute that is translated into an LDAP
|
|||
|
attribute.
|
|||
|
|
|||
|
2.7 Example
|
|||
|
|
|||
|
The template included below is a hypothetical abstract printer
|
|||
|
service template, similar to that described in [10].
|
|||
|
|
|||
|
template-type = printer
|
|||
|
|
|||
|
template-version = 0.0
|
|||
|
|
|||
|
template-description =
|
|||
|
The printer service template describes the attributes supported by
|
|||
|
network printing devices. Devices may be either directly
|
|||
|
connected to a network, or connected to a printer spooler that
|
|||
|
understands the a network queuing protocol such as IPP, lpr or the
|
|||
|
Salutation Architecture.
|
|||
|
|
|||
|
template-url-syntax =
|
|||
|
;The URL syntax is specific to the printing protocol being
|
|||
|
;employed
|
|||
|
|
|||
|
description = STRING
|
|||
|
# This attribute is a free form string that can contain any
|
|||
|
# site-specific descriptive information about this printer.
|
|||
|
|
|||
|
printer-security-mechanisms-supported = STRING L M
|
|||
|
none
|
|||
|
# This attribute indicates the security mechanisms supported
|
|||
|
tls, ssl, http-basic, http-digest, none
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 11]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
printer-operator = STRING O L M
|
|||
|
# A person, or persons responsible for maintaining a
|
|||
|
# printer on a day-to-day basis, including such tasks
|
|||
|
# as filling empty media trays, emptying full output
|
|||
|
# trays, replacing toner cartridges, clearing simple
|
|||
|
# paper jams, etc.
|
|||
|
|
|||
|
printer-location-address = STRING O
|
|||
|
# Physical/Postal address for this device. Useful for
|
|||
|
# nailing down a group of printers in a very large corporate
|
|||
|
# network. For example: 960 Main Street, San Jose, CA 95130
|
|||
|
|
|||
|
printer-priority-queue = BOOLEAN O
|
|||
|
FALSE
|
|||
|
# TRUE indicates this printer or print queue is a priority
|
|||
|
# queuing device.
|
|||
|
|
|||
|
printer-number-up = INTEGER O
|
|||
|
1
|
|||
|
# This job attribute specifies the number of source
|
|||
|
# page-images to impose upon a single side of an instance
|
|||
|
# of a selected medium.
|
|||
|
1, 2, 4
|
|||
|
|
|||
|
printer-paper-output = STRING M L O
|
|||
|
standard
|
|||
|
# This attribute describes the mode in which pages output
|
|||
|
# are arranged.
|
|||
|
|
|||
|
standard, noncollated sort, collated sort, stack, unknown
|
|||
|
|
|||
|
We assume that the concrete type "service:printer:lpr" for printers
|
|||
|
that speak the LPR protocol [4] has the following template
|
|||
|
definition:
|
|||
|
|
|||
|
template-type = printer:lpr
|
|||
|
|
|||
|
template-version = 0.0
|
|||
|
|
|||
|
template-description =
|
|||
|
The printer:lpr service template describes the attributes
|
|||
|
supported by network printing devices that speak the
|
|||
|
LPR protocol. No new attributes are included.
|
|||
|
|
|||
|
template-url-syntax = queue
|
|||
|
queue = ;The queue name, see RFC 1179.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 12]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
The LDAP class definition for the "service:printer:lpr" concrete
|
|||
|
service type is translated as follows:
|
|||
|
|
|||
|
( ---place the assigned OID here---
|
|||
|
NAME 'service-printer-lpr'
|
|||
|
DESC 'Description: The printer:lpr service template
|
|||
|
describes the attributes supported by network printing
|
|||
|
devices that speak the LPR protocol. No new attributes
|
|||
|
are included.
|
|||
|
|
|||
|
URL Syntax: queue
|
|||
|
queue = ;The queue name, see RFC 1179.'
|
|||
|
SUP slpService
|
|||
|
MUST ( description $ security-mechanisms-supported $
|
|||
|
labeledURI)
|
|||
|
MAY ( operator $ location-address $ priority-queue $
|
|||
|
number-up $ paper-output)
|
|||
|
)
|
|||
|
|
|||
|
The attribute definitions are translated as follows:
|
|||
|
|
|||
|
( ---place the assigned OID here---
|
|||
|
NAME 'printer-security-mechanisms-supported'
|
|||
|
DESC 'Description: This attribute indicates the security mechanisms
|
|||
|
supported.
|
|||
|
|
|||
|
Default: value
|
|||
|
|
|||
|
Allowed: tls, ssl, http-basic, http-digest, none
|
|||
|
|
|||
|
Literal:'
|
|||
|
EQUALITY caseIgnoreMatch
|
|||
|
ORDERING caseIgnoreOrderingMatch
|
|||
|
SUBSTR caseIgnoreSubstringsMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
)
|
|||
|
|
|||
|
( ---place the assigned OID here---
|
|||
|
NAME 'printer-operator'
|
|||
|
DESC 'Description: A person, or persons responsible for
|
|||
|
maintaining a printer on a day-to-day basis, including
|
|||
|
such tasks as filling empty media trays, emptying full
|
|||
|
output trays, replacing toner cartridges, clearing simple
|
|||
|
paper jams, etc.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 13]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
Literal:'
|
|||
|
EQUALITY caseIgnoreMatch
|
|||
|
ORDERING caseIgnoreOrderingMatch
|
|||
|
SUBSTR caseIgnoreSubstringsMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
)
|
|||
|
|
|||
|
( --place the assigned OID here---
|
|||
|
NAME 'printer-location-address'
|
|||
|
DESC 'Description Physical/Postal address for this device.
|
|||
|
Useful for nailing down a group of printers in a very
|
|||
|
large corporate network. For example: 960 Main Street,
|
|||
|
San Jose, CA 95130.'
|
|||
|
EQUALITY caseIgnoreMatch
|
|||
|
ORDERING caseIgnoreOrderingMatch
|
|||
|
SUBSTR caseIgnoreSubstringsMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
( ---place the assigned OID here---
|
|||
|
NAME 'printer-priority-queue'
|
|||
|
DESC 'Description: TRUE indicates this printer or print
|
|||
|
queue is a priority queuing device.'
|
|||
|
EQUALITY booleanMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.7
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
( ---place the assigned OID here---
|
|||
|
NAME 'printer-number-up'
|
|||
|
DESC 'Description: This job attribute specifies the number
|
|||
|
of source page-images to impose upon a single side of
|
|||
|
an instance of a selected medium. This attribute is
|
|||
|
INTEGER.
|
|||
|
|
|||
|
Default: 1
|
|||
|
|
|||
|
Allowed: 1, 2, 3, 4'
|
|||
|
EQUALITY integerMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.27
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 14]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
( ---place the assigned OID here---
|
|||
|
NAME 'printer-paper-output'
|
|||
|
DESC 'Description: This attribute describes the mode in
|
|||
|
which pages output are arranged. Default value is
|
|||
|
standard.
|
|||
|
|
|||
|
Default: standard
|
|||
|
|
|||
|
Allowed: standard, noncollated sort, collated sort,
|
|||
|
stack, unknown.
|
|||
|
Literal:'
|
|||
|
EQUALITY caseIgnoreMatch
|
|||
|
ORDERING caseIgnoreOrderingMatch
|
|||
|
SUBSTR caseIgnoreSubstringsMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
)
|
|||
|
|
|||
|
3.0 Attribute Name Conflicts
|
|||
|
|
|||
|
LDAP has a flat name space, and attribute names and OIDs must be
|
|||
|
unique in a directory server. In order to avoid name conflicts in the
|
|||
|
translation of SLP templates to LDAP schemas, template developers may
|
|||
|
want to consider prepending the name of the service type to the
|
|||
|
attribute. Postprocessing attribute names to make them unique when
|
|||
|
translated is not possible, because it would require the DA to
|
|||
|
rewrite queries before submitting them to the directory server. In
|
|||
|
addition, developers should use standard LDAP attributes when such
|
|||
|
attributes are available.
|
|||
|
|
|||
|
In the above example template, the abstract type name "printer" is
|
|||
|
prepended to attributes to avoid conflicts. The standard
|
|||
|
"description" attribute defined by X.520 [3] is used to translate the
|
|||
|
template description attribute.
|
|||
|
|
|||
|
4.0 Mapping from Schema to Templates
|
|||
|
|
|||
|
The reverse mapping from LDAP schema to SLP service type templates
|
|||
|
requires dealing with both LDAP and ASN.1 data types. RFC 2252
|
|||
|
defines 33 attribute syntaxes that should be supported by LDAP
|
|||
|
directory servers. These syntaxes are defined using BNF for strings
|
|||
|
or using ASN.1 for binary valued attributes defined by X.520.
|
|||
|
|
|||
|
Mapping of the LDAP data types into SLP template types is fairly
|
|||
|
straightforward, but mapping arbitrary ASN.1 data types is somewhat
|
|||
|
more complicated and requires encoding the ASN.1 data type into a
|
|||
|
string. To a certain extent, this masks the ASN.1 data type because
|
|||
|
it becomes impossible to distinguish between a native string having
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 15]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
content equivalent to an encoded ASN.1 string. However, inclusion of
|
|||
|
the ASN.1 data type in the comment provides additional information
|
|||
|
should a reverse transformation from SLP to ASN.1 be required.
|
|||
|
|
|||
|
The following subsections deal with both LDAP and ASN.1 attribute
|
|||
|
data type mappings.
|
|||
|
|
|||
|
4.1 Mapping LDAP Attribute Syntaxes to SLP Attribute Types
|
|||
|
|
|||
|
The following table contains the mappings for LDAP syntaxes to SLP
|
|||
|
data types:
|
|||
|
|
|||
|
LDAP Type SLP Type
|
|||
|
--------------------------------------------------------
|
|||
|
ACI Item NA
|
|||
|
Access Point NA
|
|||
|
Attribute Type Description NA
|
|||
|
Audio Opaque
|
|||
|
Binary ASN.1 escape
|
|||
|
Bit String String
|
|||
|
Boolean Boolean
|
|||
|
Certificate Opaque
|
|||
|
Certificate List Opaque
|
|||
|
Certificate Pair Opaque
|
|||
|
Country String String
|
|||
|
DN String
|
|||
|
Data Quality Syntax NA
|
|||
|
Delivery Method NA
|
|||
|
Directory String String
|
|||
|
DIT Content Rule Description NA
|
|||
|
DIT Structure Rule Description NA
|
|||
|
DL Submit Permission NA
|
|||
|
DSA Quality Syntax NA
|
|||
|
Enhanced Guide NA
|
|||
|
Facsimile Telephone Number String
|
|||
|
Fax Opaque
|
|||
|
Generalized Time String
|
|||
|
Guide NA
|
|||
|
IA5 String String
|
|||
|
INTEGER Integer
|
|||
|
JPEG Opaque
|
|||
|
LDAP Syntax Description NA
|
|||
|
LDAP Schema Definition NA
|
|||
|
LDAP Schema Description NA
|
|||
|
Master and Shadow Access Points NA
|
|||
|
Matching Rule Description NA
|
|||
|
Matching Rule Use Description NA
|
|||
|
Mail Preference NA
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 16]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
MHS OR Address String
|
|||
|
Modify Rights NA
|
|||
|
Name and Optional UID NA
|
|||
|
Name Form Description NA
|
|||
|
Numeric String String
|
|||
|
Object Class Description NA
|
|||
|
Octet String Opaque
|
|||
|
OID String
|
|||
|
Other Mailbox String
|
|||
|
Postal Address String
|
|||
|
Protocol Information NA
|
|||
|
Presentation Address String
|
|||
|
Printable String String
|
|||
|
Substring Assertion NA
|
|||
|
Subtree Specification NA
|
|||
|
Supplier Information NA
|
|||
|
Supplier or Consumer NA
|
|||
|
Supplier And Consumer NA
|
|||
|
Supported Algorithm NA
|
|||
|
DSE Type NA
|
|||
|
Telephone Number String
|
|||
|
Teletex Terminal Identifier String
|
|||
|
Telex Number String
|
|||
|
UTC Time String
|
|||
|
|
|||
|
4.2 Mapping ASN.1 Types to SLP Types
|
|||
|
|
|||
|
ASN.1 employs a much richer set of data types than provided by SLP.
|
|||
|
The table below show the mapping of selected ASN.1 data type to their
|
|||
|
nearest SLP equivalent. Because of the complexity and flexibility of
|
|||
|
ASN.1, a complete list cannot be provided.
|
|||
|
|
|||
|
As sample of some ASN.1 encodings and their mappings to SLP:
|
|||
|
|
|||
|
ASN.1 type SLP type
|
|||
|
-----------------------------------------
|
|||
|
INTEGER Integer
|
|||
|
BOOLEAN Boolean
|
|||
|
ENUMERATED String
|
|||
|
OBJECT IDENTIFIER String
|
|||
|
OCTET STRING Opaque
|
|||
|
REAL String
|
|||
|
|
|||
|
Data types that do not map directly to SLP data types should be
|
|||
|
defined as either a String, or as Opaque. ASN.1 types that may only
|
|||
|
contain valid characters for Strings, as defined in X.680 [9] should
|
|||
|
be encoded as strings. ASN.1 types such as GraphicString that change
|
|||
|
their character set encoding in part way through a value should not
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 17]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
be encoded as strings, however, If such types are required, the SLP
|
|||
|
Opaque type should be used. In either case, the first line of the
|
|||
|
help text is used to indicate the original ASN.1 data type.
|
|||
|
|
|||
|
The following subsections describe how to convert from the ASN.1 BER
|
|||
|
[9] to the SLP template for the different types in the table above.
|
|||
|
|
|||
|
4.2.1 Integer
|
|||
|
|
|||
|
Both SLP templates and ASN.1 support Integers, so there is a one to
|
|||
|
one mapping between an SLP Integer attribute and an ASN.1 Integer
|
|||
|
attribute. Details on the encoding of integers is summarized in the
|
|||
|
SLP template to ASN.1 section above.
|
|||
|
|
|||
|
4.2.2 Boolean
|
|||
|
|
|||
|
Boolean values are supported by both SLP and ASN.1, though on wire
|
|||
|
encodings differ. X.680 [9] specifies zero and non-zero encoding for
|
|||
|
booleans, where SLP encodes booleans using the strings TRUE and
|
|||
|
FALSE. In general, most LDAP servers will use the LDAP Boolean type
|
|||
|
(which is a string), so again the ASN.1 type should be recorded in
|
|||
|
the comment or it will be lost.
|
|||
|
|
|||
|
4.2.3 Enumerated
|
|||
|
|
|||
|
SLP templates support the concept of enumerations through the listing
|
|||
|
of allowed values in the attribute definition. These enumerations
|
|||
|
are not strictly binding on clients or DAs, but they are similar to
|
|||
|
the ASN.1 definition of enumerations. BER encodes the ASN.1
|
|||
|
enumeration by passing the number of the element's position in the
|
|||
|
enumeration. This requires both sides to have knowledge of the
|
|||
|
specific enumeration prior to decoding an enumeration's value. SLP
|
|||
|
provides no specific support for transmitting enumerations. They are
|
|||
|
simply String types. Information on the ASN.1 type and ASN.1 encoding
|
|||
|
of the enumeration values is recorded in the comment.
|
|||
|
|
|||
|
Example:
|
|||
|
|
|||
|
color-supported = STRING M
|
|||
|
none
|
|||
|
# ASN.1: Enumeration.
|
|||
|
# ASN.1 Mapping: none = 0, highlight = 1, three color = 2,
|
|||
|
# four color = 4, monochromatic = 5
|
|||
|
#This attribute specifies whether the Printer supports
|
|||
|
# color and, if so, what type.
|
|||
|
none,highlight,three color,four color,monochromatic
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 18]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
4.2.4 Object Identifier
|
|||
|
|
|||
|
Object identifiers(OIDs) are commonly used in the ASN.1 world to
|
|||
|
identify object and attributes. OIDs are a numerical representation
|
|||
|
of an element's place in the naming hierarchy. Each element at a
|
|||
|
particular level of a hierarchy has a unique number assigned within
|
|||
|
that level of the hierarchy. A sample OID would be the naming tree
|
|||
|
for SNMP MIBs: iso(1) org(3) dod(6) internet(1) mgmt(2) mib(1) would
|
|||
|
be written as the string "1.3.6.1.2.1".
|
|||
|
|
|||
|
Because this representation reduces down to a string of dot separated
|
|||
|
numbers, this maps easily to the SLP String type. The help text for
|
|||
|
this element should indicate it is an ASN.1 OID
|
|||
|
|
|||
|
identifier = STRING
|
|||
|
# ASN.1: OID
|
|||
|
# The object identifier for this SNMP agent.
|
|||
|
|
|||
|
4.2.5 Octet String
|
|||
|
|
|||
|
An ASN.1 octet string should be mapped to an Opaque in an SLP
|
|||
|
template. An octet string is a sequence of bytes, whereas an Opaque
|
|||
|
is a a string that encodes a sequence of bytes. Again, the ASN.1 type
|
|||
|
is lost unless recorded in the comment.
|
|||
|
|
|||
|
4.2.6 Real
|
|||
|
|
|||
|
There is no direct mapping between floating point numbers and any SLP
|
|||
|
data types. Attributes having the ASN.1 type of Real are mapped to
|
|||
|
SLP type String. Comments are added to the attribute help text
|
|||
|
indicating the value was originally an ASN.1 real. For example:
|
|||
|
|
|||
|
weight = STRING
|
|||
|
# ASN.1: Real
|
|||
|
# The objects weight in pounds.
|
|||
|
|
|||
|
4.3 Example ASN.1 Schema
|
|||
|
|
|||
|
The following is an example schema for an exported filesystem. The
|
|||
|
section presents it as in ASN.1 and the following section shows the
|
|||
|
SLP template translation. The template translation does not capture
|
|||
|
the actual attribute format for the Set type, that would be done in
|
|||
|
the LDAP client software making the translation. Note that even
|
|||
|
though the class definition does not conform with the previously
|
|||
|
defined conventions for SLP classes, the schema can still be
|
|||
|
translated into an SLP template. The syntax used in this example
|
|||
|
follows
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 19]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
-- Abstraction of a fstab entry (a "mount").
|
|||
|
-- These lookups would likely be performed by an
|
|||
|
-- an automounter type application.
|
|||
|
mount OBJECT-CLASS ::= {
|
|||
|
SUBCLASS OF { top }
|
|||
|
MUST CONTAIN { mountHost |
|
|||
|
mountDirectory |
|
|||
|
mountType
|
|||
|
}
|
|||
|
MAY CONTAIN { mountOption |
|
|||
|
mountDumpFrequency |
|
|||
|
mountPassNo
|
|||
|
}
|
|||
|
ID { <oid1> }
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
- The mount host.
|
|||
|
mountHost ATTRIBUTE ::= {
|
|||
|
WITH SYNTAX caseIgnoreString
|
|||
|
EQUALITY MATCHING RULE caseIgnoreMatch
|
|||
|
SINGLE VALUE
|
|||
|
ID { <oid2> }
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
- The file system to mount.
|
|||
|
mountDirectory ATTRIBUTE ::= {
|
|||
|
WITH SYNTAX caseIgnoreString
|
|||
|
EQUALITY MATCHING RULE caseIgnoreMatch
|
|||
|
SINGLE VALUE
|
|||
|
ID { <oid3> }
|
|||
|
}
|
|||
|
|
|||
|
- The type of file system being mounted.
|
|||
|
mountType ATTRIBUTE ::= {
|
|||
|
WITH SYNTAX INTEGER { ufs(1),
|
|||
|
hsfs(2),
|
|||
|
nfs(3),
|
|||
|
rfs(4)
|
|||
|
}
|
|||
|
EQUALITY MATCHING RULE integerMatch
|
|||
|
SINGLE VALUE
|
|||
|
ID { <oid4> }
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 20]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
- Options for the mount operation.
|
|||
|
mountOption ATTRIBUTE ::= {
|
|||
|
WITH SYNTAX caseIgnoreString
|
|||
|
EQUALITY MATCHING RULE caseIgnoreString
|
|||
|
ID { <oid5> }
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
- How often to dump the file system.
|
|||
|
mountDumpFrequency ATTRIBUTE :: = {
|
|||
|
WITH SYNTAX INTEGER (0..9)
|
|||
|
EQUALITY MATCHING RULE integerMatch
|
|||
|
SINGLE VALUE
|
|||
|
ID { <oid6> }
|
|||
|
}
|
|||
|
|
|||
|
- Boot time mount pass number.
|
|||
|
mountPassNo ATTRIBUTE ::= {
|
|||
|
WITH SYNTAX INTEGER
|
|||
|
EQUALITY MATCHING RULE integerMatch
|
|||
|
SINGLE VALUE
|
|||
|
ID { <oid7> }
|
|||
|
}
|
|||
|
|
|||
|
The translated SLP template is:
|
|||
|
|
|||
|
template-type = mount
|
|||
|
|
|||
|
template-version = 1.0
|
|||
|
|
|||
|
template-description = "Describes a remote filesystem access
|
|||
|
protocol"
|
|||
|
|
|||
|
template-url-syntax =
|
|||
|
filesystem = 1*[ DIGIT / ALPHA ]
|
|||
|
urlpath = "/" filesystem
|
|||
|
|
|||
|
mountHost = STRING L
|
|||
|
# ASN.1: Case Ignore String, Single Value
|
|||
|
# The mount host
|
|||
|
|
|||
|
mountDirectory = STRING L
|
|||
|
# ASN.1: Case Ignore String, Single Value
|
|||
|
# The filesystem to mount
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 21]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
mountType = STRING L
|
|||
|
ufs
|
|||
|
# ASN.1: Enumeration, Single Value
|
|||
|
# ASN.1 Mapping: ufs = 1, hsfs = 2, nfs = 3, rfs = 4
|
|||
|
# The type of the filesystem being mounted
|
|||
|
ufs, hsfs, nfs, rfs
|
|||
|
|
|||
|
mountOption = STRING M O L
|
|||
|
# ASN.1: Case Ignore String
|
|||
|
# mount options for this filesystem
|
|||
|
|
|||
|
mountDumpFrequency = INTEGER O
|
|||
|
0
|
|||
|
# ASN.1: Integer Range, Single Value
|
|||
|
# How often to dump this filesystem
|
|||
|
0, 1, 2, 3, 4, 5, 6, 7, 8, 9
|
|||
|
|
|||
|
mountPassNo = INTEGER O
|
|||
|
# ASN.1: Integer, Single Value
|
|||
|
# Boot time mount pass number
|
|||
|
|
|||
|
5.0 Representing SLP Service Advertisements in an LDAP DIT
|
|||
|
|
|||
|
In addition to translating between SLP templates and LDAP schema,
|
|||
|
another area requiring compatibility is the representation of SLP
|
|||
|
service advertisements in an LDAP DIT. A standardized representation
|
|||
|
for service information allows SLP DAs to store service
|
|||
|
advertisements in LDAP, and for LDAP clients to query the DIT for
|
|||
|
those services. Similarly, if LDAP clients represent service
|
|||
|
information in the same form, SLP clients can benefit from
|
|||
|
interoperability.
|
|||
|
|
|||
|
A service advertisement contains the service URL in a 'labeledURI'
|
|||
|
attribute [11]. The labeledURI attribute in a service advertisement
|
|||
|
should only contain the service URL for the service, with no
|
|||
|
additional label. It is recommended that the labeledURI be used as
|
|||
|
the RDN for the service object in the DIT.
|
|||
|
|
|||
|
Although service advertisements can appear anywhere within the DIT,
|
|||
|
it is recommended that all services be stored under a single common
|
|||
|
point, or root node, to facilitate searching in a domain. This allows
|
|||
|
a client to search for all of advertisements of a particular service
|
|||
|
type, say, for all printers. The recommended parent entry is one
|
|||
|
named "ou=service" below the entry which is the representation of the
|
|||
|
domain, as described in RFC 2247.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 22]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
For example, a printer service with labeledURI of
|
|||
|
"service:lpr://printsrv/queue1" in the domain foobar.com advertised
|
|||
|
in the LDAP server that holds the entry "dc=foobar,dc=com" tree has
|
|||
|
the following DN:
|
|||
|
|
|||
|
"labeledURI=service:lpr://printsrv/queue1, ou=service, dc=foobar,
|
|||
|
dc=com"
|
|||
|
|
|||
|
While this leads to a flat space of service storage, since SLP uses
|
|||
|
search filters from LDAP for searches, these filters can be used for
|
|||
|
one-level searches from the root node.
|
|||
|
|
|||
|
The following example illustrates how an advertisement having a
|
|||
|
simple service type is represented. The advertisement (in conceptual
|
|||
|
form) for a printer is:
|
|||
|
|
|||
|
Service Type: service:lpr://printsrv/queue1
|
|||
|
Scopes: eng,corp
|
|||
|
Attributes:
|
|||
|
description = A general printer for all to use.
|
|||
|
security-mechanisms-supported = none
|
|||
|
Authentication: none
|
|||
|
|
|||
|
The RDN of the object is labeledURI=service:lpr://printsrv/queue1,
|
|||
|
and the following LDAP search filter will return this object, along
|
|||
|
with any others of the service type "service:lpr" that match the
|
|||
|
other attributes:
|
|||
|
|
|||
|
(&(service-advert-service-type=service:lpr)
|
|||
|
(service-advert-scopes=eng)
|
|||
|
(service-advert-scopes=corp)
|
|||
|
(description=A general printer for all to use.)
|
|||
|
(security-mechanisms-supported=none))
|
|||
|
|
|||
|
Service advertisements in SLP also have a lease time associated with
|
|||
|
them. In LDAP servers that support the extensions for dynamic
|
|||
|
directory services [12], the service advertisement entry objectClass
|
|||
|
should be extended with the dynamicObject class. This allows the
|
|||
|
service advertisement to time out within the LDAP directory server.
|
|||
|
If the LDAP directory server does not support the dynamic directory
|
|||
|
services extension, then advertisement lease timeouts must be handled
|
|||
|
by the SLP agent.
|
|||
|
|
|||
|
While the service advertisement schema outlined in this section is
|
|||
|
primarily for SLP DAs that use LDAP as a backing store, if LDAP
|
|||
|
agents register services using the same format, complete
|
|||
|
interoperability with SLP is achieved.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 23]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
6.0 Internationalization Considerations
|
|||
|
|
|||
|
SLP specifies that an RFC 1766 [13] language code accompanies every
|
|||
|
service advertisement. Language codes for service advertisements in
|
|||
|
LDAP must be represented according to RFC 2596 [14].
|
|||
|
|
|||
|
RFC 2596 prohibits language codes in DNs, and specifies that a
|
|||
|
directory server which does not support language codes must treat an
|
|||
|
attribute with a language code as an unrecognized attributes.
|
|||
|
According to RFC 2596, language codes are appended to attribute names
|
|||
|
with a semicolon (";"). For example, the following attribute/value
|
|||
|
pair is in the German locale:
|
|||
|
|
|||
|
(address;lang-de=44 Bahnhofstrasse, 2365 Weibstadt, Deutschland)
|
|||
|
|
|||
|
An attribute with a language tag in a specific locale is considered a
|
|||
|
separate attribute from attributes in other locales.
|
|||
|
|
|||
|
If the service advertisement is in the default SLP locale ("en", no
|
|||
|
dialect), then the language code need not be appended to the
|
|||
|
attribute name.
|
|||
|
|
|||
|
SLP queries in locales other than the default need not be rewritten
|
|||
|
to include language tags before being submitted to the directory
|
|||
|
server. RFC 2596 specifies that all entries that match are returned,
|
|||
|
including those with language tags, without requiring the language
|
|||
|
tags to be explicitly present in the query. The SLP DA can then
|
|||
|
postprocess the result to select the entries from the required
|
|||
|
locale.
|
|||
|
|
|||
|
7.0 Security Considerations
|
|||
|
|
|||
|
SLP authenticators are stored with the service advertisement in the
|
|||
|
DIT, as discussed in Section~7ef{slpdit}. LDAP clients need to use
|
|||
|
LDAP authentication [15] to assure that they are connecting with a
|
|||
|
secure server. In particular, SLP DAs that use LDAP as a back end
|
|||
|
store and that implement SLP authentication MUST use LDAP
|
|||
|
authentication to assure that the LDAP entries for their service
|
|||
|
registrations are secure.
|
|||
|
|
|||
|
Acknowledgements
|
|||
|
|
|||
|
Many thanks are due to Mark Wahl whose detailed and insightful
|
|||
|
comments were instrumental in helping improve the technical accuracy
|
|||
|
of this document with respect to LDAP.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 24]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
8.0 References
|
|||
|
|
|||
|
[1] Guttman, E., Perkins, C. and J. Kempf, "Service Templates and
|
|||
|
service: Schemes", RFC 2609, April 1999.
|
|||
|
|
|||
|
[2] Wahl, W., Howes, T. and S. Kille, "Lightweight Directory Access
|
|||
|
Protocol (v3)", RFC 2251, December 1997.
|
|||
|
|
|||
|
[3] International Telecommunications Union. The Directory:Selected
|
|||
|
Attribute Types. ITU Recommendation X.520. August, 1997.
|
|||
|
|
|||
|
[4] McLaughlin, L., "Line Printer Daemon Protocol, RFC 1179, August
|
|||
|
1990.
|
|||
|
|
|||
|
[5] Guttman, E., Perkins, C., Veizades, J. and M. Day, "Service
|
|||
|
Location Protocol Version 2", RFC 2608, April 1999.
|
|||
|
|
|||
|
[6] Crocker, D. and P. Overell, "Augmented BNF for Syntax
|
|||
|
Specifications: ABNF", RFC 2234, November 1997.
|
|||
|
|
|||
|
[7] Howes, T., "The String Representation of LDAP Search Filters",
|
|||
|
RFC 2254, December 1997.
|
|||
|
|
|||
|
[8] Wahl, W., Coulbeck, A., Howe, T. and S. Kille, "Lightweight
|
|||
|
Directory Access Protocol (v3): Attribute Syntax Definition",
|
|||
|
RFC 2252, December 1997.
|
|||
|
|
|||
|
[9] ITU-T Rec. X.680. Abstract Syntax Notation One (ASN.1) -
|
|||
|
Specification of Basic Notation. 1994.
|
|||
|
|
|||
|
[10] Fleming, P., Jones, K., Lewis, H., and McDonald, I., "Internet
|
|||
|
Printing Protocol (IPP): LDAP Schema for Printer Services", Work
|
|||
|
in Progress.
|
|||
|
|
|||
|
[11] Smith, M., "Definition of an X.500 Attribute Type and an Object
|
|||
|
Class to Hold Uniform Resource Identifiers (URIs)", RFC 2079,
|
|||
|
January 1997.
|
|||
|
|
|||
|
[12] Yaacovi, Y., Wahl, M. and T. Genovese, "Lightweight Directory
|
|||
|
Access Protocol (v3): Extensions for Dynamic Directory
|
|||
|
Services", RFC 2589, May 1999.
|
|||
|
|
|||
|
[13] Alvestrand, H., "Tags for the Identification of Languages", RFC
|
|||
|
1766, December 1997.
|
|||
|
|
|||
|
[14] Wahl, M. and T. Howes, "Use of Language Codes in LDAP", RFC
|
|||
|
2596, May 1999.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 25]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
[15] Wahl, M., Alvestrand, H., Hodges, J. and R. Morgan,
|
|||
|
"Authentication Methods for LDAP", RFC 2829, May 2000.
|
|||
|
|
|||
|
[16] Bradner, S., "Key Words for Use in RFCs to Indicate Requirement
|
|||
|
Levels", BCP 14, RFC 2119, March 1997.
|
|||
|
|
|||
|
[17] Dubuisson, O. ASN.1: Communication between Heterogeneous
|
|||
|
Systems. OSS Nokalva, 2000.
|
|||
|
|
|||
|
[18] http://www.srvloc.org
|
|||
|
|
|||
|
9.0 Authors' Addresses
|
|||
|
|
|||
|
James Kempf
|
|||
|
Sun Microsystems
|
|||
|
901 San Antonio Avenue
|
|||
|
Palo Alto, CA 94303
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +1 650 786-5890
|
|||
|
EMail: james.kempf@sun.com
|
|||
|
|
|||
|
|
|||
|
Ryan Moats
|
|||
|
Coreon, Inc.
|
|||
|
15621 Drexel Circle
|
|||
|
Omaha, NE, 68135
|
|||
|
USA
|
|||
|
|
|||
|
EMail: rmoats@coreon.net
|
|||
|
|
|||
|
|
|||
|
Pete St. Pierre
|
|||
|
Sun Microsystems
|
|||
|
901 San Antonio Avenue
|
|||
|
Palo Alto, CA 94303
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +1 415 786-5790
|
|||
|
EMail: Pete.StPierre@Eng.Sun.COM
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 26]
|
|||
|
|
|||
|
RFC 2926 Conversion of LDAP Schemas September 2000
|
|||
|
|
|||
|
|
|||
|
10. Full Copyright Statement
|
|||
|
|
|||
|
Copyright (C) The Internet Society (2000). 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 assigns.
|
|||
|
|
|||
|
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.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Kempf, et al. Informational [Page 27]
|
|||
|
|