summaryrefslogtreecommitdiff
path: root/usr/src/lib/libldap5/sources/ldap/common/llib-lldap
diff options
context:
space:
mode:
Diffstat (limited to 'usr/src/lib/libldap5/sources/ldap/common/llib-lldap')
-rw-r--r--usr/src/lib/libldap5/sources/ldap/common/llib-lldap530
1 files changed, 530 insertions, 0 deletions
diff --git a/usr/src/lib/libldap5/sources/ldap/common/llib-lldap b/usr/src/lib/libldap5/sources/ldap/common/llib-lldap
new file mode 100644
index 0000000000..9ce0512704
--- /dev/null
+++ b/usr/src/lib/libldap5/sources/ldap/common/llib-lldap
@@ -0,0 +1,530 @@
+/* LINTLIBRARY */
+/* PROTOLIB1 */
+
+/*
+ * Copyright 2001, 2003 Sun Microsystems, Inc. All rights reserved.
+ * Use is subject to license terms.
+ */
+
+#pragma ident "%Z%%M% %I% %E% SMI"
+
+#include <stdio.h>
+#include <sys/types.h>
+#include <lber.h>
+#include <ldap.h>
+
+
+/*
+ * in abandon.c:
+ */
+int ldap_abandon_ext(LDAP *ld, int msgid, LDAPControl **serverctrls, LDAPControl ** clientctrls);
+
+int ldap_abandon( LDAP *ld, int msgid );
+
+/*
+ * in add.c:
+ */
+int ldap_add_ext( LDAP *ld, const char *dn, LDAPMod **attrs, LDAPControl ** serverctrls, LDAPControl **clientctrls, int *msgidp);
+
+int ldap_add_ext_s( LDAP *ld, const char *dn, LDAPMod **attrs, LDAPControl ** serverctrls, LDAPControl **clientctrls);
+
+int ldap_add( LDAP *ld, const char *dn, LDAPMod **attrs );
+int ldap_add_s( LDAP *ld, const char *dn, LDAPMod **attrs );
+
+/*
+ * in bind.c:
+ */
+int ldap_bind(LDAP *ld, const char *dn, const char *passwd, int authmethod);
+int ldap_bind_s(LDAP *ld, const char *dn, const char *passwd, int authmethod);
+void ldap_set_rebind_proc(LDAP *ld, LDAP_REBINDPROC_CALLBACK *rebindproc, void *arg);
+
+/*
+ * in sbind.c:
+ */
+int ldap_simple_bind( LDAP *ld, const char *dn, const char *passwd );
+int ldap_simple_bind_s( LDAP *ld, const char *dn, const char *passwd );
+
+/*
+ * in saslbind.c:
+ */
+int ldap_sasl_bind(LDAP *ld, const char *dn, const char *mechanism, const struct berval *cred, LDAPControl **serverctrls, LDAPControl **clientctrls, int *msgidp);
+
+int ldap_sasl_bind_s(LDAP *ld, const char *dn, const char *mechanism, const struct berval *cred, LDAPControl **serverctrls, LDAPControl **clientctrls, struct berval **servercredp);
+
+/*
+ * in kbind.c:
+ */
+
+/*
+ * in cache.c
+ */
+
+/*
+ * in compare.c:
+ */
+int ldap_compare_ext(LDAP *ld, const char *dn, const char *attr, const struct berval *bvalue, LDAPControl ** serverctrls, LDAPControl **clientctrls, int *msgidp);
+
+int ldap_compare_ext_s(LDAP *ld, const char *dn, const char *attr, const struct berval *bvalue, LDAPControl ** serverctrls, LDAPControl **clientctrls) ;
+
+int ldap_compare( LDAP *ld, const char *dn, const char *attr, const char *value );
+
+int ldap_compare_s( LDAP *ld, const char *dn, const char *attr, const char *value );
+
+/*
+ * in delete.c:
+ */
+int ldap_delete_ext(LDAP *ld, const char *dn, LDAPControl **serverctrls, LDAPControl **clientctrls, int *msgidp);
+
+int ldap_delete_ext_s(LDAP *ld, const char *dn, LDAPControl **serverctrls, LDAPControl **clientctrls);
+
+int ldap_delete( LDAP *ld, const char *dn );
+int ldap_delete_s( LDAP *ld, const char *dn );
+
+/*
+ * in error.c:
+ */
+char *ldap_err2string( int err );
+void ldap_perror(LDAP *ld, const char *s);
+int ldap_result2error(LDAP *ld, LDAPMessage *r, int freeit);
+int ldap_get_lderrno(LDAP *ld, char **m, char **s);
+int ldap_set_lderrno(LDAP *ld, int e, char *m, char *s);
+
+/*
+ * in modify.c:
+ */
+int ldap_modify_ext(LDAP *ld, const char *dn, LDAPMod **mods, LDAPControl **serverctrls, LDAPControl **clientctrls, int *msgidp);
+
+int ldap_modify_ext_s(LDAP *ld, const char *dn, LDAPMod **mods, LDAPControl **serverctrls, LDAPControl **clientctrls) ;
+
+int ldap_modify( LDAP *ld, const char *dn, LDAPMod **mods );
+int ldtap_modify_s( LDAP *ld, const char *dn, LDAPMod **mods );
+
+/*
+ * in modrdn.c:
+ */
+
+/*
+ * in rename.c:
+ */
+int ldap_rename(LDAP *ld, const char *dn, const char *newrdn, const char *newparent, int deleteoldrdn, LDAPControl ** serverctrls, LDAPControl **clientctrls, int *msgidp);
+
+int ldap_rename_s(LDAP *ld, const char *dn, const char *newrdn, const char *newparent, int deleteoldrdn, LDAPControl ** serverctrls, LDAPControl **clientctrls);
+
+int ldap_modrdn(LDAP *ld, const char *dn, const char *newrdn);
+int ldap_modrdn_s(LDAP *ld, const char *dn, const char *newrdn);
+int ldap_modrdn2(LDAP *ld, const char *dn, const char *newrdn, int deleteoldrdn);
+
+int ldap_modrdn2_s(LDAP *ld, const char *dn, const char *newrdn, int deleteoldrdn);
+
+/*
+ * in open.c:
+ */
+LDAP *ldap_init( const char *defhost, int defport );
+LDAP *ldap_open(const char *host, int port);
+int ldap_version(LDAPVersion *ver);
+
+/*
+ * in getentry.c:
+ */
+LDAPMessage *ldap_first_entry( LDAP *ld, LDAPMessage *res );
+LDAPMessage *ldap_next_entry( LDAP *ld, LDAPMessage *entry );
+int ldap_count_entries( LDAP *ld, LDAPMessage *res );
+int ldap_get_entry_controls(LDAP *ld, LDAPMessage *entry, LDAPControl ***serverctrlsp);
+
+/*
+ * in getmsg.c:
+ */
+LDAPMessage *ldap_first_message( LDAP *ld, LDAPMessage *res );
+LDAPMessage *ldap_next_message( LDAP *ld, LDAPMessage *msg );
+int ldap_count_messages( LDAP *ld, LDAPMessage *res );
+
+/*
+ * in getref.c:
+ */
+LDAPMessage *ldap_first_reference( LDAP *ld, LDAPMessage *res );
+LDAPMessage *ldap_next_reference( LDAP *ld, LDAPMessage *entry );
+int ldap_count_references( LDAP *ld, LDAPMessage *res );
+
+/*
+ * in getdn.c
+ */
+char *ldap_get_dn( LDAP *ld, LDAPMessage *entry );
+char **ldap_explode_dn( const char *dn, const int notypes );
+char ** ldap_explode_rdn( const char *rdn, const int notypes );
+char *ldap_dn2ufn( const char *dn );
+char **ldap_explode_dns( const char *dn );
+int ldap_is_dns_dn( const char *dn );
+char *ldap_dns_to_dn(char *dns_name, int *nameparts);
+
+/*
+ * in getattr.c
+ */
+char *ldap_first_attribute( LDAP *ld, LDAPMessage *entry,
+ BerElement **ber );
+
+char *ldap_next_attribute( LDAP *ld, LDAPMessage *entry,
+ BerElement *ber );
+
+void ldap_memfree(void *p);
+
+/*
+ * in getvalues.c
+ */
+char **ldap_get_values( LDAP *ld, LDAPMessage *entry, const char *target );
+int ldap_count_values( char **vals );
+int ldap_count_values_len( struct berval **vals );
+void ldap_value_free( char **vals );
+void ldap_value_free_len( struct berval **vals );
+
+struct berval **ldap_get_values_len(LDAP *ld, LDAPMessage *entry, const char *target);
+
+char **ldap_get_lang_values(LDAP *ld, LDAPMessage *entry, const char *target, char **type);
+
+struct berval **ldap_get_lang_values_len(LDAP *ld, LDAPMessage *entry, const char *target, char **type);
+
+/*
+ * in referral.c:
+ */
+int ldap_parse_reference(LDAP *ld, LDAPMessage *ref,
+ char ***referralsp, LDAPControl ***serverctrlsp, int freeit);
+char ** ldap_get_reference_urls(LDAP *ld, LDAPMessage *res);
+
+/*
+ * in result.c:
+ */
+int ldap_result( LDAP *ld, int msgid, int all,
+ struct timeval *timeout, LDAPMessage **result );
+
+int ldap_msgfree( LDAPMessage *lm );
+int ldap_msgtype( LDAPMessage *res );
+int ldap_msgid( LDAPMessage *res );
+int ldap_parse_result(LDAP *ld, LDAPMessage *res, int *errcodep, char **matcheddnp, char **errmsgp, char ***referralsp, LDAPControl ***serverctrlsp, int freeit) ;
+
+int ldap_parse_sasl_bind_result(LDAP *ld, LDAPMessage *res, struct berval **servercredp, int freeit);
+
+int ldap_parse_extended_result(LDAP *ld, LDAPMessage *res, char **resultoidp, struct berval **resultdata, int freeit);
+
+/*
+ * in search.c:
+ */
+int ldap_search_ext(LDAP *ld, const char *base, int scope, const char *filter, char **attrs, int attrsonly, LDAPControl **serverctrls, LDAPControl **clientctrls, struct timeval *timeoutp, int sizelimit, int *msgidp);
+
+int ldap_search_ext_s(LDAP *ld, const char *base, int scope, const char *filter, char **attrs, int attrsonly, LDAPControl **serverctrls, LDAPControl **clientctrls, struct timeval *timeoutp, int sizelimit, LDAPMessage **res);
+
+int ldap_search( LDAP *ld, const char *base, int scope, const char *filter,
+ char **attrs, int attrsonly );
+
+int ldap_search_s( LDAP *ld, const char *base, int scope, const char *filter,
+ char **attrs, int attrsonly, LDAPMessage **res );
+
+int ldap_search_st( LDAP *ld, const char *base, int scope, const char *filter,
+ char **attrs, int attrsonly, struct timeval *timeout, LDAPMessage **res );
+
+/*
+ * in ufn.c
+ */
+int ldap_ufn_search_c( LDAP *ld, char *ufn, char **attrs,
+ int attrsonly, LDAPMessage **res, LDAP_CANCELPROC_CALLBACK cancelproc,
+ void *cancelparm );
+
+int ldap_ufn_search_ct( LDAP *ld, char *ufn, char **attrs,
+ int attrsonly, LDAPMessage **res, LDAP_CANCELPROC_CALLBACK cancelproc,
+ void *cancelparm, char *tag1, char *tag2, char *tag3 );
+
+int ldap_ufn_search_s( LDAP *ld, char *ufn, char **attrs,
+ int attrsonly, LDAPMessage **res );
+
+LDAPFiltDesc *ldap_ufn_setfilter( LDAP *ld, char *fname );
+void ldap_ufn_setprefix( LDAP *ld, char *prefix );
+int ldap_ufn_timeout( void *tvparam );
+
+
+/*
+ * in unbind.c
+ */
+int ldap_unbind( LDAP *ld );
+int ldap_unbind_s( LDAP *ld );
+int ldap_unbind_ext(LDAP *ld, LDAPControl **serverctrls, LDAPControl **clientctrls);
+
+
+/*
+ * in getfilter.c
+ */
+LDAPFiltDesc *ldap_init_getfilter( char *fname );
+LDAPFiltDesc *ldap_init_getfilter_buf( char *buf, ssize_t buflen );
+LDAPFiltInfo *ldap_getfirstfilter( LDAPFiltDesc *lfdp, char *tagpat,
+ char *value );
+
+LDAPFiltInfo *ldap_getnextfilter( LDAPFiltDesc *lfdp );
+void ldap_setfilteraffixes( LDAPFiltDesc *lfdp, char *prefix, char *suffix );
+void ldap_build_filter( char *filtbuf, size_t buflen,
+ char *pattern, char *prefix, char *suffix, char *attr,
+ char *value, char **valwords );
+
+int ldap_create_filter(char *buf, unsigned long buflen, char *pattern, char *prefix, char *suffix, char *attr, char *value, char **valwords);
+
+/*
+ * in free.c
+ */
+void ldap_getfilter_free( LDAPFiltDesc *lfdp );
+void ldap_mods_free( LDAPMod **mods, int freemods );
+void ldap_ber_free(BerElement *ber, int freebuf);
+
+/*
+ * in friendly.c
+ */
+char *ldap_friendly_name( char *filename, char *uname,
+ FriendlyMap *map );
+
+void ldap_free_friendlymap( FriendlyMap *map );
+
+
+/*
+ * in cldap.c
+ */
+
+
+/*
+ * in sort.c
+ */
+int ldap_sort_entries( LDAP *ld, LDAPMessage **chain, char *attr,
+ int (*cmp)() );
+
+int ldap_sort_values( LDAP *ld, char **vals, int (*cmp)() );
+int ldap_sort_strcasecmp( const char **a, const char **b );
+int ldap_multisort_entries(LDAP *ld, LDAPMessage **chain, char **attr, LDAP_CMP_CALLBACK *cmp);
+
+
+/*
+ * in url.c
+ */
+int ldap_is_ldap_url( const char *url );
+int ldap_url_parse( const char *url, LDAPURLDesc **ludpp );
+int ldap_url_parse_nodn(const char *url, LDAPURLDesc **ludpp);
+void ldap_free_urldesc( LDAPURLDesc *ludp );
+int ldap_url_search( LDAP *ld, const char *url, int attrsonly );
+int ldap_url_search_s( LDAP *ld, const char *url, int attrsonly,
+ LDAPMessage **res );
+
+int ldap_url_search_st( LDAP *ld, const char *url, int attrsonly,
+ struct timeval *timeout, LDAPMessage **res );
+
+char *ldap_dns_to_url(LDAP *ld, char *dns_name, char *attrs,
+char *scope, char *filter);
+char *ldap_dn_to_url(LDAP *ld, char *dn, int nameparts);
+
+
+/*
+ * in charset.c
+ */
+void ldap_set_string_translators( LDAP *ld,
+ BERTranslateProc encode_proc, BERTranslateProc decode_proc );
+
+int ldap_translate_from_t61( LDAP *ld, char **bufp,
+ unsigned int *lenp, int free_input );
+
+int ldap_translate_to_t61( LDAP *ld, char **bufp,
+ unsigned int *lenp, int free_input );
+
+void ldap_enable_translation( LDAP *ld, LDAPMessage *entry,
+ int enable );
+
+int ldap_t61_to_8859(char **bufp, unsigned long *buflenp,
+ int free_input);
+
+int ldap_8859_to_t61(char **bufp, unsigned long *buflenp,
+ int free_input);
+
+
+/*
+ * in io.c
+ */
+BerElement *ber_alloc_t(int options);
+int ber_flatten(BerElement *ber, struct berval **bvPtr);
+void ber_free(BerElement *ber, int freebuf);
+BerElement *ber_alloc(void);
+BerElement *ber_init(const struct berval *bv);
+
+/*
+ * in decode.c
+ */
+struct berval *ber_bvdup(const struct berval *bv);
+void ber_bvecfree(struct berval **bv);
+void ber_bvfree(struct berval *bv);
+ber_tag_t ber_first_element(BerElement *ber, unsigned int *len, char **last);
+ber_tag_t ber_next_element(BerElement *ber, ber_tag_t *len, char *last);
+ber_tag_t ber_peek_tag(BerElement *ber, ber_tag_t *len);
+ber_tag_t ber_scanf(BerElement *ber, const char *fmt, ...);
+ber_tag_t ber_skip_tag(BerElement *ber, ber_tag_t *len);
+ber_tag_t ber_get_int(BerElement *ber, ber_int_t *num);
+
+/*
+ * in encode.c
+ */
+int ber_printf(BerElement *ber, const char *fmt, ...);
+
+/*
+ * in control.c
+ */
+void ldap_control_free (LDAPControl *ctrl);
+void ldap_controls_free (LDAPControl **ctrls);
+
+/*
+ * in spagectrl.c
+ */
+int ldap_create_page_control(LDAP *ld, unsigned int pagesize, struct berval *cookie, char isCritical, LDAPControl **output);
+
+int ldap_parse_page_control(LDAP *ld, LDAPControl **controls, unsigned int *totalcount, struct berval **cookie);
+
+/*
+ * in tmplout.c
+ */
+int 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);
+
+int 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);
+
+int 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);
+
+int 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);
+
+int 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);
+
+int ldap_vals2text(LDAP *ld, char *buf, char **vals, char *label, int labelwidth, unsigned long syntaxid, writeptype writeproc, void *writeparm, char *eol, int rdncount);
+
+/*
+ * in extendop.c
+ */
+int ldap_extended_operation(LDAP *ld, const char *requestoid, const struct berval *requestdata, LDAPControl **serverctrls, LDAPControl**clientctrls, int *msgidp);
+
+int ldap_extended_operation_s(LDAP *ld, const char *requestoid, const struct berval *requestdata, LDAPControl **serverctrls, LDAPControl **clientctrls, char **retoidp, struct berval **retdatap);
+
+/*
+ * in disptmpl.c
+ */
+struct ldap_disptmpl *ldap_first_disptmpl(struct ldap_disptmpl *tmpllist);
+struct ldap_tmplitem *ldap_first_tmplcol(struct ldap_disptmpl *tmpl,struct ldap_tmplitem *row);
+
+struct ldap_tmplitem *ldap_first_tmplrow(struct ldap_disptmpl *tmpl);
+void ldap_free_templates(struct ldap_disptmpl *tmpllist);
+int ldap_init_templates(char *file, struct ldap_disptmpl **tmpllistp);
+
+int ldap_init_templates_buf(char *buf, long buflen, struct ldap_disptmpl **tmpllistp);
+
+struct ldap_disptmpl *ldap_next_disptmpl(struct ldap_disptmpl *tmpllist, struct ldap_disptmpl *tmpl);
+
+struct ldap_tmplitem *ldap_next_tmplcol(struct ldap_disptmpl *tmpl, struct ldap_tmplitem *row, struct ldap_tmplitem *col);
+
+struct ldap_tmplitem *ldap_next_tmplrow(struct ldap_disptmpl *tmpl, struct ldap_tmplitem *row);
+
+struct ldap_disptmpl *ldap_oc2template(char **oclist, struct ldap_disptmpl *tmpllist);
+
+char **ldap_tmplattrs(struct ldap_disptmpl *tmpl, char **includeattrs, int exclude, unsigned long syntaxmask);
+
+struct ldap_disptmpl *ldap_name2template(char *name, struct ldap_disptmpl *tmpllist);
+
+/*
+ * in cram_md5.c
+ */
+int ldap_sasl_cram_md5_bind_s(LDAP *ld, char *dn, struct berval *cred, LDAPControl **serverctrls, LDAPControl **clientctrls);
+
+/*
+ * in setoption.c
+ */
+int ldap_set_option (LDAP *ld, int option, const void *optdata);
+
+/*
+ * in log.c
+ */
+void ldaplogconfigf(FILE *fd);
+
+/*
+ * in line64.c
+ */
+char *ldif_type_and_value(char *type, char *val, int vlen);
+char *str_getline(char **next);
+int str_parse_line(char *line, char **type, char **value, int *vlen);
+
+/*
+ * in sortctrl.c
+ */
+int ldap_create_sort_control (LDAP *ld, LDAPsortkey **sortKeyList, const char ctl_iscritical, LDAPControl **ctrlp);
+
+int ldap_parse_sort_control(LDAP *ld, LDAPControl **ctrlp, unsigned long *result, char **attribute);
+
+int ldap_create_sort_keylist(LDAPsortkey ***sortKeyList, const char *string_rep);
+
+void ldap_free_sort_keylist(LDAPsortkey **sortKeyList);
+
+/*
+ * in vlistctrl.c
+ */
+int ldap_create_virtuallist_control(LDAP *ld, LDAPVirtualList *ldvlistp, LDAPControl **ctrlp);
+
+int ldap_parse_virtuallist_control(LDAP *ld, LDAPControl **ctrls, unsigned long *target_posp, unsigned long *list_sizep, int *errcodep);
+
+/*
+ * in ldapsinit.c
+ */
+LDAP * ldapssl_init( const char *defhost, int defport, int defsecure );
+int ldapssl_install_routines( LDAP *ld );
+int ldapssl_enable_clientauth( LDAP *ld, char *keynickname, char *keypasswd, char *certnickname );
+
+/*
+ * in clientinit.c
+ */
+int ldapssl_client_init( const char *certdbpath, void *certdbhandle);
+int ldapssl_clientauth_init(const char *certdbpath, void *certdbhandle, const int needkeydb, const char *keydbpath, void *keydbhandle);
+
+int ldapssl_advclientauth_init( const char *certdbpath, void *certdbhandle, const int needkeydb, const char *keydbpath, void *keydbhandle, const int needsecmoddb, const char *secmoddbpath, const int sslstrength );
+
+int ldapssl_pkcs_init( const struct ldapssl_pkcs_fns *pfns);
+
+/*
+ * in errormap.c
+ */
+const char * ldapssl_err2string( const int prerrno );
+
+/*
+ * in psearch.c
+ */
+int ldap_create_persistentsearch_control(LDAP *ld, int changetypes, int changesonly, int return_echg_ctls, char ctl_iscritical, LDAPControl **ctrlp);
+
+int ldap_parse_entrychange_control(LDAP *ld, LDAPControl **ctrls, int *chgtypep, char **prevdnp, int *chgnumpresentp, ber_int_t *chgnump);
+
+/*
+ * in proxyauthctrl.c
+ */
+int ldap_create_proxyauth_control(LDAP *ld, const char *dn, const char ctl_iscritical, LDAPControl **ctrlp);
+
+int ldap_create_proxiedauth_control(LDAP *ld, const char *authzid, LDAPControl **ctrlp);
+
+/*
+ * in srchpref.c
+ */
+struct ldap_searchobj *ldap_first_searchobj(struct ldap_searchobj *solist);
+void ldap_free_searchprefs(struct ldap_searchobj *solist);
+int ldap_init_searchprefs(char *file, struct ldap_searchobj **solistp);
+int ldap_init_searchprefs_buf(char *buf, long buflen, struct ldap_searchobj **solistp);
+
+struct ldap_searchobj *ldap_next_searchobj(struct ldap_searchobj *solist, struct ldap_searchobj *so);
+
+/*
+ * in getoption.c
+ */
+int ldap_get_option (LDAP *ld, int option, void *outvalue);
+
+/*
+ * in memcache.c
+ */
+int ldap_memcache_init(unsigned long ttl, unsigned long size, char **baseDNs, struct ldap_thread_fns *thread_fns, LDAPMemCache **cachep);
+
+int ldap_memcache_set(LDAP *ld, LDAPMemCache *cache);
+int ldap_memcache_get(LDAP *ld, LDAPMemCache **cachep);
+void ldap_memcache_flush(LDAPMemCache *cache, char *dn, int scope);
+void ldap_memcache_destroy(LDAPMemCache *cache);
+void ldap_memcache_update(LDAPMemCache *cache);
+
+/*
+ * in digest_md5.c
+ */
+int ldap_x_sasl_digest_md5_bind_s(LDAP *ld, char *dn, struct berval *cred, LDAPControl **serverctrls, LDAPControl **clientctrls);