X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fback-ldap%2Funbind.c;h=a5aa5f1f9245f117b8e9b1b9e73a2e7f301f0f93;hb=08059f1633bfd9d0a709761b026bdb8e4441c6e6;hp=ac1adcb7405a9488861bc4d7665f2b810f999bba;hpb=403f4479bc9f9a864122d4aeecf7284408918302;p=openldap diff --git a/servers/slapd/back-ldap/unbind.c b/servers/slapd/back-ldap/unbind.c index ac1adcb740..a5aa5f1f92 100644 --- a/servers/slapd/back-ldap/unbind.c +++ b/servers/slapd/back-ldap/unbind.c @@ -1,6 +1,10 @@ /* unbind.c - ldap backend unbind function */ /* $OpenLDAP$ */ - +/* + * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved. + * COPYING RESTRICTIONS APPLY, see COPYRIGHT file + */ +/* This is an altered version */ /* * Copyright 1999, Howard Chu, All rights reserved. * @@ -20,6 +24,15 @@ * ever read sources, credits should appear in the documentation. * * 4. This notice may not be removed or altered. + * + * + * + * Copyright 2000, Pierangelo Masarati, All rights reserved. + * + * This software is being modified by Pierangelo Masarati. + * The previously reported conditions apply to the modified code as well. + * Changes in the original code are highlighted where required. + * Credits for the original code go to the author, Howard Chu. */ #include "portable.h" @@ -39,21 +52,54 @@ ldap_back_conn_destroy( ) { struct ldapinfo *li = (struct ldapinfo *) be->be_private; - struct ldapconn *lc, *lp; + struct ldapconn *lc, lc_curr; +#ifdef NEW_LOGGING + LDAP_LOG( BACK_LDAP, INFO, + "ldap_back_conn_destroy: fetching conn %ld\n", conn->c_connid, 0, 0 ); +#else /* !NEW_LOGGING */ + Debug( LDAP_DEBUG_TRACE, + "=>ldap_back_conn_destroy: fetching conn %ld\n", + conn->c_connid, 0, 0 ); +#endif /* !NEW_LOGGING */ + + lc_curr.conn = conn; + ldap_pvt_thread_mutex_lock( &li->conn_mutex ); - for (lc = li->lcs, lp = (struct ldapconn *)&li->lcs; lc; - lp=lc, lc=lc->next) - if (lc->conn == conn) { - lp->next = lc->next; - break; - } + lc = avl_delete( &li->conntree, (caddr_t)&lc_curr, ldap_back_conn_cmp ); ldap_pvt_thread_mutex_unlock( &li->conn_mutex ); if (lc) { - if (lc->bound) - ldap_unbind(lc->ld); - free(lc); +#ifdef NEW_LOGGING + LDAP_LOG( BACK_LDAP, DETAIL1, + "ldap_back_conn_destroy: destroying conn %ld\n", + conn->c_connid, 0, 0 ); +#else /* !NEW_LOGGING */ + Debug( LDAP_DEBUG_TRACE, + "=>ldap_back_conn_destroy: destroying conn %ld\n", + lc->conn->c_connid, 0, 0 ); +#endif + +#ifdef ENABLE_REWRITE + /* + * Cleanup rewrite session + */ + rewrite_session_delete( li->rwinfo, conn ); +#endif /* ENABLE_REWRITE */ + + /* + * Needs a test because the handler may be corrupted, + * and calling ldap_unbind on a corrupted header results + * in a segmentation fault + */ + ldap_unbind(lc->ld); + if ( lc->bound_dn.bv_val ) { + ch_free( lc->bound_dn.bv_val ); + } + if ( lc->cred.bv_val ) { + ch_free( lc->cred.bv_val ); + } + ch_free( lc ); } /* no response to unbind */