1 Star 0 Fork 43

pojunxing/openldap

forked from src-openEuler/openldap 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
backport-ITS-9871-slapo-ppolicy-use-explicit-backend-in-bind_.patch 3.11 KB
一键复制 编辑 原始数据 按行查看 历史
compile_success 提交于 2022-11-07 12:04 . backport patch
From 4e3687cda37b8ed0c6b377d32b6e25dc1b07a735 Mon Sep 17 00:00:00 2001
From: Howard Chu <hyc@openldap.org>
Date: Fri, 24 Jun 2022 16:49:45 +0100
Subject: [PATCH] ITS#9871 slapo-ppolicy: use explicit backend in bind_response
---
servers/slapd/overlays/ppolicy.c | 24 +++++++++++++-----------
1 file changed, 13 insertions(+), 11 deletions(-)
diff --git a/servers/slapd/overlays/ppolicy.c b/servers/slapd/overlays/ppolicy.c
index 1815837aa..7913f35c0 100644
--- a/servers/slapd/overlays/ppolicy.c
+++ b/servers/slapd/overlays/ppolicy.c
@@ -1656,7 +1656,8 @@ free_pwd_history_list( pw_hist **l )
}
typedef struct ppbind {
- slap_overinst *on;
+ pp_info *pi;
+ BackendDB *be;
int send_ctrl;
int set_restrict;
LDAPControl **oldctrls;
@@ -1706,8 +1707,7 @@ static int
ppolicy_bind_response( Operation *op, SlapReply *rs )
{
ppbind *ppb = op->o_callback->sc_private;
- slap_overinst *on = ppb->on;
- pp_info *pi = on->on_bi.bi_private;
+ pp_info *pi = ppb->pi;
Modifications *mod = ppb->mod, *m;
int pwExpired = 0;
int ngut = -1, warn = -1, fc = 0, age, rc;
@@ -1718,7 +1718,7 @@ ppolicy_bind_response( Operation *op, SlapReply *rs )
char nowstr[ LDAP_LUTIL_GENTIME_BUFSIZE ];
char nowstr_usec[ LDAP_LUTIL_GENTIME_BUFSIZE+8 ];
struct berval timestamp, timestamp_usec;
- BackendInfo *bi = op->o_bd->bd_info;
+ BackendDB *be = op->o_bd;
LDAPControl *ctrl = NULL;
Entry *e;
@@ -1728,9 +1728,9 @@ ppolicy_bind_response( Operation *op, SlapReply *rs )
goto locked;
}
- op->o_bd->bd_info = (BackendInfo *)on->on_info;
+ op->o_bd = ppb->be;
rc = be_entry_get_rw( op, &op->o_req_ndn, NULL, NULL, 0, &e );
- op->o_bd->bd_info = bi;
+ op->o_bd = be;
if ( rc != LDAP_SUCCESS ) {
ldap_pvt_thread_mutex_unlock( &pi->pwdFailureTime_mutex );
@@ -2032,8 +2032,9 @@ check_expiring_password:
}
done:
- op->o_bd->bd_info = (BackendInfo *)on->on_info;
+ op->o_bd = ppb->be;
be_entry_release_r( op, e );
+ op->o_bd = be;
locked:
if ( mod && !pi->disable_write ) {
@@ -2072,7 +2073,7 @@ locked:
op2.orm_no_opattrs = 1;
op2.o_dont_replicate = 1;
}
- op2.o_bd->bd_info = (BackendInfo *)on->on_info;
+ op2.o_bd = ppb->be;
}
rc = op2.o_bd->be_modify( &op2, &r2 );
if ( rc != LDAP_SUCCESS ) {
@@ -2103,7 +2104,6 @@ locked:
ppb->oldctrls = add_passcontrol( op, rs, ctrl );
op->o_callback->sc_cleanup = ppolicy_ctrls_cleanup;
}
- op->o_bd->bd_info = bi;
ldap_pvt_thread_mutex_unlock( &pi->pwdFailureTime_mutex );
return SLAP_CB_CONTINUE;
}
@@ -2136,7 +2136,8 @@ ppolicy_bind( Operation *op, SlapReply *rs )
cb = op->o_tmpcalloc( sizeof(ppbind)+sizeof(slap_callback),
1, op->o_tmpmemctx );
ppb = (ppbind *)(cb+1);
- ppb->on = on;
+ ppb->pi = on->on_bi.bi_private;
+ ppb->be = op->o_bd->bd_self;
ppb->pErr = PP_noError;
ppb->set_restrict = 1;
@@ -2426,7 +2427,8 @@ ppolicy_compare(
cb = op->o_tmpcalloc( sizeof(ppbind)+sizeof(slap_callback),
1, op->o_tmpmemctx );
ppb = (ppbind *)(cb+1);
- ppb->on = on;
+ ppb->pi = on->on_bi.bi_private;
+ ppb->be = op->o_bd->bd_self;
ppb->pErr = PP_noError;
ppb->send_ctrl = 1;
/* failures here don't lockout the connection */
--
2.33.0
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/chengyechun/openldap.git
git@gitee.com:chengyechun/openldap.git
chengyechun
openldap
openldap
master

搜索帮助