fix ITS#4686 (retry with idassert)

This commit is contained in:
Pierangelo Masarati 2006-09-26 14:51:47 +00:00
parent 067d6904c2
commit 0e9983ff2b
6 changed files with 18 additions and 6 deletions

View File

@ -92,6 +92,7 @@ ldap_back_add(
} }
attrs[ i ] = NULL; attrs[ i ] = NULL;
retry:
ctrls = op->o_ctrls; ctrls = op->o_ctrls;
rs->sr_err = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn, rs->sr_err = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn,
li->li_version, &li->li_idassert, op, rs, &ctrls ); li->li_version, &li->li_idassert, op, rs, &ctrls );
@ -100,7 +101,6 @@ ldap_back_add(
goto cleanup; goto cleanup;
} }
retry:
rs->sr_err = ldap_add_ext( lc->lc_ld, op->o_req_dn.bv_val, attrs, rs->sr_err = ldap_add_ext( lc->lc_ld, op->o_req_dn.bv_val, attrs,
ctrls, NULL, &msgid ); ctrls, NULL, &msgid );
rs->sr_err = ldap_back_op_result( lc, op, rs, msgid, rs->sr_err = ldap_back_op_result( lc, op, rs, msgid,
@ -109,6 +109,8 @@ retry:
if ( rs->sr_err == LDAP_UNAVAILABLE && retrying ) { if ( rs->sr_err == LDAP_UNAVAILABLE && retrying ) {
retrying &= ~LDAP_BACK_RETRYING; retrying &= ~LDAP_BACK_RETRYING;
if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) { if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) {
/* if the identity changed, there might be need to re-authz */
(void)ldap_back_proxy_authz_ctrl_free( op, &ctrls );
goto retry; goto retry;
} }
} }

View File

@ -50,6 +50,7 @@ ldap_back_compare(
goto cleanup; goto cleanup;
} }
retry:
ctrls = op->o_ctrls; ctrls = op->o_ctrls;
rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn, rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn,
li->li_version, &li->li_idassert, op, rs, &ctrls ); li->li_version, &li->li_idassert, op, rs, &ctrls );
@ -58,7 +59,6 @@ ldap_back_compare(
goto cleanup; goto cleanup;
} }
retry:
rs->sr_err = ldap_compare_ext( lc->lc_ld, op->o_req_dn.bv_val, rs->sr_err = ldap_compare_ext( lc->lc_ld, op->o_req_dn.bv_val,
op->orc_ava->aa_desc->ad_cname.bv_val, op->orc_ava->aa_desc->ad_cname.bv_val,
&op->orc_ava->aa_value, &op->orc_ava->aa_value,
@ -69,6 +69,8 @@ retry:
if ( rc == LDAP_UNAVAILABLE && retrying ) { if ( rc == LDAP_UNAVAILABLE && retrying ) {
retrying &= ~LDAP_BACK_RETRYING; retrying &= ~LDAP_BACK_RETRYING;
if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) { if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) {
/* if the identity changed, there might be need to re-authz */
(void)ldap_back_proxy_authz_ctrl_free( op, &ctrls );
goto retry; goto retry;
} }
} }

View File

@ -50,6 +50,7 @@ ldap_back_delete(
return rs->sr_err; return rs->sr_err;
} }
retry:
ctrls = op->o_ctrls; ctrls = op->o_ctrls;
rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn, rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn,
li->li_version, &li->li_idassert, op, rs, &ctrls ); li->li_version, &li->li_idassert, op, rs, &ctrls );
@ -59,7 +60,6 @@ ldap_back_delete(
goto cleanup; goto cleanup;
} }
retry:
rs->sr_err = ldap_delete_ext( lc->lc_ld, op->o_req_dn.bv_val, rs->sr_err = ldap_delete_ext( lc->lc_ld, op->o_req_dn.bv_val,
ctrls, NULL, &msgid ); ctrls, NULL, &msgid );
rc = ldap_back_op_result( lc, op, rs, msgid, rc = ldap_back_op_result( lc, op, rs, msgid,
@ -68,6 +68,8 @@ retry:
if ( rs->sr_err == LDAP_SERVER_DOWN && retrying ) { if ( rs->sr_err == LDAP_SERVER_DOWN && retrying ) {
retrying &= ~LDAP_BACK_RETRYING; retrying &= ~LDAP_BACK_RETRYING;
if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) { if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) {
/* if the identity changed, there might be need to re-authz */
(void)ldap_back_proxy_authz_ctrl_free( op, &ctrls );
goto retry; goto retry;
} }
} }

View File

@ -98,6 +98,7 @@ ldap_back_modify(
} }
modv[ i ] = 0; modv[ i ] = 0;
retry:;
ctrls = op->o_ctrls; ctrls = op->o_ctrls;
rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn, rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn,
li->li_version, &li->li_idassert, op, rs, &ctrls ); li->li_version, &li->li_idassert, op, rs, &ctrls );
@ -107,7 +108,6 @@ ldap_back_modify(
goto cleanup; goto cleanup;
} }
retry:
rs->sr_err = ldap_modify_ext( lc->lc_ld, op->o_req_dn.bv_val, modv, rs->sr_err = ldap_modify_ext( lc->lc_ld, op->o_req_dn.bv_val, modv,
ctrls, NULL, &msgid ); ctrls, NULL, &msgid );
rc = ldap_back_op_result( lc, op, rs, msgid, rc = ldap_back_op_result( lc, op, rs, msgid,
@ -116,6 +116,8 @@ retry:
if ( rs->sr_err == LDAP_UNAVAILABLE && retrying ) { if ( rs->sr_err == LDAP_UNAVAILABLE && retrying ) {
retrying &= ~LDAP_BACK_RETRYING; retrying &= ~LDAP_BACK_RETRYING;
if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) { if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) {
/* if the identity changed, there might be need to re-authz */
(void)ldap_back_proxy_authz_ctrl_free( op, &ctrls );
goto retry; goto retry;
} }
} }

View File

@ -73,6 +73,7 @@ ldap_back_modrdn(
newSup = op->orr_newSup->bv_val; newSup = op->orr_newSup->bv_val;
} }
retry:
ctrls = op->o_ctrls; ctrls = op->o_ctrls;
rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn, rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn,
li->li_version, &li->li_idassert, op, rs, &ctrls ); li->li_version, &li->li_idassert, op, rs, &ctrls );
@ -82,7 +83,6 @@ ldap_back_modrdn(
goto cleanup; goto cleanup;
} }
retry:
rs->sr_err = ldap_rename( lc->lc_ld, op->o_req_dn.bv_val, rs->sr_err = ldap_rename( lc->lc_ld, op->o_req_dn.bv_val,
op->orr_newrdn.bv_val, newSup, op->orr_newrdn.bv_val, newSup,
op->orr_deleteoldrdn, ctrls, NULL, &msgid ); op->orr_deleteoldrdn, ctrls, NULL, &msgid );
@ -92,6 +92,8 @@ retry:
if ( rs->sr_err == LDAP_SERVER_DOWN && retrying ) { if ( rs->sr_err == LDAP_SERVER_DOWN && retrying ) {
retrying &= ~LDAP_BACK_RETRYING; retrying &= ~LDAP_BACK_RETRYING;
if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) { if ( ldap_back_retry( &lc, op, rs, LDAP_BACK_SENDERR ) ) {
/* if the identity changed, there might be need to re-authz */
(void)ldap_back_proxy_authz_ctrl_free( op, &ctrls );
goto retry; goto retry;
} }
} }

View File

@ -767,6 +767,7 @@ ldap_back_entry_get(
*ptr++ = '\0'; *ptr++ = '\0';
} }
retry:
ctrls = op->o_ctrls; ctrls = op->o_ctrls;
rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn, rc = ldap_back_proxy_authz_ctrl( &lc->lc_bound_ndn,
li->li_version, &li->li_idassert, op, &rs, &ctrls ); li->li_version, &li->li_idassert, op, &rs, &ctrls );
@ -774,7 +775,6 @@ ldap_back_entry_get(
goto cleanup; goto cleanup;
} }
retry:
rc = ldap_search_ext_s( lc->lc_ld, ndn->bv_val, LDAP_SCOPE_BASE, filter, rc = ldap_search_ext_s( lc->lc_ld, ndn->bv_val, LDAP_SCOPE_BASE, filter,
attrp, 0, ctrls, NULL, attrp, 0, ctrls, NULL,
NULL, LDAP_NO_LIMIT, &result ); NULL, LDAP_NO_LIMIT, &result );
@ -782,6 +782,8 @@ retry:
if ( rc == LDAP_SERVER_DOWN && do_retry ) { if ( rc == LDAP_SERVER_DOWN && do_retry ) {
do_retry = 0; do_retry = 0;
if ( ldap_back_retry( &lc, op, &rs, LDAP_BACK_DONTSEND ) ) { if ( ldap_back_retry( &lc, op, &rs, LDAP_BACK_DONTSEND ) ) {
/* if the identity changed, there might be need to re-authz */
(void)ldap_back_proxy_authz_ctrl_free( op, &ctrls );
goto retry; goto retry;
} }
} }