]> git.sur5r.net Git - openldap/commitdiff
Call post-op bind functions after SASL bind
authorLuke Howard <lukeh@openldap.org>
Sun, 31 Aug 2003 03:08:06 +0000 (03:08 +0000)
committerLuke Howard <lukeh@openldap.org>
Sun, 31 Aug 2003 03:08:06 +0000 (03:08 +0000)
servers/slapd/bind.c

index d0add6a7a5b569dd9288c580c63d2acd248977da..c7dfa7ebb0c228487924563403b6db9b29cd749a 100644 (file)
@@ -294,6 +294,22 @@ do_bind(
 
                rs->sr_err = slap_sasl_bind( op, rs );
 
+#ifdef LDAP_SLAPI
+               /*
+                * Normally post-operation plugins are called only after the
+                * backend operation. Because the front-end performs SASL
+                * binds on behalf of the backend, we'll make a special
+                * exception to call the post-operation plugins after a
+                * SASL bind.
+                */
+               slapi_x_pblock_set_operation( pb, op );
+               slapi_pblock_set( pb, SLAPI_BIND_TARGET, (void *)dn.bv_val );
+               slapi_pblock_set( pb, SLAPI_BIND_METHOD, (void *)method );
+               slapi_pblock_set( pb, SLAPI_BIND_CREDENTIALS, (void *)&op->orb_cred );
+               slapi_pblock_set( pb, SLAPI_MANAGEDSAIT, (void *)(0) );
+               (void) doPluginFNs( op->o_bd, SLAPI_PLUGIN_POST_BIND_FN, pb );
+#endif /* LDAP_SLAPI */
+
                ldap_pvt_thread_mutex_lock( &op->o_conn->c_mutex );
                if( rs->sr_err == LDAP_SUCCESS ) {
                        ber_dupbv(&op->o_conn->c_dn, &op->orb_edn);
@@ -634,6 +650,7 @@ do_bind(
 #endif /* defined( LDAP_SLAPI ) */
 
 cleanup:
+
        op->o_conn->c_sasl_bindop = NULL;
 
        if( op->o_req_dn.bv_val != NULL ) {