2 /* This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 * Copyright 1999-2004 The OpenLDAP Foundation.
5 * Portions Copyright 2001-2003 Pierangelo Masarati.
6 * Portions Copyright 1999-2003 Howard Chu.
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted only as authorized by the OpenLDAP
13 * A copy of this license is available in the file LICENSE in the
14 * top-level directory of the distribution or, alternatively, at
15 * <http://www.OpenLDAP.org/license.html>.
22 #include <ac/string.h>
23 #include <ac/socket.h>
26 #include "../back-ldap/back-ldap.h"
27 #include "back-meta.h"
29 #if SLAPD_META == SLAPD_MOD_DYNAMIC
32 init_module( int argc, char *argv[] ) {
35 memset( &bi, '\0', sizeof( bi ) );
37 bi.bi_init = meta_back_initialize;
43 #endif /* SLAPD_META */
50 bi->bi_controls = slap_known_controls;
57 bi->bi_db_init = meta_back_db_init;
58 bi->bi_db_config = meta_back_db_config;
61 bi->bi_db_destroy = meta_back_db_destroy;
63 bi->bi_op_bind = meta_back_bind;
65 bi->bi_op_search = meta_back_search;
66 bi->bi_op_compare = meta_back_compare;
67 bi->bi_op_modify = meta_back_modify;
68 bi->bi_op_modrdn = meta_back_modrdn;
69 bi->bi_op_add = meta_back_add;
70 bi->bi_op_delete = meta_back_delete;
71 bi->bi_op_abandon = 0;
75 bi->bi_chk_referrals = 0;
77 bi->bi_connection_init = 0;
78 bi->bi_connection_destroy = meta_back_conn_destroy;
90 struct rewrite_info *rwinfo;
92 rwinfo = rewrite_info_init( REWRITE_MODE_USE_DEFAULT );
93 if ( rwinfo == NULL ) {
97 li = ch_calloc( 1, sizeof( struct metainfo ) );
99 rewrite_info_delete( &rwinfo );
104 * At present the default is no default target;
107 li->defaulttarget = META_DEFAULT_TARGET_NONE;
110 ldap_pvt_thread_mutex_init( &li->conn_mutex );
111 ldap_pvt_thread_mutex_init( &li->cache.mutex );
122 struct metaconn *lc = v_lc;
123 struct metasingleconn *lsc;
125 for ( lsc = lc->conns; !META_LAST(lsc); lsc++ ) {
126 if ( lsc->ld != NULL ) {
127 ldap_unbind( lsc->ld );
129 if ( lsc->bound_dn.bv_val ) {
130 ber_memfree( lsc->bound_dn.bv_val );
132 if ( lsc->cred.bv_val ) {
133 memset( lsc->cred.bv_val, 0, lsc->cred.bv_len );
134 ber_memfree( lsc->cred.bv_val );
143 struct metatarget *lt
149 if ( lt->psuffix.bv_val ) {
150 free( lt->psuffix.bv_val );
152 if ( lt->suffix.bv_val ) {
153 free( lt->suffix.bv_val );
155 if ( lt->binddn.bv_val ) {
156 free( lt->binddn.bv_val );
158 if ( lt->bindpw.bv_val ) {
159 free( lt->bindpw.bv_val );
161 if ( lt->pseudorootdn.bv_val ) {
162 free( lt->pseudorootdn.bv_val );
164 if ( lt->pseudorootpw.bv_val ) {
165 free( lt->pseudorootpw.bv_val );
167 if ( lt->rwmap.rwm_rw ) {
168 rewrite_info_delete( <->rwmap.rwm_rw );
170 avl_free( lt->rwmap.rwm_oc.remap, NULL );
171 avl_free( lt->rwmap.rwm_oc.map, mapping_free );
172 avl_free( lt->rwmap.rwm_at.remap, NULL );
173 avl_free( lt->rwmap.rwm_at.map, mapping_free );
177 meta_back_db_destroy(
183 if ( be->be_private ) {
186 li = ( struct metainfo * )be->be_private;
189 * Destroy the connection tree
191 ldap_pvt_thread_mutex_lock( &li->conn_mutex );
193 if ( li->conntree ) {
194 avl_free( li->conntree, conn_free );
198 * Destroy the per-target stuff (assuming there's at
201 for ( i = 0; i < li->ntargets; i++ ) {
202 target_free( li->targets[ i ] );
203 free( li->targets[ i ] );
208 ldap_pvt_thread_mutex_lock( &li->cache.mutex );
209 if ( li->cache.tree ) {
210 avl_free( li->cache.tree, meta_dncache_free );
213 ldap_pvt_thread_mutex_unlock( &li->cache.mutex );
214 ldap_pvt_thread_mutex_destroy( &li->cache.mutex );
216 ldap_pvt_thread_mutex_unlock( &li->conn_mutex );
217 ldap_pvt_thread_mutex_destroy( &li->conn_mutex );
220 free( be->be_private );