1 .TH LDAP_CONTROLS 3 "RELEASEDATE" "OpenLDAP LDVERSION"
2 .\" $OpenLDAP: pkg/ldap/doc/man/man3/ldap_controls.3,v 1.1.2.3 2008/02/11 23:26:39 kurt Exp $
3 .\" Copyright 1998-2008 The OpenLDAP Foundation All Rights Reserved.
4 .\" Copying restrictions apply. See COPYRIGHT/LICENSE.
6 ldap_control_create, ldap_control_find, ldap_control_dup,
7 ldap_controls_dup, ldap_control_free, ldap_controls_free
8 \- LDAP control manipulation routines
10 OpenLDAP LDAP (libldap, -lldap)
14 .BI "int ldap_control_create(const char *" oid ", int " iscritical ", struct berval *" value ", int " dupval ", LDAPControl **" ctrlp ");"
16 .BI "LDAPControl *ldap_control_find( const char *" oid ", LDAPControl **" ctrls ", LDAPControl ***" nextctrlp ");"
18 .BI "LDAPControl *ldap_control_dup(LDAPControl *" ctrl ");"
20 .BI "LDAPControl **ldap_controls_dup(LDAPControl **" ctrls ");"
22 .BI "void ldap_control_free(LDAPControl *" ctrl ");"
24 .BI "void ldap_controls_free(LDAPControl **" ctrls ");"
26 These routines are used to manipulate structures used for LDAP controls.
28 .BR ldap_control_create ()
29 creates a control with the specified
31 using the contents of the
33 parameter for the control value, if any. The content of
39 parameter must be non-zero for a critical control. The created control
42 parameter. The routine returns
44 on success or some other error code on failure.
47 for supported control types, can be prepared using helpers provided
48 by this implementation of libldap, usually in the form
49 .BR "ldap_create_<control name>_control_value" ().
50 Otherwise, it can be BER-encoded using the functionalities of liblber.
52 .BR ldap_control_find ()
53 searches the NULL-terminated
55 array for a control whose OID matches the
57 parameter. The routine returns a pointer to the control if found,
61 is not NULL, on return it will point to the next control
62 in the array, and can be passed to the
63 .BR ldap_control_find ()
64 routine for subsequent calls, to find further occurrences of the same
66 The use of this function is discouraged; the recommended way of handling
67 controls in responses consists in going through the array of controls,
68 dealing with each of them in the returned order, since it could matter.
70 .BR ldap_control_dup ()
71 duplicates an individual control structure, and
72 .BR ldap_controls_dup ()
73 duplicates a NULL-terminated array of controls.
75 .BR ldap_control_free ()
76 frees an individual control structure, and
77 .BR ldap_controls_free ()
78 frees a NULL-terminated array of controls.