From 753bf8fb995d5cd9abe4c23b5dc79e2392dfa1cb Mon Sep 17 00:00:00 2001 From: Simo Sorce Date: Wed, 15 Mar 2006 21:23:17 +0000 Subject: r14459: Make this async compatible (This used to be commit a71d762acff73a5ba11927a3afbcbf404314aa24) --- source4/nbt_server/wins/wins_ldb.c | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) (limited to 'source4/nbt_server') diff --git a/source4/nbt_server/wins/wins_ldb.c b/source4/nbt_server/wins/wins_ldb.c index 83b8d3f438..6fcf675702 100644 --- a/source4/nbt_server/wins/wins_ldb.c +++ b/source4/nbt_server/wins/wins_ldb.c @@ -44,6 +44,11 @@ static int wins_ldb_verify(struct ldb_module *module, struct ldb_request *req, c struct winsdb_handle); char *error = NULL; + /* do not manipulate our control entries */ + if (ldb_dn_is_special(msg->dn)) { + return ldb_next_request(module, req); + } + if (!h) { error = talloc_strdup(module, "WINS_LDB: INTERNAL ERROR: no winsdb_handle present!"); ldb_debug(module->ldb, LDB_DEBUG_FATAL, "%s", error); @@ -68,28 +73,28 @@ static int wins_ldb_verify(struct ldb_module *module, struct ldb_request *req, c static int wins_ldb_request(struct ldb_module *module, struct ldb_request *req) { - const struct ldb_message *msg = req->op.mod.message; + const struct ldb_message *msg; switch (req->operation) { case LDB_REQ_ADD: + case LDB_ASYNC_ADD: + msg = req->op.add.message; break; - + case LDB_REQ_MODIFY: + case LDB_ASYNC_MODIFY: + msg = req->op.mod.message; break; default: - goto call_next; + return ldb_next_request(module, req); } - if (ldb_dn_is_special(msg->dn)) goto call_next; - return wins_ldb_verify(module, req, msg); - -call_next: - return ldb_next_request(module, req); } + static int wins_ldb_init(struct ldb_module *ctx) { -- cgit