mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-06 10:46:21 +08:00
464 lines
17 KiB
Plaintext
464 lines
17 KiB
Plaintext
|
||
Network Working Group M. Smith, Editor
|
||
INTERNET-DRAFT G. Good
|
||
Intended Category: Informational R. Weltman
|
||
Expires: September 2000 Netscape Communications Corp.
|
||
T. Howes
|
||
Loudcloud, Inc.
|
||
|
||
7 March 2000
|
||
|
||
|
||
Persistent Search: A Simple LDAP Change Notification Mechanism
|
||
<draft-ietf-ldapext-psearch-02.txt>
|
||
|
||
|
||
|
||
|
||
|
||
1. Status of this Memo
|
||
|
||
This document is an Internet-Draft and is in full conformance with all
|
||
provisions of Section 10 of RFC2026. Internet-Drafts are working docu-
|
||
ments of the Internet Engineering Task Force (IETF), its areas, and its
|
||
working groups. Note that other groups may also distribute working
|
||
documents as Internet-Drafts.
|
||
|
||
Internet-Drafts are draft documents valid for a maximum of six months
|
||
and may be updated, replaced, or obsoleted by other documents at any
|
||
time. It is inappropriate to use Internet-Drafts as reference material
|
||
or to cite them other than as "work in progress."
|
||
|
||
The list of current Internet-Drafts can be accessed at
|
||
http://www.ietf.org/ietf/1id-abstracts.txt.
|
||
|
||
The list of Internet-Draft Shadow Directories can be accessed at
|
||
http://www.ietf.org/shadow.html.
|
||
|
||
This draft document will be submitted to the RFC Editor as an Informa-
|
||
tional document. Distribution of this memo is unlimited. Technical dis-
|
||
cussion of this document will take place on the IETF LDAP Extension
|
||
Working Group mailing list <ietf-ldapext@netscape.com>. Please send
|
||
editorial comments directly to the editor <mcs@netscape.com>.
|
||
|
||
Copyright (C) The Internet Society (1997-2000). All Rights Reserved.
|
||
|
||
Please see the Copyright section near the end of this document for more
|
||
information.
|
||
|
||
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 1]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
2. Abstract
|
||
|
||
This document defines two controls that extend the LDAPv3 [LDAP] search
|
||
operation to provide a simple mechanism by which an LDAP client can
|
||
receive notification of changes that occur in an LDAP server. The
|
||
mechanism is designed to be very flexible yet easy for clients and
|
||
servers to implement. Since the IETF is likely to pursue a different,
|
||
more comprehensive solution in this area, this document will eventually
|
||
be published with Informational status in order to document an existing
|
||
practice.
|
||
|
||
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
|
||
"SHOULD", "SHOULD NOT", "RECOMMENDED", and "MAY" in this document are
|
||
to be interpreted as described in RFC 2119 [KEYWORDS].
|
||
|
||
|
||
|
||
3. General Approach
|
||
|
||
The approach taken by the Persistent Search mechanism described in this
|
||
document is to alter the standard LDAP search operation so that it does
|
||
not end after the initial set of entries matching the search criteria
|
||
are returned. Instead, LDAP servers keep the search operation going.
|
||
This provides clients and servers participating in Persistent Search
|
||
with an active channel through which entries that change (and additional
|
||
information about the changes that occur) can be communicated.
|
||
|
||
|
||
|
||
4. Persistent Search Control
|
||
|
||
This control may be included in the Controls portion of an LDAPv3 Sear-
|
||
chRequest message. The controlType is "2.16.840.1.113730.3.4.3".
|
||
|
||
PersistentSearch ::= SEQUENCE {
|
||
changeTypes INTEGER,
|
||
changesOnly BOOLEAN,
|
||
returnECs BOOLEAN
|
||
}
|
||
|
||
Upon receiving this control, a server that supports it MUST process this
|
||
as a standard LDAPv3 search with the following exceptions:
|
||
|
||
|
||
a) If changesOnly is TRUE, the server MUST NOT return any existing
|
||
entries that match the search criteria. Entries are only
|
||
returned when they are changed (added, modified, deleted, or
|
||
subject to a modifyDN operation).
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 2]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
b) The server MUST NOT return a SearchResult message. Instead, the
|
||
search operation MUST be kept active until it is abandoned by
|
||
the client or until the client unbinds.
|
||
|
||
|
||
c) As changes are made to the server, the effected entries MUST be
|
||
returned to the client if they match the standard search cri-
|
||
teria and if the operation that caused the change is included in
|
||
the changeTypes field. The changeTypes field is the logical OR
|
||
of one or more of these values: add (1), delete (2), modify (4),
|
||
modDN (8).
|
||
|
||
|
||
d) If returnECs is TRUE, the server MUST return an Entry Change
|
||
Notification control with each entry returned as the result of
|
||
changes. This control is described in the next section.
|
||
|
||
|
||
|
||
5. Entry Change Notification Control
|
||
|
||
This control provides additional information about the change the caused
|
||
a particular entry to be returned as the result of a persistent search.
|
||
The controlType is "2.16.840.1.113730.3.4.7". If the client set the
|
||
returnECs boolean to TRUE in the PersistentSearch control, servers MUST
|
||
include an EntryChangeNotification control in the Controls portion of
|
||
each SearchResultEntry that is returned due to an entry being added,
|
||
deleted, or modified.
|
||
|
||
EntryChangeNotification ::= SEQUENCE {
|
||
changeType ENUMERATED {
|
||
add (1),
|
||
delete (2),
|
||
modify (4),
|
||
modDN (8)
|
||
},
|
||
previousDN LDAPDN OPTIONAL, -- modifyDN ops. only
|
||
changeNumber INTEGER OPTIONAL -- if supported
|
||
}
|
||
|
||
changeType indicates what LDAP operation caused the entry to be
|
||
returned.
|
||
|
||
previousDN is present only for modifyDN operations and gives the DN of
|
||
the entry before it was renamed and/or moved. Servers MUST include this
|
||
optional field only when returning change notifications as a result of
|
||
modifyDN operations.
|
||
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 3]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
changeNumber is the change number [CHANGELOG] assigned by a server for
|
||
the change. If a server supports an LDAP Change Log it SHOULD include
|
||
this field.
|
||
|
||
|
||
|
||
6. Intended Use
|
||
|
||
Some of the scenarios that the Persistent Search mechanism described in
|
||
this document is designed to support are described in this section.
|
||
Other uses of the mechanism are possible as well, but please refer to
|
||
the "Implementation Considerations" section for some issues to consider.
|
||
|
||
|
||
6.1. Cache Consistency
|
||
|
||
An LDAP client application with high performance needs may want to main-
|
||
tain a temporary, local cache of information obtained through LDAP
|
||
search, compare, or bind operations. To improve performance, the local
|
||
cache is always consulted before sending a request to an LDAP server.
|
||
The client application can use Persistent Search(es) against the change-
|
||
log [CHANGELOG] (if one is available) or against one or more subtrees
|
||
within the LDAP server to enable it to maintain consistency between the
|
||
data in its local cache and the data stored in the LDAP server. A Per-
|
||
sistent Search request where the changesOnly flag is FALSE can be used
|
||
if it is desirable to prime the cache; otherwise changesOnly would typi-
|
||
cally be set to TRUE in the request.
|
||
|
||
Caches are used for reasons other than performance improvement as well.
|
||
In some cases, they arise naturally out of a particular application's
|
||
design. For example, an LDAP client designed for administration of
|
||
information held in LDAP servers will undoubtedly generate screen
|
||
displays that show information gleaned from an LDAP server. The screen
|
||
display is a cache that is active and visible until the user of the
|
||
application takes some action that causes different information to be
|
||
displayed. A refresh button or similar control may be provided to the
|
||
user to allow them to update the cached display. A Persistent Search
|
||
request can be used instead by the administrative application to
|
||
automatically refresh the screen display as soon as the underlying LDAP
|
||
information changes.
|
||
|
||
|
||
6.2. Synchronization
|
||
|
||
Some LDAP clients such as those that execute on a portable computer may
|
||
maintain a partial or complete offline copy of the entries stored in an
|
||
LDAP server. While connected to the network, such a client can direct
|
||
all queries to the copy of data it holds and use a Persistent Search to
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 4]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
actively maintain the contents of the offline copy (alternatively, the
|
||
client could direct requests to the LDAP server that is the source of
|
||
the data). While disconnected from the network, the client must satisfy
|
||
all queries using its offline copy of the data. When the client recon-
|
||
nects to the network, it can synchronize its own copy of the data with
|
||
the one stored on the LDAP server and proceed to actively maintain its
|
||
offline copy by issuing a Persistent Search with the changesOnly flag
|
||
set to FALSE against the server's changelog [CHANGELOG]. A search
|
||
filter like "(changeNumber>=NUM)" where NUM is an integer one greater
|
||
than the last change the client processed would be used to limit the
|
||
entries returned to the set of changes the client has not yet seen.
|
||
|
||
|
||
6.3. Triggered Actions
|
||
|
||
An LDAP client application may want to take some action when an entry in
|
||
the directory is changed. A Persistent Search request can be used to
|
||
proactively monitor one or more LDAP servers for interesting changes
|
||
that in turn cause specific actions to be taken by an application. For
|
||
example, an electronic mail repository may want to perform a "create
|
||
mailbox" task when a new person entry is added to an LDAP directory and
|
||
a "delete mailbox" task when a person entry is deleted from an LDAP
|
||
directory.
|
||
|
||
|
||
|
||
7. Implementation Considerations
|
||
|
||
Implementors of servers that support the mechanism described in this
|
||
document should ensure that their implementation scales well as the
|
||
number of active Persistent Search requests increases and as the number
|
||
of changes made in the directory increases.
|
||
|
||
Each active Persistent Search request requires that an open TCP connec-
|
||
tion be maintained between an LDAP client and an LDAP server that might
|
||
not otherwise be kept open. Therefore, client implementors are
|
||
encouraged to avoid using Persistent Search for non-essential tasks and
|
||
to close idle LDAP connections as soon as practical. Server implemen-
|
||
tors are encouraged to support a large number of client connections if
|
||
they need to support large numbers of Persistent Search clients.
|
||
|
||
|
||
This specification makes no guarantees about how soon a server should
|
||
send notification of a changed entry to a Persistent Search client.
|
||
This is intentional as any specific maximum delay would be impossible to
|
||
meet in a distributed directory service implementation. Server imple-
|
||
mentors are encouraged to minimize the delay before sending notifica-
|
||
tions to ensure that clients' needs for timeliness of change
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 5]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
notification are met.
|
||
|
||
|
||
|
||
8. Security Considerations
|
||
|
||
In some situations, it may be important to prevent general exposure of
|
||
information about changes that occur in an LDAP server. Therefore,
|
||
servers that implement the mechanism described in this document SHOULD
|
||
provide a means to enforce access control on the entries returned and
|
||
MAY also provide specific access control mechanisms to control the use
|
||
of the PersistentSearch and EntryChangeNotification controls.
|
||
|
||
|
||
As with normal LDAP search requests, a malicious client can initiate a
|
||
large number of Persistent Search requests in an attempt to consume all
|
||
available server resources and deny service to legitimate clients. For
|
||
this reason, servers that implement the mechanism described in the docu-
|
||
ment SHOULD provide a means to limit the number of resources that can be
|
||
consumed by a single client.
|
||
|
||
|
||
|
||
9. Copyright
|
||
|
||
Copyright (C) The Internet Society (1997-2000). All Rights Reserved.
|
||
|
||
This document and translations of it may be copied and furnished to oth-
|
||
ers, and derivative works that comment on or otherwise explain it or
|
||
assist in its implementation may be prepared, copied, published and dis-
|
||
tributed, 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 Stan-
|
||
dards 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
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 6]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
FITNESS FOR A PARTICULAR PURPOSE.
|
||
|
||
|
||
|
||
10. Bibliography
|
||
|
||
[KEYWORDS] S. Bradner, "Key words for use in RFCs to Indicate Require-
|
||
ment Levels", RFC 2119, March 1997.
|
||
|
||
[LDAP] M. Wahl, T. Howes, S. Kille, "Lightweight Directory Access
|
||
Protocol (v3)", RFC 2251, December 1997.
|
||
|
||
[CHANGELOG] G. Good, "Definition of an Object Class to Hold LDAP Change
|
||
Record", INTERNET-DRAFT <draft-ietf-asid-changelog-01.txt>,
|
||
July 1997.
|
||
|
||
[PSEARCHAPI] M. Smith, "LDAP C API Extensions for Persistent Search",
|
||
INTERNET-DRAFT <draft-ietf-ldapext-c-api-psearch-00.txt>,
|
||
March 1998.
|
||
|
||
|
||
|
||
11. Authors' Addresses
|
||
|
||
Mark Smith
|
||
Netscape Communications Corp.
|
||
501 E. Middlefield Rd., Mailstop MV068
|
||
Mountain View, CA 94043
|
||
USA
|
||
+1 650 937-3477
|
||
mcs@netscape.com
|
||
|
||
Gordon Good
|
||
Netscape Communications Corp.
|
||
501 E. Middlefield Rd., Mailstop MV068
|
||
Mountain View, CA 94043
|
||
USA
|
||
+1 650 937-3825
|
||
ggood@netscape.com
|
||
|
||
Rob Weltman
|
||
Netscape Communications Corp.
|
||
501 E. Middlefield Rd., Mailstop MV068
|
||
Mountain View, CA 94043
|
||
USA
|
||
+1 650 937-3301
|
||
rweltman@netscape.com
|
||
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 7]
|
||
|
||
LDAP Persistent Search 7 March 2000
|
||
|
||
|
||
Tim Howes
|
||
Loudcloud, Inc.
|
||
615 Tasman Dr.
|
||
Sunnyvale, CA 94089
|
||
USA
|
||
+1 650 321 4565
|
||
howes@loudcloud.com
|
||
|
||
|
||
|
||
12. Appendix A: Changes since draft-ietf-ldapext-psearch-01.txt
|
||
|
||
"Status of this Memo" section: changed "Intended Category" to Infor-
|
||
mational. Also updated boilerplate text to reflect current I-D
|
||
guidelines and updated copyright to include the year "2000."
|
||
|
||
"Abstract" section: added sentence that says why this will be pub-
|
||
lished as Informational.
|
||
|
||
"Entry Change Notification Control" section: added the word "only" to
|
||
clarify that the previousDN field is only returned for modifyDN
|
||
operations.
|
||
|
||
"Authors' Addresses" section: updated Tim Howes' information.
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
Smith, et. al. Intended Category: Informational [Page 8]
|
||
|
||
|
||
|
||
1. Status of this Memo............................................1
|
||
2. Abstract.......................................................2
|
||
3. General Approach...............................................2
|
||
4. Persistent Search Control......................................2
|
||
5. Entry Change Notification Control..............................3
|
||
6. Intended Use...................................................4
|
||
6.1. Cache Consistency...........................................4
|
||
6.2. Synchronization.............................................4
|
||
6.3. Triggered Actions...........................................5
|
||
7. Implementation Considerations..................................5
|
||
8. Security Considerations........................................6
|
||
9. Copyright......................................................6
|
||
10. Bibliography...................................................7
|
||
11. Authors' Addresses.............................................7
|
||
12. Appendix A: Changes since draft-ietf-ldapext-psearch-01.txt...8
|