mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-24 13:24:56 +08:00
676 lines
26 KiB
Plaintext
676 lines
26 KiB
Plaintext
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Network Working Group Y. Yaacovi
|
|||
|
Request for Comments: 2589 Microsoft
|
|||
|
Category: Standards Track M. Wahl
|
|||
|
Innosoft International, Inc.
|
|||
|
T. Genovese
|
|||
|
Microsoft
|
|||
|
May 1999
|
|||
|
|
|||
|
|
|||
|
Lightweight Directory Access Protocol (v3):
|
|||
|
Extensions for Dynamic Directory Services
|
|||
|
|
|||
|
Status of this Memo
|
|||
|
|
|||
|
This document specifies an Internet standards track protocol for the
|
|||
|
Internet community, and requests discussion and suggestions for
|
|||
|
improvements. Please refer to the current edition of the "Internet
|
|||
|
Official Protocol Standards" (STD 1) for the standardization state
|
|||
|
and status of this protocol. Distribution of this memo is unlimited.
|
|||
|
|
|||
|
Copyright Notice
|
|||
|
|
|||
|
Copyright (C) The Internet Society (1999). All Rights Reserved.
|
|||
|
|
|||
|
1. Abstract
|
|||
|
|
|||
|
This document defines the requirements for dynamic directory services
|
|||
|
and specifies the format of request and response extended operations
|
|||
|
for supporting client-server interoperation in a dynamic directories
|
|||
|
environment.
|
|||
|
|
|||
|
The Lightweight Directory Access Protocol (LDAP) [1] supports
|
|||
|
lightweight access to static directory services, allowing relatively
|
|||
|
fast search and update access. Static directory services store
|
|||
|
information about people that persists in its accuracy and value over
|
|||
|
a long period of time.
|
|||
|
|
|||
|
Dynamic directory services are different in that they store
|
|||
|
information that only persists in its accuracy and value when it is
|
|||
|
being periodically refreshed. This information is stored as dynamic
|
|||
|
entries in the directory. A typical use will be a client or a person
|
|||
|
that is either online - in which case it has an entry in the
|
|||
|
directory, or is offline - in which case its entry disappears from
|
|||
|
the directory. Though the protocol operations and attributes used by
|
|||
|
dynamic directory services are similar to the ones used for static
|
|||
|
directory services, clients that store dynamic information in the
|
|||
|
directory need to periodically refresh this information, in order to
|
|||
|
prevent it from disappearing. If dynamic entries are not refreshed
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 1]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
within a given timeout, they will be removed from the directory. For
|
|||
|
example, this will happen if the client that set them goes offline.
|
|||
|
|
|||
|
A flow control mechanism from the server is also described that
|
|||
|
allows a server to inform clients how often they should refresh their
|
|||
|
presence.
|
|||
|
|
|||
|
2. Requirements
|
|||
|
|
|||
|
The protocol extensions must allow accessing dynamic information in a
|
|||
|
directory in a standard LDAP manner, to allow clients to access
|
|||
|
static and dynamic information in the same way.
|
|||
|
|
|||
|
By definition, dynamic entries are not persistent and clients may go
|
|||
|
away gracefully or not. The proposed extensions must offer a way for
|
|||
|
a server to tell if entries are still valid, and to do this in a way
|
|||
|
that is scalable. There also must be a mechanism for clients to
|
|||
|
reestablish their entry with the server.
|
|||
|
|
|||
|
There must be a way for clients to find out, in a standard LDAP
|
|||
|
manner, if servers support the dynamic extensions.
|
|||
|
|
|||
|
Finally, to allow clients to broadly use the dynamic extensions, the
|
|||
|
extensions need to be registered as standard LDAP extended
|
|||
|
operations.
|
|||
|
|
|||
|
3. Description of Approach
|
|||
|
|
|||
|
The Lightweight Directory Access Protocol (LDAP) [1] permits
|
|||
|
additional operation requests and responses to be added to the
|
|||
|
protocol. This proposal takes advantage of these to support
|
|||
|
directories which contain dynamic information in a manner which is
|
|||
|
fully integrated with LDAP.
|
|||
|
|
|||
|
The approach described in this proposal defines dynamic entries in
|
|||
|
order to allow implementing directories with dynamic information. An
|
|||
|
implementation of dynamic directories, must be able to support
|
|||
|
dynamic directory entries.
|
|||
|
|
|||
|
3.1. Dynamic Entries and the dynamicObject object class
|
|||
|
|
|||
|
A dynamic entry is an object in the directory tree which has a time-
|
|||
|
to-live associated with it. This time-to-live is set when the entry
|
|||
|
is created. The time-to-live is automatically decremented, and when
|
|||
|
it expires the dynamic entry disappears. By invoking the refresh
|
|||
|
extended operation (defined below) to re-set the time-to-live, a
|
|||
|
client can cause the entry to remain present a while longer.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 2]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
A dynamic entry is created by including the objectClass value given
|
|||
|
in section 5 in the list of attributes when adding an entry. This
|
|||
|
method is subject to standard access control restrictions.
|
|||
|
|
|||
|
The extended operation covered here, allows a client to refresh a
|
|||
|
dynamic entry by invoking, at intervals, refresh operations
|
|||
|
containing that entry's name. Dynamic entries will be treated the
|
|||
|
same as non-dynamic entries when processing search, compare, add,
|
|||
|
delete, modify and modifyDN operations. However if clients stop
|
|||
|
sending refresh operations for an entry, then the server will
|
|||
|
automatically and without notification remove that entry from the
|
|||
|
directory. This removal will be treated the same as if the entry had
|
|||
|
been deleted by an LDAP protocol operation.
|
|||
|
|
|||
|
There is no way to change a static entry into a dynamic one and
|
|||
|
vice-versa. If the client is using Modify with an objectClass of
|
|||
|
dynamicObject on a static entry, the server must return a service
|
|||
|
error either "objectClassModsProhibited" (if the server does not
|
|||
|
allow objectClass modifications at all) or "objectClassViolation" (if
|
|||
|
the server does allow objectClass modifications in general).
|
|||
|
|
|||
|
A dynamic entry may be removed by the client using the delete
|
|||
|
operation. This operation will be subject to access control
|
|||
|
restrictions.
|
|||
|
|
|||
|
A non-dynamic entry cannot be added subordinate to a dynamic entry:
|
|||
|
the server must return an appropriate update or service error if this
|
|||
|
is attempted.
|
|||
|
|
|||
|
The support of dynamic attributes of an otherwise static object, are
|
|||
|
outside the scope of this document.
|
|||
|
|
|||
|
3.2 Dynamic meetings (conferences)
|
|||
|
|
|||
|
The way dynamicObject is defined, it has a time-to-live associated
|
|||
|
with it, and that's about it. Though the most common dynamic object
|
|||
|
is a person object, there is no specific type associated with the
|
|||
|
dynamicObject as defined here. By the use of the dynamic object's
|
|||
|
attributes, one can make this object represent practically anything.
|
|||
|
|
|||
|
Specifically, Meetings (conferences) can be represented by dynamic
|
|||
|
objects. While full-featured meeting support requires special
|
|||
|
semantics and handling by the server (and is not in the scope of this
|
|||
|
document), the extensions described here, provide basic meetings
|
|||
|
support. A meeting object can be refreshed by the meeting
|
|||
|
participants, and when it is not, the meeting entry disappears. The
|
|||
|
one meeting type that is naturally supported by the dynamic
|
|||
|
extensions is creator-owned meeting.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 3]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
3.2.1 Creator-owned meetings
|
|||
|
|
|||
|
Creator-owned meetings are created by a client that sets the time-
|
|||
|
to-live attribute for the entry, and it is this client's
|
|||
|
responsibility to refresh the meeting entry, so that it will not
|
|||
|
disappear. Others might join the meeting, by modifying the
|
|||
|
appropriate attribute, but they are not allowed to refresh the entry.
|
|||
|
When the client that created the entry goes away, it can delete the
|
|||
|
meeting entry, or it might disappear when its time-to-live expires.
|
|||
|
This is consistent with the common model for dynamicObject as
|
|||
|
described above.
|
|||
|
|
|||
|
4. Protocol Additions
|
|||
|
|
|||
|
4.1 Refresh Request
|
|||
|
|
|||
|
Refresh is a protocol operation sent by a client to tell the server
|
|||
|
that the client is still alive and the dynamic directory entry is
|
|||
|
still accurate and valuable. The client sends a Refresh request
|
|||
|
periodically based on the value of the client refresh period (CRP).
|
|||
|
The server can request that the client change this value. As long as
|
|||
|
the server receives a Refresh request within the timeout period, the
|
|||
|
directory entry is guaranteed to persist on the server. Client
|
|||
|
implementers should be aware that since the intervening network
|
|||
|
between the client and server is unreliable, a Refresh request packet
|
|||
|
may be delayed or lost while in transit. If this occurs, the entry
|
|||
|
may disappear, and the client will need to detect this and re-add the
|
|||
|
entry.
|
|||
|
|
|||
|
A client may request this operation by transmitting an LDAP PDU
|
|||
|
containing an ExtendedRequest. An LDAP ExtendedRequest is defined as
|
|||
|
follows:
|
|||
|
|
|||
|
ExtendedRequest ::= [APPLICATION 23] SEQUENCE {
|
|||
|
requestName [0] LDAPOID,
|
|||
|
requestValue [1] OCTET STRING OPTIONAL }
|
|||
|
|
|||
|
The requestName field must be set to the string
|
|||
|
"1.3.6.1.4.1.1466.101.119.1".
|
|||
|
|
|||
|
The requestValue field will contain as a value the DER-encoding of
|
|||
|
the following ASN.1 data type:
|
|||
|
|
|||
|
SEQUENCE {
|
|||
|
entryName [0] LDAPDN,
|
|||
|
requestTtl [1] INTEGER
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 4]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
The entryName field is the UTF-8 string representation of the name of
|
|||
|
the dynamic entry [3]. This entry must already exist.
|
|||
|
|
|||
|
The requestTtl is a time in seconds (between 1 and 31557600) that the
|
|||
|
client requests that the entry exists in the directory before being
|
|||
|
automatically removed. Servers are not required to accept this value
|
|||
|
and might return a different TTL value to the client. Clients must
|
|||
|
be able to use this server-dictated value as their CRP.
|
|||
|
|
|||
|
4.2 Refresh Response
|
|||
|
|
|||
|
If a server implements this extension, then when the request is made
|
|||
|
it will return an LDAP PDU containing an ExtendedResponse. An LDAP
|
|||
|
ExtendedResponse is defined as follows:
|
|||
|
|
|||
|
ExtendedResponse ::= [APPLICATION 24] SEQUENCE {
|
|||
|
COMPONENTS OF LDAPResult,
|
|||
|
responseName [10] LDAPOID OPTIONAL,
|
|||
|
response [11] OCTET STRING OPTIONAL }
|
|||
|
|
|||
|
The responseName field contains the same string as that present in
|
|||
|
the request.
|
|||
|
|
|||
|
The response field will contain as a value the DER-encoding of the
|
|||
|
following ASN.1 data type:
|
|||
|
|
|||
|
SEQUENCE {
|
|||
|
responseTtl [1] INTEGER
|
|||
|
}
|
|||
|
|
|||
|
The responseTtl field is the time in seconds which the server chooses
|
|||
|
to have as the time-to-live field for that entry. It must not be any
|
|||
|
smaller than that which the client requested, and it may be larger.
|
|||
|
However, to allow servers to maintain a relatively accurate
|
|||
|
directory, and to prevent clients from abusing the dynamic
|
|||
|
extensions, servers are permitted to shorten a client-requested
|
|||
|
time-to-live value, down to a minimum of 86400 seconds (one day).
|
|||
|
|
|||
|
If the operation was successful, the errorCode field in the
|
|||
|
standardResponse part of an ExtendedResponse will be set to success.
|
|||
|
|
|||
|
In case of an error, the responseTtl field will have the value 0, and
|
|||
|
the errorCode field will contain an appropriate value, as follows: If
|
|||
|
the entry named by entryName could not be located, the errorCode
|
|||
|
field will contain "noSuchObject". If the entry is not dynamic, the
|
|||
|
errorCode field will contain "objectClassViolation". If the
|
|||
|
requester does not have permission to refresh the entry, the
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 5]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
errorCode field will contain "insufficientAccessRights". If the
|
|||
|
requestTtl field is too large, the errorCode field will contain
|
|||
|
"sizeLimitExceeded".
|
|||
|
|
|||
|
If a server does not implement this extension, it will return an LDAP
|
|||
|
PDU containing an ExtendedResponse, which contains only the
|
|||
|
standardResponse element (the responseName and response elements will
|
|||
|
be absent). The LDAPResult element will indicate the protocolError
|
|||
|
result code.
|
|||
|
|
|||
|
This request is permitted to be invoked when LDAP is carried by a
|
|||
|
connectionless transport.
|
|||
|
|
|||
|
When using a connection-oriented transport, there is no requirement
|
|||
|
that this operation be on the same particular connection as any
|
|||
|
other. A client may open multiple connections, or close and then
|
|||
|
reopen a connection.
|
|||
|
|
|||
|
4.3 X.500/DAP Modify(97)
|
|||
|
|
|||
|
X.500/DAP servers can map the Refresh request and response operations
|
|||
|
into the X.500/DAP Modify(97) operation.
|
|||
|
|
|||
|
5. Schema Additions
|
|||
|
|
|||
|
All dynamic entries must have the dynamicObject value in their
|
|||
|
objectClass attribute. This object class is defined as follows
|
|||
|
(using the ObjectClassDescription notation of [2]):
|
|||
|
|
|||
|
( 1.3.6.1.4.1.1466.101.119.2 NAME 'dynamicObject'
|
|||
|
DESC 'This class, if present in an entry, indicates that this entry
|
|||
|
has a limited lifetime and may disappear automatically when
|
|||
|
its time-to-live has reached 0. There are no mandatory
|
|||
|
attributes of this class, however if the client has not
|
|||
|
supplied a value for the entryTtl attribute, the server will
|
|||
|
provide one.'
|
|||
|
SUP top AUXILIARY )
|
|||
|
|
|||
|
Furthermore, the dynamic entry must have the following operational
|
|||
|
attribute. It is described using the AttributeTypeDescription
|
|||
|
notation of [2]:
|
|||
|
|
|||
|
( 1.3.6.1.4.1.1466.101.119.3 NAME 'entryTtl'
|
|||
|
DESC 'This operational attribute is maintained by the server and
|
|||
|
appears to be present in every dynamic entry. The attribute
|
|||
|
is not present when the entry does not contain the
|
|||
|
dynamicObject object class. The value of this attribute is
|
|||
|
the time in seconds that the entry will continue to exist
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 6]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
before disappearing from the directory. In the absence of
|
|||
|
intervening refresh operations, the values returned by
|
|||
|
reading the attribute in two successive searches are
|
|||
|
guaranteed to be nonincreasing. The smallest permissible
|
|||
|
value is 0, indicating that the entry may disappear without
|
|||
|
warning. The attribute is marked NO-USER-MODIFICATION since
|
|||
|
it may only be changed using the refresh operation.'
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.27 SINGLE-VALUE
|
|||
|
NO-USER-MODIFICATION USAGE dSAOperation )
|
|||
|
|
|||
|
To allow servers to support dynamic entries in only a part of the
|
|||
|
DIT, the following operational attribute is defined. It is
|
|||
|
described using the AttributeTypeDescription notation of [2]:
|
|||
|
|
|||
|
( 1.3.6.1.4.1.1466.101.119.4 NAME 'dynamicSubtrees'
|
|||
|
DESC 'This operational attribute is maintained by the server and is
|
|||
|
present in the Root DSE, if the server supports the dynamic
|
|||
|
extensions described in this memo. The attribute contains a
|
|||
|
list of all the subtrees in this directory for which the
|
|||
|
server supports the dynamic extensions.'
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.12 NO-USER-MODIFICATION
|
|||
|
USAGE dSAOperation )
|
|||
|
|
|||
|
6. Client and Server Requirements
|
|||
|
|
|||
|
6.1 Client Requirements
|
|||
|
|
|||
|
Clients can find out if a server supports the dynamic extensions by
|
|||
|
checking the supportedExtension field in the root DSE, to see if the
|
|||
|
OBJECT IDENTIFIER described in section 4 is present. Since servers
|
|||
|
may select to support the dynamic extensions in only some of the
|
|||
|
subtrees of the DIT, clients must check the dynamicSubtrees
|
|||
|
operational attribute in the root DSE to find out if the dynamic
|
|||
|
extensions are supported on a specific subtree.
|
|||
|
|
|||
|
Once a dynamic entry has been created, clients are responsible for
|
|||
|
invoking the refresh extended operation, in order to keep that entry
|
|||
|
present in the directory.
|
|||
|
|
|||
|
Clients must not expect that a dynamic entry will be present in the
|
|||
|
DIT after it has timed out, however it must not require that the
|
|||
|
server remove the entry immediately (some servers may only process
|
|||
|
timing out entries at intervals). If the client wishes to ensure the
|
|||
|
entry does not exist it should issue a RemoveRequest for that entry.
|
|||
|
|
|||
|
Initially, a client needs to know how often it should send refresh
|
|||
|
requests to the server. This value is defined as the CRP (Client
|
|||
|
Refresh Period) and is set by the server based on the entryTtl.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 7]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
Since the LDAP AddRequest operation is left unchanged and is not
|
|||
|
modified in this proposal to return this value, a client must issue a
|
|||
|
Refresh extended operation immediately after an Add that created a
|
|||
|
dynamic entry. The Refresh Response will return the CRP (in
|
|||
|
responseTtl) to the client.
|
|||
|
|
|||
|
Clients must not issue the refresh request for dynamic entries which
|
|||
|
they have not created. If an anonymous client attempts to do so, a
|
|||
|
server is permitted to return insufficientAccessRights (50) in the
|
|||
|
RefreshResponse, enforcing the client to bind first. Please note that
|
|||
|
servers which allow anonymous clients to create and refresh dynamic
|
|||
|
entries will not be able to enforce the above.
|
|||
|
|
|||
|
Clients should always be ready to handle the case in which their
|
|||
|
entry timed out. In such a case, the Refresh operation will fail
|
|||
|
with an error code such as noSuchObject, and the client is expected
|
|||
|
to re-create its entry.
|
|||
|
|
|||
|
Clients should be prepared to experience refresh operations failing
|
|||
|
with protocolError, even though the add and any previous refresh
|
|||
|
requests succeeded. This might happen if a proxy between the client
|
|||
|
and the server goes down, and another proxy is used which does not
|
|||
|
support the Refresh extended operation.
|
|||
|
|
|||
|
6.2 Server Requirements
|
|||
|
|
|||
|
Servers are responsible for removing dynamic entries when they time
|
|||
|
out. Servers are not required to do this immediately.
|
|||
|
|
|||
|
Servers must enforce the structural rules listed in above section 3.
|
|||
|
|
|||
|
Servers must ensure that the operational attribute described in
|
|||
|
section 5 is present in dynamic entries
|
|||
|
|
|||
|
Servers may permit anonymous users to refresh entries. However, to
|
|||
|
eliminate the possibility of a malicious use of the Refresh
|
|||
|
operation, servers may require the refreshing client to bind first. A
|
|||
|
server implementation can achieve this by presenting ACLs on the
|
|||
|
entryTtl attribute, and returning insufficientAccessRights (50) in
|
|||
|
the RefreshResponse, if the client is not allowed to refresh the
|
|||
|
entry. Doing this, though, might have performance implications on the
|
|||
|
server and might impact the server's scalability.
|
|||
|
|
|||
|
Servers may require that a client which attempts to create a dynamic
|
|||
|
entry have a remove permission for that entry.
|
|||
|
|
|||
|
Servers which implement the dynamic extensions must have the OBJECT
|
|||
|
IDENTIFIER, described above in section 4 for the request and
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 8]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
response, present as a value of the supportedExtension field in the
|
|||
|
root DSE. They must also have as values in the attributeTypes and
|
|||
|
objectClasses attributes of their subschema subentries, the
|
|||
|
AttributeTypeDescription and ObjectClassDescription from section 5.
|
|||
|
|
|||
|
Servers can limit the support of the dynamic extensions to only some
|
|||
|
of the subtrees in the DIT. Servers indicate for which subtrees they
|
|||
|
support the extensions, by specifying the OIDs for the supported
|
|||
|
subtrees in the dynamicSubtrees attribute described in section 5. If
|
|||
|
a server supports the dynamic extensions for all naming contexts it
|
|||
|
holds, the dynamicSubtrees attribute may be absent.
|
|||
|
|
|||
|
7. Implementation issues
|
|||
|
|
|||
|
7.1 Storage of dynamic information
|
|||
|
|
|||
|
Dynamic information is expected to change very often. In addition,
|
|||
|
Refresh requests are expected to arrive at the server very often.
|
|||
|
Disk-based databases that static directory services often use are
|
|||
|
likely inappropriate for storing dynamic information. We recommend
|
|||
|
that server implementations store dynamic entries in memory
|
|||
|
sufficient to avoid paging. This is not a requirement.
|
|||
|
|
|||
|
We expect LDAP servers to be able to store static and dynamic
|
|||
|
entries. If an LDAP server does not support dynamic entries, it
|
|||
|
should respond with an error code such as objectClassViolation.
|
|||
|
|
|||
|
7.2 Client refresh behavior
|
|||
|
|
|||
|
In some cases, the client might not get a Refresh response. This may
|
|||
|
happen as a result of a server crash after receiving the Refresh
|
|||
|
request, the TCP/IP socket timing out in the connection case, or the
|
|||
|
UDP packet getting lost in the connection-less case.
|
|||
|
|
|||
|
It is recommended that in such a case, the client will retry the
|
|||
|
Refresh operation immediately, and if this Refresh request does not
|
|||
|
get a response as well, it will resort to its original Refresh cycle,
|
|||
|
i.e. send a Refresh request at its Client Refresh Period (CRP).
|
|||
|
|
|||
|
7.3 Configuration of refresh times
|
|||
|
|
|||
|
We recommend that servers will provide administrators with the
|
|||
|
ability to configure the default client refresh period (CRP), and
|
|||
|
also a minimum and maximum CRP values. This, together with allowing
|
|||
|
administrators to request that the server will not change the CRP
|
|||
|
dynamically, will allow administrators to set CRP values which will
|
|||
|
enforce a low refresh traffic, or - on the other extreme, an highly
|
|||
|
up-to-date directory.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 9]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
8. Replication
|
|||
|
|
|||
|
Replication is only partially addressed in this memo. There is a
|
|||
|
separate effort in progress at the IETF on replication of static and
|
|||
|
dynamic directories.
|
|||
|
|
|||
|
it is allowed to replicate a dynamic entry or a static entry with
|
|||
|
dynamic attributes. Since the entryTtl is expressed as a relative
|
|||
|
time (how many seconds till the entry will expire), replicating it
|
|||
|
means that the replicated entry will be "off" by the replication
|
|||
|
time.
|
|||
|
|
|||
|
9. Localization
|
|||
|
|
|||
|
The are no localization issues for this extended operation.
|
|||
|
|
|||
|
10. Security Considerations
|
|||
|
|
|||
|
Standard LDAP security rules and support apply for the extensions
|
|||
|
described in this document, and there are no special security issues
|
|||
|
for these extensions. Please note, though, that servers may permit
|
|||
|
anonymous clients to refresh entries which they did not create.
|
|||
|
Servers are also permitted to control a refresh access to an entry by
|
|||
|
requiring clients to bind before issuing a RefreshRequest. This will
|
|||
|
have implications on the server performance and scalability.
|
|||
|
|
|||
|
Also, Care should be taken in making use of information obtained from
|
|||
|
directory servers that has been supplied by client, as it may now be
|
|||
|
out of date. In many networks, for example, IP addresses are
|
|||
|
automatically assigned when a host connects to the network, and may
|
|||
|
be reassigned if that host later disconnects. An IP address obtained
|
|||
|
from the directory may no longer be assigned to the host that placed
|
|||
|
the address in the directory. This issue is not specific to LDAP or
|
|||
|
dynamic directories.
|
|||
|
|
|||
|
11. Acknowledgments
|
|||
|
|
|||
|
Design ideas included in this document are based on those discussed
|
|||
|
in ASID and other IETF Working Groups.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 10]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
12. Authors' Addresses
|
|||
|
|
|||
|
Yoram Yaacovi
|
|||
|
Microsoft
|
|||
|
One Microsoft way
|
|||
|
Redmond, WA 98052
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +1 206-936-9629
|
|||
|
EMail: yoramy@microsoft.com
|
|||
|
|
|||
|
|
|||
|
Mark Wahl
|
|||
|
Innosoft International, Inc.
|
|||
|
8911 Capital of Texas Hwy #4140
|
|||
|
Austin, TX 78759
|
|||
|
USA
|
|||
|
|
|||
|
Email: M.Wahl@innosoft.com
|
|||
|
|
|||
|
|
|||
|
Tony Genovese
|
|||
|
Microsoft
|
|||
|
One Microsoft way
|
|||
|
Redmond, WA 98052
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +1 206-703-0852
|
|||
|
EMail: tonyg@microsoft.com
|
|||
|
|
|||
|
13. Bibliography
|
|||
|
|
|||
|
[1] Wahl, M., Howes, T. and S. Kille, "Lightweight Directory Access
|
|||
|
Protocol (Version 3)", RFC 2251, December 1997.
|
|||
|
|
|||
|
[2] Wahl, M. Coulbeck, A., Howes, T. and S. Kille, "Lightweight
|
|||
|
Directory Access Protocol (v3): Attribute Syntax Definitions",
|
|||
|
RFC 2252, December 1997.
|
|||
|
|
|||
|
[3] Wahl, M. and S. Kille, "Lightweight Directory Access Protocol
|
|||
|
(v3): UTF-8 String Representation of Distinguished Names", RFC
|
|||
|
2253, December 1997.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 11]
|
|||
|
|
|||
|
RFC 2589 LDAPv3 Extensions for Dynamic Directory Services May 1999
|
|||
|
|
|||
|
|
|||
|
14. Full Copyright Statement
|
|||
|
|
|||
|
Copyright (C) The Internet Society (1999). 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.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Yaacovi, et al. Standards Track [Page 12]
|
|||
|
|