create ndr_pull_union_blob_all() and match the logic of the struct fns
authormetze <metze@0c0555d6-39d7-0310-84fc-f1cc0bd64818>
Thu, 1 Nov 2007 08:10:54 +0000 (08:10 +0000)
committerStefan Metzmacher <metze@samba.org>
Wed, 7 Nov 2007 11:10:29 +0000 (12:10 +0100)
metze

git-svn-id: svn+ssh://svn.samba.org/data/svn/samba/branches/SAMBA_4_0@25774 0c0555d6-39d7-0310-84fc-f1cc0bd64818
(This used to be commit 8ed241532a069c4207945d5f1ceb1ec817ba7976)

source3/librpc/ndr/ndr.c

index 326ab12e9b7f4d1911793366adea62dfb4d33175..3ceb728a3f33b83340a9ee1cab68fea37789cc48 100644 (file)
@@ -713,7 +713,7 @@ NTSTATUS ndr_pull_struct_blob_all(const DATA_BLOB *blob, TALLOC_CTX *mem_ctx, vo
        if (ndr->offset < ndr->data_size) {
                return NT_STATUS_PORT_MESSAGE_TOO_LONG;
        }
-       return status;
+       return NT_STATUS_OK;
 }
 
 /*
@@ -721,6 +721,22 @@ NTSTATUS ndr_pull_struct_blob_all(const DATA_BLOB *blob, TALLOC_CTX *mem_ctx, vo
 */
 NTSTATUS ndr_pull_union_blob(const DATA_BLOB *blob, TALLOC_CTX *mem_ctx, void *p,
                             uint32_t level, ndr_pull_flags_fn_t fn)
+{
+       struct ndr_pull *ndr;
+       ndr = ndr_pull_init_blob(blob, mem_ctx);
+       if (!ndr) {
+               return NT_STATUS_NO_MEMORY;
+       }
+       ndr_pull_set_switch_value(ndr, p, level);
+       return fn(ndr, NDR_SCALARS|NDR_BUFFERS, p);
+}
+
+/*
+  pull a union from a blob using NDR, given the union discriminator,
+  failing if all bytes are not consumed
+*/
+_PUBLIC_ NTSTATUS ndr_pull_union_blob_all(const DATA_BLOB *blob, TALLOC_CTX *mem_ctx, void *p,
+                            uint32_t level, ndr_pull_flags_fn_t fn)
 {
        struct ndr_pull *ndr;
        NTSTATUS status;
@@ -732,10 +748,10 @@ NTSTATUS ndr_pull_union_blob(const DATA_BLOB *blob, TALLOC_CTX *mem_ctx, void *p
        ndr_pull_set_switch_value(ndr, p, level);
        status = fn(ndr, NDR_SCALARS|NDR_BUFFERS, p);
        if (!NT_STATUS_IS_OK(status)) return status;
-       if (ndr->offset != ndr->data_size) {
-               return NT_STATUS_BUFFER_TOO_SMALL;
+       if (ndr->offset < ndr->data_size) {
+               return NT_STATUS_PORT_MESSAGE_TOO_LONG;
        }
-       return status;
+       return NT_STATUS_OK;
 }
 
 /*