LDAP_GET_OPTION(3LDAP) LDAP Library Functions LDAP_GET_OPTION(3LDAP)

NAME


ldap_get_option, ldap_set_option - get or set session preferences in
the ldap structure.

SYNOPSIS


cc [ flag... ] file... -lldap [ library... ]
#include <lber.h>
#include <ldap.h>

LDAP ldap_set_option(LDAP *ld, int option, void *optdata[]);


LDAP ldap_get_option(LDAP *ld, int option, void optdata[]);


DESCRIPTION


These functions provide an LDAP structure with access to session
preferences. The ldap_get_option() function gets session preferences
from the LDAP structure. The ldap_set_option() function sets session
preferences in the LDAP structure.


The ld parameter specifies the connection handle, a pointer to an
LDAP structure that contains information about the LDAP server
connection. The option parameter specifies the name of the option to
be read or modified. The optdata parameter serves as a pointer to the
value of the option that you set or get.

PARAMETERS


The following values can be specified for the option parameter:

LDAP_OPT_API_INFO

Retrieves basic information about the LDAP API implementation at
execution time. The data type for the optdata parameter is
(LDAPAPIInfo *). This option is READ-ONLY and cannot be set.


LDAP_OPT_DEREF

Determines how aliases are handled during a search. The data type
for the optdata parameter is (int *). The following values can be
specified for the optdata parameter:

LDAP_DEREF_NEVER
Specifies that aliases are never
dereferenced.


LDAP_DEREF_SEARCHING
Specifies that aliases are dereferenced
when searching under the base object, but
not when finding the base object.


LDAP_DEREF_FINDING
Specifies that aliases are dereferenced
when finding the base object, but not
when searching under the base object.


LDAP_DEREF_ALWAYS
Specifies that aliases are always
dereferenced when finding the base object
and searching under the base object.


LDAP_OPT_SIZELIMIT

Specifies the maximum number of entries returned by the server in
search results. The data type for the optdata parameter is (int
*). Setting the optdata parameter to LDAP_NO_LIMIT removes any
size limit enforced by the client.


LDAP_OPT_TIMELIMIT

Specifies the maximum number of seconds spent by the server when
answering a search request. The data type for the optdata
parameter is (int *). Setting the optdata parameter to
LDAP_NO_LIMIT removes any time limit enforced by the client.


LDAP_OPT_REFERRALS

Determines whether the client should follow referrals. The data
type for the optdata parameter is (int *). The following values
can be specified for the optdata parameter:

LDAP_OPT_ON
Specifies that the client should follow
referrals.


LDAP_OPT_OFF
Specifies that the client should not follow
referrals.

By default, the client follows referrals.


LDAP_OPT_RESTART

Determines whether LDAP I/O operations are automatically
restarted if aborted prematurely. It can be set to one of the
constants LDAP_OPT_ON or LDAP_OPT_OFF.


LDAP_OPT_PROTOCOL_VERSION

Specifies the version of the protocol supported by the client.
The data type for the optdata parameter is (int *). The version
LDAP_VERSION2 or LDAP_VERSION3 can be specified. If no version is
set, the default version LDAP_VERSION2 is set. To use LDAP v3
features, set the protocol version to LDAP_VERSION3.


LDAP_OPT_SERVER_CONTROLS

Specifies a pointer to an array of LDAPControl structures that
represent the LDAP v3 server controls sent by default with every
request. The data type for the optdata parameter for
ldap_set_option() is (LDAPControl **). For ldap_get_option(), the
data type is (LDAPControl ***).


LDAP_OPT_CLIENT_CONTROLS

Specifies a pointer to an array of LDAPControl structures that
represent the LDAP v3 client controls sent by default with every
request. The data type for the optdata parameter for
ldap_set_option() is (LDAPControl **). For ldap_get_option(), the
data type is (LDAPControl ***).


LDAP_OPT_API_FEATURE_INFO

Retrieves version information at execution time about extended
features of the LDAP API. The data type for the optdata parameter
is (LDAPAPIFeatureInfo *). This option is READ-ONLY and cannot be
set.


LDAP_OPT_HOST_NAME

Sets the host name or a list of hosts for the primary LDAP
server. The data type for the optdata parameter for
ldap_set_option() is (char *). For ldap_get_option(), the data
type is (char **).


LDAP_OPT_ERROR_NUMBER

Specifies the code of the most recent LDAP error that occurred
for this session. The data type for the optdata parameter is (int
*).


LDAP_OPT_ERROR_STRING

Specifies the message returned with the most recent LDAP error
that occurred for this session. The data type for the optdata
parameter for ldap_set_option() is (char *) and for
ldap_get_option() is (char **).


LDAP_OPT_MATCHED_DN

Specifies the matched DN value returned with the most recent LDAP
error that occurred for this session. The data type for the
optdata parameter for ldap_set_option() is (char *) and for
ldap_get_option() is (char **).


LDAP_OPT_REBIND_ARG

Sets the last argument passed to the routine specified by
LDAP_OPT_REBIND_FN. This option can also be set by calling the
ldap_set_rebind_proc() function. The data type for the optdata
parameter is (void * ).


LDAP_OPT_REBIND_FN

Sets the routine to be called to authenticate a connection with
another LDAP server. For example, the option is used to set the
routine called during the course of a referral. This option can
also be by calling the ldap_set_rebind_proc() function. The data
type for the optdata parameter is (LDAP_REBINDPROC_CALLBACK *).


LDAP_OPT_X_SASL_MECH

Sets the default SASL mechanism to call
ldap_interactive_bind_s(). The data type for the optdata
parameter is (char * ).


LDAP_OPT_X_SASL_REALM

Sets the default SASL_REALM. The default SASL_REALM should be
used during a SASL challenge in response to a SASL_CB_GETREALM
request when using the ldap_interactive_bind_s() function. The
data type for the optdata parameter is (char * ).


LDAP_OPT_X_SASL_AUTHCID

Sets the default SASL_AUTHNAME used during a SASL challenge in
response to a SASL_CB_AUTHNAME request when using the
ldap_interactive_bind_s() function. The data type for the optdata
parameter is (char * ).


LDAP_OPT_X_SASL_AUTHZID

Sets the default SASL_USER that should be used during a SASL
challenge in response to a SASL_CB_USER request when using the
ldap_interactive_bind_s function. The data type for the optdata
parameter is (char * ).


LDAP_OPT_X_SASL_SSF

A read-only option used exclusively with the ldap_get_option()
function. The ldap_get_option() function performs a
sasl_getprop() operation that gets the SASL_SSF value for the
current connection. The data type for the optdata parameter is
(sasl_ssf_t * ).


LDAP_OPT_X_SASL_SSF_EXTERNAL

A write-only option used exclusively with the ldap_set_option()
function. The ldap_set_option() function performs a
sasl_setprop() operation to set the SASL_SSF_EXTERNAL value for
the current connection. The data type for the optdata parameter
is (sasl_ssf_t * ).


LDAP_OPT_X_SASL_SECPROPS

A write-only option used exclusively with the ldap_set_option().
This function performs a sasl_setprop(3SASL) operation for the
SASL_SEC_PROPS value for the current connection during an
ldap_interactive_bind_s() operation. The data type for the
optdata parameter is (char * ), a comma delimited string
containing text values for any of the SASL_SEC_PROPS that should
be set. The text values are:

noanonymous
Sets the SASL_SEC_NOANONYMOUS flag


nodict
Sets the SASL_SEC_NODICTIONARY flag


noplain
Sets the SASL_SEC_NOPLAINTEXT flag


forwardsec
Sets the SASL_SEC_FORWARD_SECRECY flag


passcred
Sets the SASL_SEC_PASS_CREDENTIALS flag


minssf=N
Sets minssf to the integer value N


maxssf=N
Sets maxssf to the integer value N


maxbufsize=N
Sets maxbufsize to the integer value N


LDAP_OPT_X_SASL_SSF_MIN

Sets the default SSF_MIN value used during a
ldap_interactive_bind_s() operation. The data type for the
optdata parameter is (char * ) numeric string.


LDAP_OPT_X_SASL_SSF_MAX

Sets the default SSF_MAX value used during a
ldap_interactive_bind_s() operation. The data type for the
optdata parameter is (char * ) numeric string.


LDAP_OPT_X_SASL_MAXBUFSIZE

Sets the default SSF_MAXBUFSIZE value used during a
ldap_interactive_bind_s() operation. The data type for the
optdata parameter is (char * ) numeric string.


RETURN VALUES


The ldap_set_option() and ldap_get_option() functions return:

LDAP_SUCCESS
If successful


-1
If unsuccessful


ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Evolving |
+--------------------+-----------------+
|MT-Level | Safe |
+--------------------+-----------------+

SEE ALSO


ldap_init(3LDAP), sasl_setprop(3SASL), attributes(7)

NOTES


There are other elements in the LDAP structure that should not be
changed. No assumptions should be made about the order of elements in
the LDAP structure.

January 15, 2004 LDAP_GET_OPTION(3LDAP)

tribblix@gmail.com :: GitHub :: Privacy