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"
35 bi->bi_controls = slap_known_controls;
44 bi->bi_open = meta_back_open;
49 bi->bi_db_init = meta_back_db_init;
50 bi->bi_db_config = meta_back_db_config;
53 bi->bi_db_destroy = meta_back_db_destroy;
55 bi->bi_op_bind = meta_back_bind;
57 bi->bi_op_search = meta_back_search;
58 bi->bi_op_compare = meta_back_compare;
59 bi->bi_op_modify = meta_back_modify;
60 bi->bi_op_modrdn = meta_back_modrdn;
61 bi->bi_op_add = meta_back_add;
62 bi->bi_op_delete = meta_back_delete;
63 bi->bi_op_abandon = 0;
67 bi->bi_chk_referrals = 0;
69 bi->bi_connection_init = 0;
70 bi->bi_connection_destroy = meta_back_conn_destroy;
82 struct rewrite_info *rwinfo;
84 rwinfo = rewrite_info_init( REWRITE_MODE_USE_DEFAULT );
85 if ( rwinfo == NULL ) {
89 li = ch_calloc( 1, sizeof( struct metainfo ) );
91 rewrite_info_delete( &rwinfo );
96 * At present the default is no default target;
99 li->defaulttarget = META_DEFAULT_TARGET_NONE;
102 ldap_pvt_thread_mutex_init( &li->conn_mutex );
103 ldap_pvt_thread_mutex_init( &li->cache.mutex );
114 struct metaconn *lc = v_lc;
115 struct metasingleconn *lsc;
117 for ( lsc = lc->conns; !META_LAST(lsc); lsc++ ) {
118 if ( lsc->ld != NULL ) {
119 ldap_unbind( lsc->ld );
121 if ( lsc->bound_dn.bv_val ) {
122 ber_memfree( lsc->bound_dn.bv_val );
124 if ( lsc->cred.bv_val ) {
125 memset( lsc->cred.bv_val, 0, lsc->cred.bv_len );
126 ber_memfree( lsc->cred.bv_val );
134 mapping_free( void *v_mapping )
136 struct ldapmapping *mapping = v_mapping;
137 ch_free( mapping->src.bv_val );
138 ch_free( mapping->dst.bv_val );
144 struct metatarget *lt
150 if ( lt->psuffix.bv_val ) {
151 free( lt->psuffix.bv_val );
153 if ( lt->suffix.bv_val ) {
154 free( lt->suffix.bv_val );
156 if ( lt->binddn.bv_val ) {
157 free( lt->binddn.bv_val );
159 if ( lt->bindpw.bv_val ) {
160 free( lt->bindpw.bv_val );
162 if ( lt->pseudorootdn.bv_val ) {
163 free( lt->pseudorootdn.bv_val );
165 if ( lt->pseudorootpw.bv_val ) {
166 free( lt->pseudorootpw.bv_val );
168 if ( lt->rwmap.rwm_rw ) {
169 rewrite_info_delete( <->rwmap.rwm_rw );
171 avl_free( lt->rwmap.rwm_oc.remap, NULL );
172 avl_free( lt->rwmap.rwm_oc.map, mapping_free );
173 avl_free( lt->rwmap.rwm_at.remap, NULL );
174 avl_free( lt->rwmap.rwm_at.map, mapping_free );
178 meta_back_db_destroy(
184 if ( be->be_private ) {
187 li = ( struct metainfo * )be->be_private;
190 * Destroy the connection tree
192 ldap_pvt_thread_mutex_lock( &li->conn_mutex );
194 if ( li->conntree ) {
195 avl_free( li->conntree, conn_free );
199 * Destroy the per-target stuff (assuming there's at
202 for ( i = 0; i < li->ntargets; i++ ) {
203 target_free( li->targets[ i ] );
204 free( li->targets[ i ] );
209 ldap_pvt_thread_mutex_lock( &li->cache.mutex );
210 if ( li->cache.tree ) {
211 avl_free( li->cache.tree, meta_dncache_free );
214 ldap_pvt_thread_mutex_unlock( &li->cache.mutex );
215 ldap_pvt_thread_mutex_destroy( &li->cache.mutex );
217 ldap_pvt_thread_mutex_unlock( &li->conn_mutex );
218 ldap_pvt_thread_mutex_destroy( &li->conn_mutex );
221 free( be->be_private );
225 #if SLAPD_META == SLAPD_MOD_DYNAMIC
228 init_module( int argc, char *argv[] )
232 memset( &bi, '\0', sizeof( bi ) );
234 bi.bi_init = meta_back_initialize;
241 #endif /* SLAPD_META */