diff options
author | Andrew Bartlett <abartlet@samba.org> | 2009-09-01 11:59:50 +1000 |
---|---|---|
committer | Matthias Dieter Wallnöfer <mwallnoefer@yahoo.de> | 2009-10-02 12:45:01 +0200 |
commit | 38f87f40bfd7892043d49009067ae28431279580 (patch) | |
tree | ded4df4df76f7671469ed3c634c9756f11b7331c /source4/lib | |
parent | 8bf517d340b4abbbcbda39c35e449d3c896a3728 (diff) | |
download | samba-38f87f40bfd7892043d49009067ae28431279580.tar.gz samba-38f87f40bfd7892043d49009067ae28431279580.tar.bz2 samba-38f87f40bfd7892043d49009067ae28431279580.zip |
s4:ldb-samba Use temp talloc contexts and talloc_steal avoid leaks.
We would use the mem_ctx for internal work, but previously we did not
clean it up on exit.
Andrew Bartlett
Diffstat (limited to 'source4/lib')
-rw-r--r-- | source4/lib/ldb-samba/ldif_handlers.c | 59 |
1 files changed, 47 insertions, 12 deletions
diff --git a/source4/lib/ldb-samba/ldif_handlers.c b/source4/lib/ldb-samba/ldif_handlers.c index 43a10450d1..839a8f2723 100644 --- a/source4/lib/ldb-samba/ldif_handlers.c +++ b/source4/lib/ldb-samba/ldif_handlers.c @@ -181,28 +181,38 @@ static int extended_dn_read_SID(struct ldb_context *ldb, void *mem_ctx, { struct dom_sid sid; enum ndr_err_code ndr_err; + TALLOC_CTX *tmp_ctx; if (ldif_comparision_objectSid_isString(in)) { if (ldif_read_objectSid(ldb, mem_ctx, in, out) == 0) { return 0; } } + tmp_ctx = talloc_new(mem_ctx); + if (!tmp_ctx) { + return -1; + } + /* Perhaps not a string after all */ - *out = data_blob_talloc(mem_ctx, NULL, in->length/2+1); + *out = data_blob_talloc(tmp_ctx, NULL, in->length/2+1); if (!out->data) { + talloc_free(tmp_ctx); return -1; } - (*out).length = strhex_to_str((char *)out->data, out->length, - (const char *)in->data, in->length); + out->length = strhex_to_str((char *)out->data, out->length, + (const char *)in->data, in->length); /* Check it looks like a SID */ - ndr_err = ndr_pull_struct_blob_all(out, mem_ctx, NULL, &sid, + ndr_err = ndr_pull_struct_blob_all(out, tmp_ctx, NULL, &sid, (ndr_pull_flags_fn_t)ndr_pull_dom_sid); if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) { + talloc_free(tmp_ctx); return -1; } + talloc_steal(mem_ctx, out->data); + talloc_free(tmp_ctx); return 0; } @@ -215,17 +225,24 @@ static int ldif_read_objectGUID(struct ldb_context *ldb, void *mem_ctx, struct GUID guid; NTSTATUS status; enum ndr_err_code ndr_err; + TALLOC_CTX *tmp_ctx = talloc_new(mem_ctx); + if (!tmp_ctx) { + return -1; + } status = GUID_from_data_blob(in, &guid); if (!NT_STATUS_IS_OK(status)) { return -1; } - ndr_err = ndr_push_struct_blob(out, mem_ctx, NULL, &guid, + ndr_err = ndr_push_struct_blob(out, tmp_ctx, NULL, &guid, (ndr_push_flags_fn_t)ndr_push_GUID); if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) { + talloc_free(tmp_ctx); return -1; } + talloc_steal(mem_ctx, out->data); + talloc_free(tmp_ctx); return 0; } @@ -237,12 +254,18 @@ static int ldif_write_objectGUID(struct ldb_context *ldb, void *mem_ctx, { struct GUID guid; enum ndr_err_code ndr_err; - ndr_err = ndr_pull_struct_blob_all(in, mem_ctx, NULL, &guid, + TALLOC_CTX *tmp_ctx = talloc_new(mem_ctx); + if (!tmp_ctx) { + return -1; + } + ndr_err = ndr_pull_struct_blob_all(in, tmp_ctx, NULL, &guid, (ndr_pull_flags_fn_t)ndr_pull_GUID); if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) { + talloc_free(tmp_ctx); return -1; } out->data = (uint8_t *)GUID_string(mem_ctx, &guid); + talloc_free(tmp_ctx); if (out->data == NULL) { return -1; } @@ -263,6 +286,7 @@ static int extended_dn_read_GUID(struct ldb_context *ldb, void *mem_ctx, { struct GUID guid; enum ndr_err_code ndr_err; + TALLOC_CTX *tmp_ctx; if (in->length == 36 && ldif_read_objectGUID(ldb, mem_ctx, in, out) == 0) { return 0; } @@ -272,21 +296,30 @@ static int extended_dn_read_GUID(struct ldb_context *ldb, void *mem_ctx, return -1; } - *out = data_blob_talloc(mem_ctx, NULL, in->length/2+1); + tmp_ctx = talloc_new(mem_ctx); + if (!tmp_ctx) { + return -1; + } + + *out = data_blob_talloc(tmp_ctx, NULL, in->length/2+1); if (!out->data) { + talloc_free(tmp_ctx); return -1; } - (*out).length = strhex_to_str((char *)out->data, out->length, - (const char *)in->data, in->length); + out->length = strhex_to_str((char *)out->data, out->length, + (const char *)in->data, in->length); /* Check it looks like a GUID */ - ndr_err = ndr_pull_struct_blob_all(out, mem_ctx, NULL, &guid, + ndr_err = ndr_pull_struct_blob_all(out, tmp_ctx, NULL, &guid, (ndr_pull_flags_fn_t)ndr_pull_GUID); if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) { + talloc_free(tmp_ctx); return -1; } + talloc_steal(mem_ctx, out->data); + talloc_free(tmp_ctx); return 0; } @@ -368,12 +401,14 @@ static int ldif_read_ntSecurityDescriptor(struct ldb_context *ldb, void *mem_ctx } } - ndr_err = ndr_push_struct_blob(out, mem_ctx, NULL, sd, + ndr_err = ndr_push_struct_blob(out, sd, NULL, sd, (ndr_push_flags_fn_t)ndr_push_security_descriptor); - talloc_free(sd); if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) { + talloc_free(sd); return -1; } + talloc_steal(mem_ctx, out->data); + talloc_free(sd); return 0; } |