ABCDEFGHIJKLMNOPQRSTUVWXYZ

ldap_entry2text

LDAP_ENTRY2TEXT(3)                                          LDAP_ENTRY2TEXT(3)



NAME
       ldap_entry2text,  ldap_entry2text_search,  ldap_vals2text  - LDAP entry
       display routines

SYNOPSIS
       #include <ldap.h>
       #include <disptmpl.h>

       int ldap_entry2text( ld, buf, entry, tmpl, defattrs, defvals, writeproc,
           writeparm, eol, rdncount, opts )
            LDAP           *ld;
            char           *buf;
            LDAPMessage         *entry;
            struct ldap_disptmpl     *tmpl;
            char           **defattrs;
            char           ***defvals;
            int            (*writeproc)();
            void           *writeparm;
            char           *eol;
            int            rdncount;
            unsigned long       opts;

       int ldap_entry2text_search( ld, entry, tmpllist, defattrs, defvals,
           writeproc, writeparm, eol, rdncount, opts )
            LDAP           *ld;
            char           *dn;
            char           *base;
            LDAPMessage         *entry;
            struct ldap_disptmpl     *tmpllist;
            char           **defattrs;
            char           ***defvals;
            int            (*writeproc)();
            void           *writeparm;
            char           *eol;
            int            rdncount;
            unsigned long       opts;

       int ldap_vals2text( ld, buf, vals, label, labelwidth, syntaxid, writeproc,
           writeparm, eol, rdncount )
            LDAP           *ld;
            char           *buf;
            char           **vals;
            char           *label;
            int            labelwidth;
            unsigned long       syntaxid;
            int            (*writeproc)();
            void           *writeparm;
            char           *eol;
            int            rdncount;

       int ldap_entry2html( ld, buf, entry, tmpl, defattrs, defvals, writeproc,
           writeparm, eol, rdncount, opts )
            LDAP           *ld;
            char           *buf;
            LDAPMessage         *entry;
            struct ldap_disptmpl     *tmpl;
            char           **defattrs;
            char           ***defvals;
            int            (*writeproc)();
            void           *writeparm;
            char           *eol;
            int            rdncount;
            unsigned long       opts;
            char           *urlprefix;
            char           *base;

       int ldap_entry2html_search( ld, entry, tmpllist, defattrs, defvals,
           writeproc, writeparm, eol, rdncount, opts )
            LDAP           *ld;
            char           *dn;
            LDAPMessage         *entry;
            struct ldap_disptmpl     *tmpllist;
            char           **defattrs;
            char           ***defvals;
            int            (*writeproc)();
            void           *writeparm;
            char           *eol;
            int            rdncount;
            unsigned long       opts;
            char           *urlprefix;

       int ldap_vals2html( ld, buf, vals, label, labelwidth, syntaxid, writeproc,
           writeparm, eol, rdncount )
            LDAP           *ld;
            char           *buf;
            char           **vals;
            char           *label;
            int            labelwidth;
            unsigned long       syntaxid;
            int            (*writeproc)();
            void           *writeparm;
            char           *eol;
            int            rdncount;
            char           *urlprefix;



       #define LDAP_DISP_OPT_AUTOLABELWIDTH    0x00000001
       #define LDAP_DISP_OPT_HTMLBODYONLY      0x00000002

       #define LDAP_DTMPL_BUFSIZ          2048

DESCRIPTION
       These  functions  use  the  LDAP   display   template   routines   (see
       ldap_disptmpl(3) and ldap_templates.conf(5)) to produce a plain text or
       an HyperText Markup Language (HTML) display of an entry  or  a  set  of
       values.   Typical  plain  text  output produced for an entry might look
       like:

           "Barbara J Jensen, Information Technology Division"
            Also Known As:
                    Babs Jensen
                    Barbara Jensen
                    Barbara J Jensen
            E-Mail Address:
                    bjensen@terminator.rs.itd.umich.edu
            Work Address:
                    535 W. William
                    Ann Arbor, MI 48103
            Title:
                    Mythical Manager, Research Systems
            ...
       The exact output produced will depend on the display template  configu-
       ration.   HTML  output  is  similar  to the plain text output, but more
       richly formatted.

       ldap_entry2text() produces a text representation of  entry  and  writes
       the  text  by  calling  the  writeproc function.  All of the attributes
       values to be displayed must be present in entry;  no  interaction  with
       the  LDAP  server  will be performed within ldap_entry2text.  ld is the
       LDAP pointer obtained by  a  previous  call  to  ldap_open.   writeproc
       should be declared as:

       int writeproc( writeparm, p, len )
            void      *writeparm;
            char      *p;
            int       len;

       where p is a pointer to text to be written and len is the length of the
       text.  p is guaranteed to be zero-terminated.  Lines of text are termi-
       nated  with  the  string  eol.   buf  is  a pointer to a buffer of size
       LDAP_DTMPL_BUFSIZ or larger.  If buf is NULL then a buffer is allocated
       and  freed internally.  tmpl is a pointer to the display template to be
       used (usually obtained by calling ldap_oc2template).  If tmpl is  NULL,
       no  template  is used and a generic display is produced.  defattrs is a
       NULL-terminated array of LDAP attribute names which you wish to provide
       default  values  for  (only  used  if  entry contains no values for the
       attribute).  An array of NULL-terminated arrays of default values  cor-
       responding  to the attributes should be passed in defvals. The rdncount
       parameter is used to limit the number of Distinguished Name (DN) compo-
       nents  that  are  actually displayed for DN attributes.  If rdncount is
       zero, all components  are  shown.   opts  is  used  to  specify  output
       options.   The only values currently allowed are zero (default output),
       LDAP_DISP_OPT_AUTOLABELWIDTH which causes the width for  labels  to  be
       determined  based on the longest label in tmpl, and LDAP_DISP_OPT_HTML-
       BODYONLY.  The LDAP_DISP_OPT_HTMLBODYONLY option instructs the  library
       not  to  include  <HTML>,  <HEAD>,  <TITLE>, and <BODY> tags.  In other
       words, an HTML fragment is generated, and the caller is responsible for
       prepending  and appending the appropriate HTML tags to construct a cor-
       rect HTML document.

       ldap_entry2text_search() is similar to ldap_entry2text, and all of  the
       like-named  parameters have the same meaning except as noted below.  If
       base is not NULL, it is the search base to use  when  executing  search
       actions.   If it is NULL, search action template items are ignored.  If
       entry is not NULL, it should contain the objectClass  attribute  values
       for  the entry to be displayed.  If entry is NULL, dn must not be NULL,
       and ldap_entry2text_search will retrieve the objectClass values  itself
       by  calling  ldap_search_s.   ldap_entry2text_search will determine the
       appropriate display template to use by  calling  ldap_oc2template,  and
       will  call  ldap_search_s  to  retrieve any attribute values to be dis-
       played.  The tmpllist parameter is a pointer to the entire list of tem-
       plates  available  (usually  obtained by calling ldap_init_templates or
       ldap_init_templates_buf).  If tmpllist is NULL,  ldap_entry2text_search
       will attempt to read a load templates from the default template config-
       uration file /etc/openldap/ldaptemplates.conf.

       ldap_vals2text produces a text representation of a single set  of  LDAP
       attribute values.  The ld, buf, writeproc, writeparm, eol, and rdncount
       parameters  are   the   same   as   the   like-named   parameters   for
       ldap_entry2text.   vals  is  a  NULL-terminated list of values, usually
       obtained by a call to ldap_get_values.  label is a string shown next to
       the values (usually a friendly form of an LDAP attribute name).  label-
       width specifies the label margin, which is the number of  blank  spaces
       displayed  to  the  left  of  the values.  If zero is passed, a default
       label width is used.  syntaxid is a display template  attribute  syntax
       identifier   (see  ldap_disptmpl(3)  for  a  list  of  the  pre-defined
       LDAP_SYN_...  values).

       ldap_entry2html produces an HTML representation of entry.   It  behaves
       exactly  like  ldap_entry2text(3),  except for the formatted output and
       the addition of two parameters.  urlprefix is the starting text to  use
       when  constructing an LDAP URL.  The default is the string ldap:/// The
       second  additional  parameter,  base,  the  search  base  to  use  when
       executing  search actions.  If it is NULL, search action template items
       are ignored.

       ldap_entry2html_search behaves exactly like  ldap_entry2text_search(3),
       except  HTML  output  is  produced  and  one  additional  parameter  is
       required.  urlprefix is the starting text to use when  constructing  an
       LDAP URL.  The default is the string ldap:///

       ldap_vals2html  behaves exactly like ldap_vals2text, except HTML output
       is produced and one additional parameter is required.  urlprefix is the
       starting text to use when constructing an LDAP URL.  The default is the
       string ldap:///

ERRORS
       These routines all return an LDAP error code (LDAP_SUCCESS is  returned
       if no error occurs).  See ldap_error(3) for details. The ld_errno field
       of the ld parameter is also set to indicate the error.

FILES
       /etc/openldap/ldaptemplates.conf

SEE ALSO
       ldap(3), ldap_disptmpl(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_ENTRY2TEXT(3)