mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
fix ITS#4686 (retry with idassert)
This commit is contained in:
parent
067d6904c2
commit
0e9983ff2b
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user