mirror of
https://github.com/rn10950/RetroZilla.git
synced 2024-11-11 02:10:17 +01:00
380 lines
11 KiB
C
380 lines
11 KiB
C
/* ***** BEGIN LICENSE BLOCK *****
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
*
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/MPL/
|
|
*
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
* for the specific language governing rights and limitations under the
|
|
* License.
|
|
*
|
|
* The Original Code is Mozilla Communicator client code, released
|
|
* March 31, 1998.
|
|
*
|
|
* The Initial Developer of the Original Code is
|
|
* Netscape Communications Corporation.
|
|
* Portions created by the Initial Developer are Copyright (C) 1998-1999
|
|
* the Initial Developer. All Rights Reserved.
|
|
*
|
|
* Contributor(s):
|
|
*
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
* the provisions above, a recipient may use your version of this file under
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
*
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
/*
|
|
* Copyright (c) 1993, 1994 Regents of the University of Michigan.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms are permitted
|
|
* provided that this notice is preserved and that due credit is given
|
|
* to the University of Michigan at Ann Arbor. The name of the University
|
|
* may not be used to endorse or promote products derived from this
|
|
* software without specific prior written permission. This software
|
|
* is provided ``as is'' without express or implied warranty.
|
|
*
|
|
* disptmpl.h: display template library defines
|
|
*/
|
|
|
|
#ifndef _DISPTMPL_H
|
|
#define _DISPTMPL_H
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* calling conventions used by library */
|
|
#ifndef LDAP_CALL
|
|
#if defined( _WINDOWS ) || defined( _WIN32 )
|
|
#define LDAP_C __cdecl
|
|
#ifndef _WIN32
|
|
#define __stdcall _far _pascal
|
|
#define LDAP_CALLBACK _loadds
|
|
#else
|
|
#define LDAP_CALLBACK
|
|
#endif /* _WIN32 */
|
|
#define LDAP_PASCAL __stdcall
|
|
#define LDAP_CALL LDAP_PASCAL
|
|
#else /* _WINDOWS */
|
|
#define LDAP_C
|
|
#define LDAP_CALLBACK
|
|
#define LDAP_PASCAL
|
|
#define LDAP_CALL
|
|
#endif /* _WINDOWS */
|
|
#endif /* LDAP_CALL */
|
|
|
|
#define LDAP_TEMPLATE_VERSION 1
|
|
|
|
/*
|
|
* general types of items (confined to most significant byte)
|
|
*/
|
|
#define LDAP_SYN_TYPE_TEXT 0x01000000L
|
|
#define LDAP_SYN_TYPE_IMAGE 0x02000000L
|
|
#define LDAP_SYN_TYPE_BOOLEAN 0x04000000L
|
|
#define LDAP_SYN_TYPE_BUTTON 0x08000000L
|
|
#define LDAP_SYN_TYPE_ACTION 0x10000000L
|
|
|
|
|
|
/*
|
|
* syntax options (confined to second most significant byte)
|
|
*/
|
|
#define LDAP_SYN_OPT_DEFER 0x00010000L
|
|
|
|
|
|
/*
|
|
* display template item syntax ids (defined by common agreement)
|
|
* these are the valid values for the ti_syntaxid of the tmplitem
|
|
* struct (defined below). A general type is encoded in the
|
|
* most-significant 8 bits, and some options are encoded in the next
|
|
* 8 bits. The lower 16 bits are reserved for the distinct types.
|
|
*/
|
|
#define LDAP_SYN_CASEIGNORESTR ( 1 | LDAP_SYN_TYPE_TEXT )
|
|
#define LDAP_SYN_MULTILINESTR ( 2 | LDAP_SYN_TYPE_TEXT )
|
|
#define LDAP_SYN_DN ( 3 | LDAP_SYN_TYPE_TEXT )
|
|
#define LDAP_SYN_BOOLEAN ( 4 | LDAP_SYN_TYPE_BOOLEAN )
|
|
#define LDAP_SYN_JPEGIMAGE ( 5 | LDAP_SYN_TYPE_IMAGE )
|
|
#define LDAP_SYN_JPEGBUTTON ( 6 | LDAP_SYN_TYPE_BUTTON | LDAP_SYN_OPT_DEFER )
|
|
#define LDAP_SYN_FAXIMAGE ( 7 | LDAP_SYN_TYPE_IMAGE )
|
|
#define LDAP_SYN_FAXBUTTON ( 8 | LDAP_SYN_TYPE_BUTTON | LDAP_SYN_OPT_DEFER )
|
|
#define LDAP_SYN_AUDIOBUTTON ( 9 | LDAP_SYN_TYPE_BUTTON | LDAP_SYN_OPT_DEFER )
|
|
#define LDAP_SYN_TIME ( 10 | LDAP_SYN_TYPE_TEXT )
|
|
#define LDAP_SYN_DATE ( 11 | LDAP_SYN_TYPE_TEXT )
|
|
#define LDAP_SYN_LABELEDURL ( 12 | LDAP_SYN_TYPE_TEXT )
|
|
#define LDAP_SYN_SEARCHACTION ( 13 | LDAP_SYN_TYPE_ACTION )
|
|
#define LDAP_SYN_LINKACTION ( 14 | LDAP_SYN_TYPE_ACTION )
|
|
#define LDAP_SYN_ADDDNACTION ( 15 | LDAP_SYN_TYPE_ACTION )
|
|
#define LDAP_SYN_VERIFYDNACTION ( 16 | LDAP_SYN_TYPE_ACTION )
|
|
#define LDAP_SYN_RFC822ADDR ( 17 | LDAP_SYN_TYPE_TEXT )
|
|
|
|
|
|
/*
|
|
* handy macros
|
|
*/
|
|
#define LDAP_GET_SYN_TYPE( syid ) ((syid) & 0xFF000000UL )
|
|
#define LDAP_GET_SYN_OPTIONS( syid ) ((syid) & 0x00FF0000UL )
|
|
|
|
|
|
/*
|
|
* display options for output routines (used by entry2text and friends)
|
|
*/
|
|
/*
|
|
* use calculated label width (based on length of longest label in
|
|
* template) instead of contant width
|
|
*/
|
|
#define LDAP_DISP_OPT_AUTOLABELWIDTH 0x00000001L
|
|
#define LDAP_DISP_OPT_HTMLBODYONLY 0x00000002L
|
|
|
|
/*
|
|
* perform search actions (applies to ldap_entry2text_search only)
|
|
*/
|
|
#define LDAP_DISP_OPT_DOSEARCHACTIONS 0x00000002L
|
|
|
|
/*
|
|
* include additional info. relevant to "non leaf" entries only
|
|
* used by ldap_entry2html and ldap_entry2html_search to include "Browse"
|
|
* and "Move Up" HREFs
|
|
*/
|
|
#define LDAP_DISP_OPT_NONLEAF 0x00000004L
|
|
|
|
|
|
/*
|
|
* display template item options (may not apply to all types)
|
|
* if this bit is set in ti_options, it applies.
|
|
*/
|
|
#define LDAP_DITEM_OPT_READONLY 0x00000001L
|
|
#define LDAP_DITEM_OPT_SORTVALUES 0x00000002L
|
|
#define LDAP_DITEM_OPT_SINGLEVALUED 0x00000004L
|
|
#define LDAP_DITEM_OPT_HIDEIFEMPTY 0x00000008L
|
|
#define LDAP_DITEM_OPT_VALUEREQUIRED 0x00000010L
|
|
#define LDAP_DITEM_OPT_HIDEIFFALSE 0x00000020L /* booleans only */
|
|
|
|
|
|
|
|
/*
|
|
* display template item structure
|
|
*/
|
|
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;
|
|
};
|
|
|
|
|
|
#define NULLTMPLITEM ((struct ldap_tmplitem *)0)
|
|
|
|
#define LDAP_SET_TMPLITEM_APPDATA( ti, datap ) \
|
|
(ti)->ti_appdata = (void *)(datap)
|
|
|
|
#define LDAP_GET_TMPLITEM_APPDATA( ti, type ) \
|
|
(type)((ti)->ti_appdata)
|
|
|
|
#define LDAP_IS_TMPLITEM_OPTION_SET( ti, option ) \
|
|
(((ti)->ti_options & option ) != 0 )
|
|
|
|
|
|
/*
|
|
* object class array structure
|
|
*/
|
|
struct ldap_oclist {
|
|
char **oc_objclasses;
|
|
struct ldap_oclist *oc_next;
|
|
};
|
|
|
|
#define NULLOCLIST ((struct ldap_oclist *)0)
|
|
|
|
|
|
/*
|
|
* add defaults list
|
|
*/
|
|
struct ldap_adddeflist {
|
|
int ad_source;
|
|
#define LDAP_ADSRC_CONSTANTVALUE 1
|
|
#define LDAP_ADSRC_ADDERSDN 2
|
|
char *ad_attrname;
|
|
char *ad_value;
|
|
struct ldap_adddeflist *ad_next;
|
|
};
|
|
|
|
#define NULLADLIST ((struct ldap_adddeflist *)0)
|
|
|
|
|
|
/*
|
|
* display template global options
|
|
* if this bit is set in dt_options, it applies.
|
|
*/
|
|
/*
|
|
* users should be allowed to try to add objects of these entries
|
|
*/
|
|
#define LDAP_DTMPL_OPT_ADDABLE 0x00000001L
|
|
|
|
/*
|
|
* users should be allowed to do "modify RDN" operation of these entries
|
|
*/
|
|
#define LDAP_DTMPL_OPT_ALLOWMODRDN 0x00000002L
|
|
|
|
/*
|
|
* this template is an alternate view, not a primary view
|
|
*/
|
|
#define LDAP_DTMPL_OPT_ALTVIEW 0x00000004L
|
|
|
|
|
|
/*
|
|
* display template structure
|
|
*/
|
|
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;
|
|
};
|
|
|
|
#define NULLDISPTMPL ((struct ldap_disptmpl *)0)
|
|
|
|
#define LDAP_SET_DISPTMPL_APPDATA( dt, datap ) \
|
|
(dt)->dt_appdata = (void *)(datap)
|
|
|
|
#define LDAP_GET_DISPTMPL_APPDATA( dt, type ) \
|
|
(type)((dt)->dt_appdata)
|
|
|
|
#define LDAP_IS_DISPTMPL_OPTION_SET( dt, option ) \
|
|
(((dt)->dt_options & option ) != 0 )
|
|
|
|
#define LDAP_TMPL_ERR_VERSION 1
|
|
#define LDAP_TMPL_ERR_MEM 2
|
|
#define LDAP_TMPL_ERR_SYNTAX 3
|
|
#define LDAP_TMPL_ERR_FILE 4
|
|
|
|
/*
|
|
* buffer size needed for entry2text and vals2text
|
|
*/
|
|
#define LDAP_DTMPL_BUFSIZ 8192
|
|
|
|
typedef int (*writeptype)( void *writeparm, char *p, int len );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_init_templates( char *file, struct ldap_disptmpl **tmpllistp );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_init_templates_buf( char *buf, long buflen,
|
|
struct ldap_disptmpl **tmpllistp );
|
|
|
|
LDAP_API(void)
|
|
LDAP_CALL
|
|
ldap_free_templates( struct ldap_disptmpl *tmpllist );
|
|
|
|
LDAP_API(struct ldap_disptmpl *)
|
|
LDAP_CALL
|
|
ldap_first_disptmpl( struct ldap_disptmpl *tmpllist );
|
|
|
|
LDAP_API(struct ldap_disptmpl *)
|
|
LDAP_CALL
|
|
ldap_next_disptmpl( struct ldap_disptmpl *tmpllist,
|
|
struct ldap_disptmpl *tmpl );
|
|
|
|
LDAP_API(struct ldap_disptmpl *)
|
|
LDAP_CALL
|
|
ldap_name2template( char *name, struct ldap_disptmpl *tmpllist );
|
|
|
|
LDAP_API(struct ldap_disptmpl *)
|
|
LDAP_CALL
|
|
ldap_oc2template( char **oclist, struct ldap_disptmpl *tmpllist );
|
|
|
|
LDAP_API(char **)
|
|
LDAP_CALL
|
|
ldap_tmplattrs( struct ldap_disptmpl *tmpl, char **includeattrs, int exclude,
|
|
unsigned long syntaxmask );
|
|
|
|
LDAP_API(struct ldap_tmplitem *)
|
|
LDAP_CALL
|
|
ldap_first_tmplrow( struct ldap_disptmpl *tmpl );
|
|
|
|
LDAP_API(struct ldap_tmplitem *)
|
|
LDAP_CALL
|
|
ldap_next_tmplrow( struct ldap_disptmpl *tmpl, struct ldap_tmplitem *row );
|
|
|
|
LDAP_API(struct ldap_tmplitem *)
|
|
LDAP_CALL
|
|
ldap_first_tmplcol( struct ldap_disptmpl *tmpl, struct ldap_tmplitem *row );
|
|
|
|
LDAP_API(struct ldap_tmplitem *)
|
|
LDAP_CALL
|
|
ldap_next_tmplcol( struct ldap_disptmpl *tmpl, struct ldap_tmplitem *row,
|
|
struct ldap_tmplitem *col );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_entry2text( LDAP *ld, char *buf, LDAPMessage *entry,
|
|
struct ldap_disptmpl *tmpl, char **defattrs, char ***defvals,
|
|
writeptype writeproc, void *writeparm, char *eol, int rdncount,
|
|
unsigned long opts );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_vals2text( LDAP *ld, char *buf, char **vals, char *label, int labelwidth,
|
|
unsigned long syntaxid, writeptype writeproc, void *writeparm,
|
|
char *eol, int rdncount );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_entry2text_search( LDAP *ld, char *dn, char *base, LDAPMessage *entry,
|
|
struct ldap_disptmpl *tmpllist, char **defattrs, char ***defvals,
|
|
writeptype writeproc, void *writeparm, char *eol, int rdncount,
|
|
unsigned long opts );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_entry2html( LDAP *ld, char *buf, LDAPMessage *entry,
|
|
struct ldap_disptmpl *tmpl, char **defattrs, char ***defvals,
|
|
writeptype writeproc, void *writeparm, char *eol, int rdncount,
|
|
unsigned long opts, char *urlprefix, char *base );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_vals2html( LDAP *ld, char *buf, char **vals, char *label, int labelwidth,
|
|
unsigned long syntaxid, writeptype writeproc, void *writeparm,
|
|
char *eol, int rdncount, char *urlprefix );
|
|
|
|
LDAP_API(int)
|
|
LDAP_CALL
|
|
ldap_entry2html_search( LDAP *ld, char *dn, char *base, LDAPMessage *entry,
|
|
struct ldap_disptmpl *tmpllist, char **defattrs, char ***defvals,
|
|
writeptype writeproc, void *writeparm, char *eol, int rdncount,
|
|
unsigned long opts, char *urlprefix );
|
|
|
|
LDAP_API(char *)
|
|
LDAP_CALL
|
|
ldap_tmplerr2string( int err );
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* _DISPTMPL_H */
|