pidl/NDR/Parser: do array range validation in ParseArrayPullGetLength()
[Samba.git] / source3 / rpc_client / ndr.c
blob6c40f09ab8f1840a3ae4dc38de9758d4153457b1
1 /*
2 Unix SMB/CIFS implementation.
4 libndr interface
6 Copyright (C) Jelmer Vernooij 2006
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #include "includes.h"
25 NTSTATUS cli_do_rpc_ndr(struct rpc_pipe_client *cli,
26 TALLOC_CTX *mem_ctx,
27 const struct ndr_interface_table *table,
28 uint32_t opnum, void *r)
30 prs_struct q_ps, r_ps;
31 const struct ndr_interface_call *call;
32 struct ndr_pull *pull;
33 DATA_BLOB blob;
34 struct ndr_push *push;
35 NTSTATUS status;
36 enum ndr_err_code ndr_err;
38 SMB_ASSERT(ndr_syntax_id_equal(&table->syntax_id,
39 &cli->abstract_syntax));
40 SMB_ASSERT(table->num_calls > opnum);
42 call = &table->calls[opnum];
44 push = ndr_push_init_ctx(mem_ctx, NULL);
45 if (!push) {
46 return NT_STATUS_NO_MEMORY;
49 ndr_err = call->ndr_push(push, NDR_IN, r);
50 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
51 return ndr_map_error2ntstatus(ndr_err);
54 blob = ndr_push_blob(push);
56 if (!prs_init_data_blob(&q_ps, &blob, mem_ctx)) {
57 return NT_STATUS_NO_MEMORY;
60 talloc_free(push);
62 status = rpc_api_pipe_req(mem_ctx, cli, opnum, &q_ps, &r_ps);
64 prs_mem_free( &q_ps );
66 if (!NT_STATUS_IS_OK(status)) {
67 prs_mem_free( &r_ps );
68 return status;
71 if (!prs_data_blob(&r_ps, &blob, mem_ctx)) {
72 prs_mem_free( &r_ps );
73 return NT_STATUS_NO_MEMORY;
76 prs_mem_free( &r_ps );
78 pull = ndr_pull_init_blob(&blob, mem_ctx, NULL);
79 if (pull == NULL) {
80 return NT_STATUS_NO_MEMORY;
83 /* have the ndr parser alloc memory for us */
84 pull->flags |= LIBNDR_FLAG_REF_ALLOC;
85 ndr_err = call->ndr_pull(pull, NDR_OUT, r);
86 talloc_free(pull);
88 if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
89 return ndr_map_error2ntstatus(ndr_err);
92 return NT_STATUS_OK;