From 4962548dfe8ec2854e209217066556f339d3186e Mon Sep 17 00:00:00 2001 From: Jeremy Allison Date: Fri, 26 May 2006 00:13:06 +0000 Subject: [PATCH] r15895: Ensure all new rid allocation goes through the same function (deals with races). Jeremy. --- source/passdb/pdb_ldap.c | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/source/passdb/pdb_ldap.c b/source/passdb/pdb_ldap.c index 70d9e6024c8..fbc6378f685 100644 --- a/source/passdb/pdb_ldap.c +++ b/source/passdb/pdb_ldap.c @@ -4439,7 +4439,7 @@ static NTSTATUS ldapsam_get_new_rid(struct ldapsam_privates *priv, return status; } -static BOOL ldapsam_new_rid(struct pdb_methods *methods, uint32 *rid) +static NTSTATUS ldapsam_new_rid_internal(struct pdb_methods *methods, uint32 *rid) { int i; @@ -4447,18 +4447,24 @@ static BOOL ldapsam_new_rid(struct pdb_methods *methods, uint32 *rid) NTSTATUS result = ldapsam_get_new_rid(methods->private_data, rid); if (NT_STATUS_IS_OK(result)) { - return True; + return result; } if (!NT_STATUS_EQUAL(result, NT_STATUS_ACCESS_DENIED)) { - return False; + return result; } /* The ldap update failed (maybe a race condition), retry */ } /* Tried 10 times, fail. */ - return False; + return NT_STATUS_ACCESS_DENIED; +} + +static BOOL ldapsam_new_rid(struct pdb_methods *methods, uint32 *rid) +{ + NTSTATUS result = ldapsam_new_rid_internal(methods, rid); + return NT_STATUS_IS_OK(result) ? True : False; } static BOOL ldapsam_sid_to_id(struct pdb_methods *methods, @@ -4645,7 +4651,7 @@ static NTSTATUS ldapsam_create_user(struct pdb_methods *my_methods, } /* Create the basic samu structure and generate the mods for the ldap commit */ - if (!NT_STATUS_IS_OK((ret = ldapsam_get_new_rid(ldap_state, rid)))) { + if (!NT_STATUS_IS_OK((ret = ldapsam_new_rid_internal(my_methods, rid)))) { DEBUG(1, ("ldapsam_create_user: Could not allocate a new RID\n")); return ret; } @@ -4934,7 +4940,7 @@ static NTSTATUS ldapsam_create_dom_group(struct pdb_methods *my_methods, smbldap_set_mod(&mods, LDAP_MOD_ADD, "gidNumber", gidstr); } - if (!NT_STATUS_IS_OK((ret = ldapsam_get_new_rid(ldap_state, rid)))) { + if (!NT_STATUS_IS_OK((ret = ldapsam_new_rid_internal(my_methods, rid)))) { DEBUG(1, ("ldapsam_create_group: Could not allocate a new RID\n")); return ret; }