ldap_init_templates
LDAP_DISPTMPL(3) LDAP_DISPTMPL(3)
NAME
ldap_init_templates, ldap_init_templates_buf, ldap_free_templates,
ldap_first_disptmpl, ldap_next_disptmpl, ldap_oc2template, ldap_tmplat-
trs, ldap_first_tmplrow, ldap_next_tmplrow, ldap_first_tmplcol,
ldap_next_tmplcol, - LDAP display template routines
SYNOPSIS
#include <disptmpl.h>
int ldap_init_templates( file, tmpllistp )
char *file;
struct ldap_disptmpl **tmpllistp;
int ldap_init_templates_buf( buf, buflen, tmpllistp )
char *buf;
unsigned long len;
struct ldap_disptmpl **tmpllistp;
void ldap_free_templates( tmpllist )
struct ldap_disptmpl *tmpllist;
struct ldap_disptmpl *ldap_first_disptmpl( tmpllist )
struct ldap_disptmpl *tmpllist;
struct ldap_disptmpl *ldap_next_disptmpl( tmpllist, tmpl )
struct ldap_disptmpl *tmpllist;
struct ldap_disptmpl *tmpl;
struct ldap_disptmpl *ldap_oc2template( oclist, tmpllist )
char **oclist;
struct ldap_disptmpl *tmpllist;
struct ldap_disptmpl *ldap_name2template( name, tmpllist )
char *name;
struct ldap_disptmpl *tmpllist;
char **ldap_tmplattrs( tmpl, includeattrs, exclude, syntaxmask )
struct ldap_disptmpl *tmpl;
char **includeattrs;
int exclude;
unsigned long syntaxmask;
struct ldap_tmplitem *ldap_first_tmplrow( tmpl )
struct ldap_disptmpl *tmpl;
struct ldap_tmplitem *ldap_next_tmplrow( tmpl, row )
struct ldap_disptmpl *tmpl;
struct ldap_tmplitem *row;
struct ldap_tmplitem *ldap_first_tmplcol( tmpl, row )
struct ldap_disptmpl *tmpl;
struct ldap_tmplitem *row;
struct ldap_tmplitem *ldap_next_tmplcol( tmpl, row, col )
struct ldap_disptmpl *tmpl;
struct ldap_tmplitem *row;
struct ldap_tmplitem *col;
DESCRIPTION
These functions provide a standard way to access LDAP entry display
templates. Entry display templates provide a standard way for LDAP
applications to display directory entries. The general idea is that it
is possible to map the list of object class values present in an entry
to an appropriate display template. Display templates are defined in a
configuration file (see ldaptemplates.conf(5)). Each display template
contains a pre-determined list of items, where each item generally cor-
responds to an attribute to be displayed. The items contain informa-
tion and flags that the caller can use to display the attribute and
values in a reasonable fashion. Each item has a syntaxid, which are
described in the SYNTAX IDS section below. The ldap_entry2text(3) rou-
tines use the display template functions and produce text output.
ldap_init_templates() reads a sequence of templates from a valid LDAP
template configuration file (see ldaptemplates.conf(5)) Zero is
returned upon success, and tmpllistp is set to point to a list of tem-
plates. Each member of the list is an ldap_disptmpl structure (defined
below in the DISPTMPL STRUCTURE ELEMENTS section).
ldap_init_templates_buf() reads a sequence of templates from buf (whose
size is buflen). buf should point to the data in the format defined
for an LDAP template configuration file (see ldaptemplates.conf(5))
Zero is returned upon success, and tmpllistp is set to point to a list
of templates.
The LDAP_SET_DISPTMPL_APPDATA() macro is used to set the value of the
dt_appdata field in an ldap_disptmpl structure. This field is reserved
for the calling application to use; it is not used internally.
The LDAP_GET_DISPTMPL_APPDATA() macro is used to retrieve the value in
the dt_appdata field.
The LDAP_IS_DISPTMPL_OPTION_SET() macro is used to test a ldap_disptmpl
structure for the existence of a template option. The options cur-
rently defined are: LDAP_DTMPL_OPT_ADDABLE (it is appropriate to allow
entries of this type to be added), LDAP_DTMPL_OPT_ALLOWMODRDN (it is
appropriate to offer the "modify rdn" operation),
LDAP_DTMPL_OPT_ALTVIEW (this template is merely an alternate view of
another template, typically used for templates pointed to be an
LDAP_SYN_LINKACTION item).
ldap_free_templates() disposes of the templates allocated by
ldap_init_templates().
ldap_first_disptmpl() returns the first template in the list tmpllist.
The tmpllist is typically obtained by calling ldap_init_templates().
ldap_next_disptmpl() returns the template after tmpl in the template
list tmpllist. A NULL pointer is returned if tmpl is the last template
in the list.
ldap_oc2template() searches tmpllist for the best template to use to
display an entry that has a specific set of objectClass values. oclist
should be a null-terminated array of strings that contains the values
of the objectClass attribute of the entry. A pointer to the first tem-
plate where all of the object classes listed in one of the template's
dt_oclist elements are contained in oclist is returned. A NULL pointer
is returned if no appropriate template is found.
ldap_tmplattrs() returns a null-terminated array that contains the
names of attributes that need to be retrieved if the template tmpl is
to be used to display an entry. The attribute list should be freed
using ldap_value_free(). The includeattrs parameter contains a null-
terminated array of attributes that should always be included (it may
be NULL if no extra attributes are required). If syntaxmask is non-
zero, it is used to restrict the attribute set returned. If exclude is
zero, only attributes where the logical AND of the template item syntax
id and the syntaxmask is non-zero are included. If exclude is non-
zero, attributes where the logical AND of the template item syntax id
and the syntaxmask is non-zero are excluded.
ldap_first_tmplrow() returns a pointer to the first row of items in
template tmpl.
ldap_next_tmplrow() returns a pointer to the row that follows row in
template tmpl.
ldap_first_tmplcol() returns a pointer to the first item (in the first
column) of row row within template tmpl. A pointer to an ldap_tmplitem
structure (defined below in the TMPLITEM STRUCTURE ELEMENTS section) is
returned.
The LDAP_SET_TMPLITEM_APPDATA() macro is used to set the value of the
ti_appdata field in a ldap_tmplitem structure. This field is reserved
for the calling application to use; it is not used internally.
The LDAP_GET_TMPLITEM_APPDATA() macro is used to retrieve the value of
the ti_appdata field.
The LDAP_IS_TMPLITEM_OPTION_SET() macro is used to test a ldap_tmplitem
structure for the existence of an item option. The options currently
defined are: LDAP_DITEM_OPT_READONLY (this attribute should not be mod-
ified), LDAP_DITEM_OPT_SORTVALUES (it makes sense to sort the values),
LDAP_DITEM_OPT_SINGLEVALUED (this attribute can only hold a single
value), LDAP_DITEM_OPT_VALUEREQUIRED (this attribute must contain at
least one value), LDAP_DITEM_OPT_HIDEIFEMPTY (do not show this item if
there are no values), and LDAP_DITEM_OPT_HIDEIFFALSE (for boolean
attributes only: hide this item if the value is FALSE).
ldap_next_tmplcol() returns a pointer to the item (column) that follows
column col within row row of template tmpl.
DISPTMPL STRUCTURE ELEMENTS
The ldap_disptmpl structure is defined as:
struct ldap_disptmpl {
char *dt_name;
char *dt_pluralname;
char *dt_iconname;
unsigned long dt_options;
char *dt_authattrname;
char *dt_defrdnattrname;
char *dt_defaddlocation;
struct ldap_oclist *dt_oclist;
struct ldap_adddeflist *dt_adddeflist;
struct ldap_tmplitem *dt_items;
void *dt_appdata;
struct ldap_disptmpl *dt_next;
};
The dt_name member is the singular name of the template. The dt_plu-
ralname is the plural name. The dt_iconname member will contain the
name of an icon or other graphical element that can be used to depict
entries that correspond to this display template. The dt_options con-
tains options which may be tested using the
LDAP_IS_TMPLITEM_OPTION_SET() macro.
The dt_authattrname contains the name of the DN-syntax attribute whose
value(s) should be used to authenticate to make changes to an entry.
If dt_authattrname is NULL, then authenticating as the entry itself is
appropriate. The dt_defrdnattrname is the name of the attribute that
is normally used to name entries of this type, e.g., "cn" for person
entries. The dt_defaddlocation is the distinguished name of an entry
below which new entries of this type are typically created (its value
is site-dependent).
dt_oclist is a pointer to a linked list of object class arrays, defined
as:
struct ldap_oclist {
char **oc_objclasses;
struct ldap_oclist *oc_next;
};
These are used by the ldap_oc2template() routine.
dt_adddeflist is a pointer to a linked list of rules for defaulting the
values of attributes when new entries are created. The ldap_adddeflist
structure is defined as:
struct ldap_adddeflist {
int ad_source;
char *ad_attrname;
char *ad_value;
struct ldap_adddeflist *ad_next;
};
The ad_attrname member contains the name of the attribute whose value
this rule sets. If ad_source is LDAP_ADSRC_CONSTANTVALUE then the
ad_value member contains the (constant) value to use. If ad_source is
LDAP_ADSRC_ADDERSDN then ad_value is ignored and the distinguished name
of the person who is adding the new entry is used as the default value
for ad_attrname.
TMPLITEM STRUCTURE ELEMENTS
The ldap_tmplitem structure is defined as:
struct ldap_tmplitem {
unsigned long ti_syntaxid;
unsigned long ti_options;
char *ti_attrname;
char *ti_label;
char **ti_args;
struct ldap_tmplitem *ti_next_in_row;
struct ldap_tmplitem *ti_next_in_col;
void *ti_appdata;
};
SYNTAX IDS
Syntax ids are found in the ldap_tmplitem structure element ti_syn-
taxid, and they can be used to determine how to display the values for
the attribute associated with an item. The LDAP_GET_SYN_TYPE() macro
can be used to return a general type from a syntax id. The five gen-
eral types currently defined are: LDAP_SYN_TYPE_TEXT (for attributes
that are most appropriately shown as text), LDAP_SYN_TYPE_IMAGE (for
JPEG or FAX format images), LDAP_SYN_TYPE_BOOLEAN (for boolean
attributes), LDAP_SYN_TYPE_BUTTON (for attributes whose values are to
be retrieved and display only upon request, e.g., in response to the
press of a button, a JPEG image is retrieved, decoded, and displayed),
and LDAP_SYN_TYPE_ACTION (for special purpose actions such as "search
for the entries where this entry is listed in the seeAlso attribute").
The LDAP_GET_SYN_OPTIONS macro can be used to retrieve an unsigned long
bitmap that defines options. The only currently defined option is
LDAP_SYN_OPT_DEFER, which (if set) implies that the values for the
attribute should not be retrieved until requested.
There are sixteen distinct syntax ids currently defined. These gener-
ally correspond to one or more X.500 syntaxes.
LDAP_SYN_CASEIGNORESTR is used for text attributes which are simple
strings whose case is ignored for comparison purposes.
LDAP_SYN_MULTILINESTR is used for text attributes which consist of mul-
tiple lines, e.g., postalAddress, homePostalAddress, multilineDescrip-
tion, or any attributes of syntax caseIgnoreList.
LDAP_SYN_RFC822ADDR is used for case ignore string attributes that are
RFC-822 conformant mail addresses, e.g., mail.
LDAP_SYN_DN is used for attributes with a Distinguished Name syntax,
e.g., seeAlso.
LDAP_SYN_BOOLEAN is used for attributes with a boolean syntax.
LDAP_SYN_JPEGIMAGE is used for attributes with a jpeg syntax, e.g.,
jpegPhoto.
LDAP_SYN_JPEGBUTTON is used to provide a button (or equivalent inter-
face element) that can be used to retrieve, decode, and display an
attribute of jpeg syntax.
LDAP_SYN_FAXIMAGE is used for attributes with a photo syntax, e.g.,
Photo. These are actually Group 3 Fax (T.4) format images.
LDAP_SYN_FAXBUTTON is used to provide a button (or equivalent interface
element) that can be used to retrieve, decode, and display an attribute
of photo syntax.
LDAP_SYN_AUDIOBUTTON is used to provide a button (or equivalent inter-
face element) that can be used to retrieve and play an attribute of
audio syntax. Audio values are in the "mu law" format, also known as
"au" format.
LDAP_SYN_TIME is used for attributes with the UTCTime syntax, e.g.,
lastModifiedTime. The value(s) should be displayed in complete date
and time fashion.
LDAP_SYN_DATE is used for attributes with the UTCTime syntax, e.g.,
lastModifiedTime. Only the date portion of the value(s) should be dis-
played.
LDAP_SYN_LABELEDURL is used for labeledURL attributes.
LDAP_SYN_SEARCHACTION is used to define a search that is used to
retrieve related information. If ti_attrname is not NULL, it is
assumed to be a boolean attribute which will cause no search to be per-
formed if its value is FALSE. The ti_args structure member will have
four strings in it: ti_args[ 0 ] should be the name of an attribute
whose values are used to help construct a search filter or "-dn" is the
distinguished name of the entry being displayed should be used,
ti_args[ 1 ] should be a filter pattern where any occurrences of "%v"
are replaced with the value derived from ti_args[ 0 ], ti_args[ 2 ]
should be the name of an additional attribute to retrieve when perform-
ing the search, and ti_args[ 3 ] should be a human-consumable name for
that attribute. The ti_args[ 2 ] attribute is typically displayed
along with a list of distinguished names when multiple entries are
returned by the search.
LDAP_SYN_LINKACTION is used to define a link to another template by
name. ti_args[ 0 ] will contain the name of the display template to
use. The ldap_name2template() routine can be used to obtain a pointer
to the correct ldap_disptmpl structure.
LDAP_SYN_ADDDNACTION and LDAP_SYN_VERIFYDNACTION are reserved as
actions but currently undefined.
ERRORS
The init template functions return LDAP_TMPL_ERR_VERSION if buf points
to data that is newer than can be handled, LDAP_TMPL_ERR_MEM if there
is a memory allocation problem, LDAP_TMPL_ERR_SYNTAX if there is a
problem with the format of the templates buffer or file.
LDAP_TMPL_ERR_FILE is returned by ldap_init_templates if the file
cannot be read. Other routines generally return NULL upon error.
SEE ALSO
ldap(3), ldap_entry2text(3), ldaptemplates.conf(5)
ACKNOWLEDGEMENTS
OpenLDAP is developed and maintained by The OpenLDAP Project
(http://www.openldap.org/). OpenLDAP is derived from University of
Michigan LDAP 3.3 Release.
OpenLDAP 2.0.27-Release 22 September 1998 LDAP_DISPTMPL(3)