/* init.c - initialize ldap backend */
+/* $OpenLDAP$ */
/*
* Copyright 1999, Howard Chu, All rights reserved. <hyc@highlandsun.com>
#include "back-ldap.h"
#ifdef SLAPD_LDAP_DYNAMIC
-#include <gmodule.h>
-G_MODULE_EXPORT void init_module(int argc, char *argv[]) {
- BackendInfo bi;
+int back_ldap_LTX_init_module(int argc, char *argv[]) {
+ BackendInfo bi;
- memset( &bi, 0, sizeof(bi) );
- bi.bi_type = "ldap";
- bi.bi_init = ldap_back_initialize;
+ memset( &bi, '\0', sizeof(bi) );
+ bi.bi_type = "ldap";
+ bi.bi_init = ldap_back_initialize;
- backend_add(&bi);
+ backend_add(&bi);
+ return 0;
}
#endif /* SLAPD_LDAP_DYNAMIC */
bi->bi_op_delete = ldap_back_delete;
bi->bi_op_abandon = 0;
- bi->bi_acl_group = 0;
+ bi->bi_extended = 0;
+
+ bi->bi_acl_group = ldap_back_group;
+ bi->bi_acl_attribute = 0;
+ bi->bi_chk_referrals = 0;
+
+#ifdef HAVE_CYRUS_SASL
+ bi->bi_sasl_authorize = 0;
+ bi->bi_sasl_getsecret = 0;
+ bi->bi_sasl_putsecret = 0;
+#endif /* HAVE_CYRUS_SASL */
bi->bi_connection_init = 0;
bi->bi_connection_destroy = ldap_back_conn_destroy;
if (be->be_private) {
li = (struct ldapinfo *)be->be_private;
- if (li->host) {
- free(li->host);
- li->host = NULL;
+ if (li->url) {
+ free(li->url);
+ li->url = NULL;
+ }
+ if (li->binddn) {
+ free(li->binddn);
+ li->binddn = NULL;
+ }
+ if (li->bindpw) {
+ free(li->bindpw);
+ li->bindpw = NULL;
}
ldap_pvt_thread_mutex_destroy( &li->conn_mutex );
}