diff options
author | Volker Lendecke <vlendec@samba.org> | 2006-10-04 19:40:25 +0000 |
---|---|---|
committer | Gerald (Jerry) Carter <jerry@samba.org> | 2007-10-10 12:15:08 -0500 |
commit | d234f39c79e0e50f784826d0920ebd21cc9a283d (patch) | |
tree | f4be4798bc99f3a04624fd23118c08e9f29020fd /source/groupdb | |
parent | ba18c58f1fb618447ba39bae6ef8f4e6c00c4d32 (diff) | |
download | samba-d234f39c79e0e50f784826d0920ebd21cc9a283d.tar.gz samba-d234f39c79e0e50f784826d0920ebd21cc9a283d.tar.xz samba-d234f39c79e0e50f784826d0920ebd21cc9a283d.zip |
r19073: mapping_dn can fail
Diffstat (limited to 'source/groupdb')
-rw-r--r-- | source/groupdb/mapping_ldb.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/source/groupdb/mapping_ldb.c b/source/groupdb/mapping_ldb.c index 1b0053da47f..23b800a3788 100644 --- a/source/groupdb/mapping_ldb.c +++ b/source/groupdb/mapping_ldb.c @@ -139,10 +139,14 @@ static struct ldb_dn *mapping_dn(TALLOC_CTX *mem_ctx, const DOM_SID *sid) } msg = ldb_msg_new(ldb); - if (msg == NULL) return False; + if (msg == NULL) { + return False; + } msg->dn = mapping_dn(msg, &map->sid); - if (msg->dn == NULL) goto failed; + if (msg->dn == NULL) { + goto failed; + } if (ldb_msg_add_string(msg, "objectClass", "groupMap") != LDB_SUCCESS || ldb_msg_add_string(msg, "sid", @@ -303,6 +307,9 @@ failed: } dn = mapping_dn(ldb, sid); + if (dn == NULL) { + return False; + } ret = ldb_delete(ldb, dn); talloc_free(dn); @@ -466,6 +473,9 @@ static NTSTATUS modify_aliasmem(const DOM_SID *alias, const DOM_SID *member, } msg.dn = mapping_dn(tmp_ctx, alias); + if (msg.dn == NULL) { + return NT_STATUS_NO_MEMORY; + } msg.num_elements = 1; msg.elements = ⪙ el.flags = operation; @@ -524,6 +534,9 @@ static NTSTATUS modify_aliasmem(const DOM_SID *alias, const DOM_SID *member, *num = 0; dn = mapping_dn(ldb, alias); + if (dn == NULL) { + return NT_STATUS_NO_MEMORY; + } ret = ldb_search(ldb, dn, LDB_SCOPE_BASE, NULL, attrs, &res); talloc_steal(dn, res); |