2007-09-07 20:27:33 +08:00
|
|
|
.TH SLAPD-SOCK 5 "RELEASEDATE" "OpenLDAP LDVERSION"
|
2020-01-10 00:50:21 +08:00
|
|
|
.\" Copyright 2007-2020 The OpenLDAP Foundation All Rights Reserved.
|
2007-09-07 20:27:33 +08:00
|
|
|
.\" Copying restrictions apply. See COPYRIGHT/LICENSE.
|
|
|
|
.\" $OpenLDAP$
|
|
|
|
.SH NAME
|
2011-02-04 04:53:19 +08:00
|
|
|
slapd\-sock \- Socket backend/overlay to slapd
|
2007-09-07 20:27:33 +08:00
|
|
|
.SH SYNOPSIS
|
|
|
|
ETCDIR/slapd.conf
|
|
|
|
.SH DESCRIPTION
|
|
|
|
The Socket backend to
|
|
|
|
.BR slapd (8)
|
|
|
|
uses an external program to handle queries, similarly to
|
2009-06-03 08:43:44 +08:00
|
|
|
.BR slapd\-shell (5).
|
2007-09-07 20:27:33 +08:00
|
|
|
However, in this case the external program listens on a Unix domain socket.
|
|
|
|
This makes it possible to have a pool of processes, which persist between
|
|
|
|
requests. This allows multithreaded operation and a higher level of
|
|
|
|
efficiency. The external program must have been started independently;
|
|
|
|
.BR slapd (8)
|
|
|
|
itself will not start it.
|
2011-02-04 04:53:19 +08:00
|
|
|
|
|
|
|
This module may also be used as an overlay on top of some other database.
|
|
|
|
Use as an overlay allows external actions to be triggered in response to
|
|
|
|
operations on the main database.
|
2007-09-07 20:27:33 +08:00
|
|
|
.SH CONFIGURATION
|
|
|
|
These
|
|
|
|
.B slapd.conf
|
|
|
|
options apply to the SOCK backend database.
|
|
|
|
That is, they must follow a "database sock" line and come before any
|
|
|
|
subsequent "backend" or "database" lines.
|
|
|
|
Other database options are described in the
|
|
|
|
.BR slapd.conf (5)
|
|
|
|
manual page.
|
2011-02-04 04:53:19 +08:00
|
|
|
|
|
|
|
Alternatively, to use this module as an overlay, these directives must
|
|
|
|
follow an "overlay sock" line within an existing database definition.
|
2007-09-07 20:27:33 +08:00
|
|
|
.TP
|
2011-02-04 04:53:19 +08:00
|
|
|
.B extensions [ binddn | peername | ssf | connid ]*
|
2007-09-07 20:27:33 +08:00
|
|
|
Enables the sending of additional meta-attributes with each request.
|
|
|
|
.nf
|
|
|
|
binddn: <bound DN>
|
|
|
|
peername: IP=<address>:<port>
|
|
|
|
ssf: <SSF value>
|
2011-02-04 04:53:19 +08:00
|
|
|
connid: <connection ID>
|
2007-09-07 20:27:33 +08:00
|
|
|
.fi
|
|
|
|
.TP
|
|
|
|
.B socketpath <pathname>
|
|
|
|
Gives the path to a Unix domain socket to which the commands will
|
|
|
|
be sent and from which replies are received.
|
2011-02-04 19:09:00 +08:00
|
|
|
|
|
|
|
When used as an overlay, these additional directives are defined:
|
|
|
|
.TP
|
2017-09-05 21:52:34 +08:00
|
|
|
.B sockops [ bind | unbind | search | compare | modify | modrdn | add | delete | extended ]*
|
2011-02-04 19:09:00 +08:00
|
|
|
Specify which request types to send to the external program. The default is
|
|
|
|
empty (no requests are sent).
|
|
|
|
.TP
|
|
|
|
.B sockresps [ result | search ]*
|
|
|
|
Specify which response types to send to the external program. "result"
|
|
|
|
sends just the results of an operation. "search" sends all entries that
|
|
|
|
the database returned for a search request. The default is empty
|
|
|
|
(no responses are sent).
|
2015-02-04 11:53:13 +08:00
|
|
|
.TP
|
2015-02-04 13:21:46 +08:00
|
|
|
.B sockdnpat <regexp>
|
|
|
|
Specify DN patterns for which the overlay will act. Only operations on
|
|
|
|
DNs matching the specified regular expression will be processed. The default
|
2015-02-04 11:53:13 +08:00
|
|
|
is empty (all DNs are processed).
|
2011-02-04 19:09:00 +08:00
|
|
|
|
2007-09-07 20:27:33 +08:00
|
|
|
.SH PROTOCOL
|
|
|
|
The protocol is essentially the same as
|
2009-06-03 08:43:44 +08:00
|
|
|
.BR slapd\-shell (5)
|
2007-09-07 20:27:33 +08:00
|
|
|
with the addition of a newline to terminate the command parameters. The
|
|
|
|
following commands are sent:
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
ADD
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
<entry in LDIF format>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
BIND
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
dn: <DN>
|
|
|
|
method: <method number>
|
|
|
|
credlen: <length of <credentials>>
|
|
|
|
cred: <credentials>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
COMPARE
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
dn: <DN>
|
|
|
|
<attribute>: <value>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
DELETE
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
dn: <DN>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
2017-09-05 21:52:34 +08:00
|
|
|
EXTENDED
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
oid: <OID>
|
|
|
|
value: <base64-value>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
2007-09-07 20:27:33 +08:00
|
|
|
MODIFY
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
dn: <DN>
|
|
|
|
<repeat {
|
|
|
|
<"add"/"delete"/"replace">: <attribute>
|
|
|
|
<repeat { <attribute>: <value> }>
|
2009-06-03 08:43:44 +08:00
|
|
|
\-
|
2007-09-07 20:27:33 +08:00
|
|
|
}>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
MODRDN
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
dn: <DN>
|
|
|
|
newrdn: <new RDN>
|
|
|
|
deleteoldrdn: <0 or 1>
|
|
|
|
<if new superior is specified: "newSuperior: <DN>">
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
SEARCH
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
base: <base DN>
|
|
|
|
scope: <0-2, see ldap.h>
|
|
|
|
deref: <0-3, see ldap.h>
|
|
|
|
sizelimit: <size limit>
|
|
|
|
timelimit: <time limit>
|
|
|
|
filter: <filter>
|
|
|
|
attrsonly: <0 or 1>
|
|
|
|
attrs: <"all" or space-separated attribute list>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
UNBIND
|
|
|
|
msgid: <message id>
|
|
|
|
<repeat { "suffix:" <database suffix DN> }>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
.LP
|
|
|
|
The commands - except \fBunbind\fP - should output:
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
RESULT
|
|
|
|
code: <integer>
|
|
|
|
matched: <matched DN>
|
|
|
|
info: <text>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
where only RESULT is mandatory, and then close the socket.
|
|
|
|
The \fBsearch\fP RESULT should be preceded by the entries in LDIF
|
|
|
|
format, each entry followed by a blank line.
|
|
|
|
Lines starting with `#' or `DEBUG:' are ignored.
|
2011-02-04 05:25:42 +08:00
|
|
|
|
2011-02-04 19:09:00 +08:00
|
|
|
When used as an overlay, the external program should return a
|
|
|
|
CONTINUE response if request processing should continue normally, or
|
|
|
|
a regular RESULT response if the external program wishes to bypass the
|
|
|
|
underlying database.
|
|
|
|
|
|
|
|
If the overlay is configured to send response messages to the external
|
|
|
|
program, they will appear as an extended RESULT message or as an
|
|
|
|
ENTRY message, defined below. The RESULT message is similar to
|
|
|
|
the one above, but also includes the msgid and any configured
|
|
|
|
extensions:
|
2011-02-04 05:25:42 +08:00
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
RESULT
|
|
|
|
msgid: <message id>
|
|
|
|
code: <integer>
|
|
|
|
matched: <matched DN>
|
|
|
|
info: <text>
|
2011-02-04 19:09:00 +08:00
|
|
|
<blank line>
|
2011-02-04 05:25:42 +08:00
|
|
|
.fi
|
|
|
|
.RE
|
2011-02-04 19:09:00 +08:00
|
|
|
|
2011-02-04 05:25:42 +08:00
|
|
|
Typically both the msgid and the connid will be needed to match
|
2011-02-04 19:09:00 +08:00
|
|
|
a result message to a request. The ENTRY message has the form
|
|
|
|
.RS
|
|
|
|
.nf
|
|
|
|
ENTRY
|
|
|
|
msgid: <message id>
|
|
|
|
<entry in LDIF format>
|
|
|
|
<blank line>
|
|
|
|
.fi
|
|
|
|
.RE
|
|
|
|
|
2017-09-05 21:52:34 +08:00
|
|
|
.SH KNOWN LIMITATIONS
|
|
|
|
The
|
|
|
|
.B sock
|
|
|
|
backend does not process extended operation results from an external program.
|
|
|
|
|
2007-09-07 20:27:33 +08:00
|
|
|
.SH ACCESS CONTROL
|
|
|
|
The
|
|
|
|
.B sock
|
|
|
|
backend does not honor all ACL semantics as described in
|
|
|
|
.BR slapd.access (5).
|
|
|
|
In general, access to objects is checked by using a dummy object
|
|
|
|
that contains only the DN, so access rules that rely on the contents
|
|
|
|
of the object are not honored.
|
|
|
|
In detail:
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B add
|
|
|
|
operation does not require
|
|
|
|
.B write (=w)
|
|
|
|
access to the
|
|
|
|
.B children
|
|
|
|
pseudo-attribute of the parent entry.
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B bind
|
|
|
|
operation requires
|
|
|
|
.B auth (=x)
|
|
|
|
access to the
|
|
|
|
.B entry
|
|
|
|
pseudo-attribute of the entry whose identity is being assessed;
|
|
|
|
.B auth (=x)
|
|
|
|
access to the credentials is not checked, but rather delegated
|
|
|
|
to the underlying program.
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B compare
|
|
|
|
operation requires
|
|
|
|
.B compare (=c)
|
2007-12-27 08:51:45 +08:00
|
|
|
access to the
|
2007-09-07 20:27:33 +08:00
|
|
|
.B entry
|
|
|
|
pseudo-attribute
|
|
|
|
of the object whose value is being asserted;
|
|
|
|
.B compare (=c)
|
|
|
|
access to the attribute whose value is being asserted is not checked.
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B delete
|
|
|
|
operation does not require
|
|
|
|
.B write (=w)
|
|
|
|
access to the
|
|
|
|
.B children
|
|
|
|
pseudo-attribute of the parent entry.
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B modify
|
|
|
|
operation requires
|
|
|
|
.B write (=w)
|
|
|
|
access to the
|
|
|
|
.B entry
|
|
|
|
pseudo-attribute;
|
|
|
|
.B write (=w)
|
|
|
|
access to the specific attributes that are modified is not checked.
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B modrdn
|
|
|
|
operation does not require
|
|
|
|
.B write (=w)
|
|
|
|
access to the
|
|
|
|
.B children
|
|
|
|
pseudo-attribute of the parent entry, nor to that of the new parent,
|
|
|
|
if different;
|
|
|
|
.B write (=w)
|
|
|
|
access to the distinguished values of the naming attributes
|
|
|
|
is not checked.
|
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B search
|
|
|
|
operation does not require
|
|
|
|
.B search (=s)
|
|
|
|
access to the
|
|
|
|
.B entry
|
|
|
|
pseudo_attribute of the searchBase;
|
|
|
|
.B search (=s)
|
|
|
|
access to the attributes and values used in the filter is not checked.
|
2017-09-05 21:52:34 +08:00
|
|
|
.LP
|
|
|
|
The
|
|
|
|
.B extended
|
|
|
|
operation does not require any access special rights.
|
|
|
|
The external program has to implement any sort of access control.
|
2007-09-07 20:27:33 +08:00
|
|
|
|
|
|
|
.SH EXAMPLE
|
2009-06-03 08:43:44 +08:00
|
|
|
There is an example script in the slapd/back\-sock/ directory
|
2007-09-07 20:27:33 +08:00
|
|
|
in the OpenLDAP source tree.
|
|
|
|
.SH FILES
|
|
|
|
.TP
|
|
|
|
ETCDIR/slapd.conf
|
|
|
|
default slapd configuration file
|
|
|
|
.SH SEE ALSO
|
|
|
|
.BR slapd.conf (5),
|
2009-01-30 08:23:58 +08:00
|
|
|
.BR slapd\-config (5),
|
2007-09-07 20:27:33 +08:00
|
|
|
.BR slapd (8).
|
|
|
|
.SH AUTHOR
|
2011-02-04 04:53:19 +08:00
|
|
|
Brian Candler, with enhancements by Howard Chu
|