From 8d6964aa2c0f2bf6ecfeeb69f2481a189805d77e Mon Sep 17 00:00:00 2001 From: Simo Sorce Date: Dec 10 2009 22:20:20 +0000 Subject: Fix for #322, update from old database versions. --- diff --git a/server/db/sysdb.c b/server/db/sysdb.c index 10da975..f22cea3 100644 --- a/server/db/sysdb.c +++ b/server/db/sysdb.c @@ -1087,6 +1087,8 @@ static int sysdb_upgrade_02(struct confdb_ctx *cdb, for (j = 0; j < res->count; j++) { + struct ldb_dn *orig_dn; + msg = res->msgs[j]; /* skip pre-created congtainers */ @@ -1096,6 +1098,17 @@ static int sysdb_upgrade_02(struct confdb_ctx *cdb, continue; } + /* regenerate the DN against the new ldb as it may have different + * casefolding rules (example: name changing from case insensitive + * to case sensitive) */ + orig_dn = msg->dn; + msg->dn = ldb_dn_new(msg, ctx->ldb, + ldb_dn_get_linearized(orig_dn)); + if (!msg->dn) { + ret = ENOMEM; + goto done; + } + ret = ldb_add(ctx->ldb, msg); if (ret != LDB_SUCCESS) { DEBUG(0, ("WARNING: Could not add entry %s," @@ -1104,7 +1117,7 @@ static int sysdb_upgrade_02(struct confdb_ctx *cdb, ret, ldb_errstring(ctx->ldb))); } - ret = ldb_delete(local->ldb, msg->dn); + ret = ldb_delete(local->ldb, orig_dn); if (ret != LDB_SUCCESS) { DEBUG(0, ("WARNING: Could not remove entry %s," " from old ldb file! (%d [%s])\n",