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;
59 bi->bi_open = meta_back_open;
64 bi->bi_db_init = meta_back_db_init;
65 bi->bi_db_config = meta_back_db_config;
68 bi->bi_db_destroy = meta_back_db_destroy;
70 bi->bi_op_bind = meta_back_bind;
72 bi->bi_op_search = meta_back_search;
73 bi->bi_op_compare = meta_back_compare;
74 bi->bi_op_modify = meta_back_modify;
75 bi->bi_op_modrdn = meta_back_modrdn;
76 bi->bi_op_add = meta_back_add;
77 bi->bi_op_delete = meta_back_delete;
78 bi->bi_op_abandon = 0;
82 bi->bi_chk_referrals = 0;
84 bi->bi_connection_init = 0;
85 bi->bi_connection_destroy = meta_back_conn_destroy;
97 struct rewrite_info *rwinfo;
99 rwinfo = rewrite_info_init( REWRITE_MODE_USE_DEFAULT );
100 if ( rwinfo == NULL ) {
104 li = ch_calloc( 1, sizeof( struct metainfo ) );
106 rewrite_info_delete( &rwinfo );
111 * At present the default is no default target;
114 li->defaulttarget = META_DEFAULT_TARGET_NONE;
117 ldap_pvt_thread_mutex_init( &li->conn_mutex );
118 ldap_pvt_thread_mutex_init( &li->cache.mutex );
129 struct metaconn *lc = v_lc;
130 struct metasingleconn *lsc;
132 for ( lsc = lc->conns; !META_LAST(lsc); lsc++ ) {
133 if ( lsc->ld != NULL ) {
134 ldap_unbind( lsc->ld );
136 if ( lsc->bound_dn.bv_val ) {
137 ber_memfree( lsc->bound_dn.bv_val );
139 if ( lsc->cred.bv_val ) {
140 memset( lsc->cred.bv_val, 0, lsc->cred.bv_len );
141 ber_memfree( lsc->cred.bv_val );
150 struct metatarget *lt
156 if ( lt->psuffix.bv_val ) {
157 free( lt->psuffix.bv_val );
159 if ( lt->suffix.bv_val ) {
160 free( lt->suffix.bv_val );
162 if ( lt->binddn.bv_val ) {
163 free( lt->binddn.bv_val );
165 if ( lt->bindpw.bv_val ) {
166 free( lt->bindpw.bv_val );
168 if ( lt->pseudorootdn.bv_val ) {
169 free( lt->pseudorootdn.bv_val );
171 if ( lt->pseudorootpw.bv_val ) {
172 free( lt->pseudorootpw.bv_val );
174 if ( lt->rwmap.rwm_rw ) {
175 rewrite_info_delete( <->rwmap.rwm_rw );
177 avl_free( lt->rwmap.rwm_oc.remap, NULL );
178 avl_free( lt->rwmap.rwm_oc.map, mapping_free );
179 avl_free( lt->rwmap.rwm_at.remap, NULL );
180 avl_free( lt->rwmap.rwm_at.map, mapping_free );
184 meta_back_db_destroy(
190 if ( be->be_private ) {
193 li = ( struct metainfo * )be->be_private;
196 * Destroy the connection tree
198 ldap_pvt_thread_mutex_lock( &li->conn_mutex );
200 if ( li->conntree ) {
201 avl_free( li->conntree, conn_free );
205 * Destroy the per-target stuff (assuming there's at
208 for ( i = 0; i < li->ntargets; i++ ) {
209 target_free( li->targets[ i ] );
210 free( li->targets[ i ] );
215 ldap_pvt_thread_mutex_lock( &li->cache.mutex );
216 if ( li->cache.tree ) {
217 avl_free( li->cache.tree, meta_dncache_free );
220 ldap_pvt_thread_mutex_unlock( &li->cache.mutex );
221 ldap_pvt_thread_mutex_destroy( &li->cache.mutex );
223 ldap_pvt_thread_mutex_unlock( &li->conn_mutex );
224 ldap_pvt_thread_mutex_destroy( &li->conn_mutex );
227 free( be->be_private );