2 Unix SMB/CIFS implementation.
4 routines for marshalling/unmarshalling spoolss subcontext buffer structures
6 Copyright (C) Andrew Tridgell 2003
7 Copyright (C) Tim Potter 2003
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>.
25 #include "librpc/gen_ndr/ndr_spoolss.h"
26 #if (_SAMBA_BUILD_ >= 4)
27 #include "param/param.h"
30 #define NDR_SPOOLSS_PUSH_ENUM_IN(fn) do { \
31 if (!r->in.buffer && r->in.offered != 0) {\
32 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
33 "SPOOLSS Buffer: r->in.offered[%u] but there's no buffer",\
34 (unsigned)r->in.offered);\
35 } else if (r->in.buffer && r->in.buffer->length != r->in.offered) {\
36 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
37 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of r->in.buffer[%u]",\
38 (unsigned)r->in.offered, (unsigned)r->in.buffer->length);\
40 _r.in.level = r->in.level;\
41 _r.in.buffer = r->in.buffer;\
42 _r.in.offered = r->in.offered;\
43 NDR_CHECK(ndr_push__##fn(ndr, flags, &_r));\
46 #define NDR_SPOOLSS_PUSH_ENUM_OUT(fn) do { \
47 struct ndr_push *_ndr_info;\
48 _r.in.level = r->in.level;\
49 _r.in.buffer = r->in.buffer;\
50 _r.in.offered = r->in.offered;\
52 _r.out.needed = r->out.needed;\
53 _r.out.count = r->out.count;\
54 _r.out.result = r->out.result;\
55 if (r->out.info && !r->in.buffer) {\
56 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
57 "SPOOLSS Buffer: r->out.info but there's no r->in.buffer");\
60 DATA_BLOB _data_blob_info;\
61 _ndr_info = ndr_push_init_ctx(ndr, ndr->iconv_convenience);\
62 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);\
63 _ndr_info->flags= ndr->flags;\
66 __r.in.level = r->in.level;\
67 __r.in.count = r->out.count;\
68 __r.out.info = r->out.info;\
69 NDR_CHECK(ndr_push___##fn(_ndr_info, flags, &__r)); \
71 if (r->in.offered > _ndr_info->offset) {\
72 uint32_t _padding_len = r->in.offered - _ndr_info->offset;\
73 NDR_CHECK(ndr_push_zero(_ndr_info, _padding_len));\
74 } else if (r->in.offered < _ndr_info->offset) {\
75 return ndr_push_error(ndr, NDR_ERR_BUFSIZE,\
76 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of out buffer[%u]!",\
77 (unsigned)r->in.offered, (unsigned)_ndr_info->offset);\
79 _data_blob_info = ndr_push_blob(_ndr_info);\
80 _r.out.info = &_data_blob_info;\
82 NDR_CHECK(ndr_push__##fn(ndr, flags, &_r));\
85 #define NDR_SPOOLSS_PUSH_ENUM(fn,in,out) do { \
87 if (flags & NDR_IN) {\
89 NDR_SPOOLSS_PUSH_ENUM_IN(fn);\
91 if (flags & NDR_OUT) {\
93 NDR_SPOOLSS_PUSH_ENUM_OUT(fn);\
97 #define NDR_SPOOLSS_PULL_ENUM_IN(fn) do { \
99 NDR_CHECK(ndr_pull__##fn(ndr, flags, &_r));\
100 r->in.level = _r.in.level;\
101 r->in.buffer = _r.in.buffer;\
102 r->in.offered = _r.in.offered;\
103 r->out.needed = _r.out.needed;\
104 if (!r->in.buffer && r->in.offered != 0) {\
105 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,\
106 "SPOOLSS Buffer: r->in.offered[%u] but there's no buffer",\
107 (unsigned)r->in.offered);\
108 } else if (r->in.buffer && r->in.buffer->length != r->in.offered) {\
109 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,\
110 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of r->in.buffer[%u]",\
111 (unsigned)r->in.offered, (unsigned)r->in.buffer->length);\
115 #define NDR_SPOOLSS_PULL_ENUM_OUT(fn) do { \
116 _r.in.level = r->in.level;\
117 _r.in.buffer = r->in.buffer;\
118 _r.in.offered = r->in.offered;\
119 _r.out.needed = r->out.needed;\
120 NDR_CHECK(ndr_pull__##fn(ndr, flags, &_r));\
122 r->out.needed = _r.out.needed;\
123 r->out.count = _r.out.count;\
124 r->out.result = _r.out.result;\
126 struct ndr_pull *_ndr_info = ndr_pull_init_blob(_r.out.info, ndr, ndr->iconv_convenience);\
127 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);\
128 _ndr_info->flags= ndr->flags;\
129 if (r->in.offered != _ndr_info->data_size) {\
130 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,\
131 "SPOOLSS Buffer: offered[%u] doesn't match length of buffer[%u]",\
132 (unsigned)r->in.offered, (unsigned)_ndr_info->data_size);\
134 if (r->out.needed <= _ndr_info->data_size) {\
136 __r.in.level = r->in.level;\
137 __r.in.count = r->out.count;\
138 __r.out.info = NULL;\
139 NDR_CHECK(ndr_pull___##fn(_ndr_info, flags, &__r));\
140 r->out.info = __r.out.info;\
145 #define NDR_SPOOLSS_PULL_ENUM(fn,in,out) do { \
147 if (flags & NDR_IN) {\
149 NDR_SPOOLSS_PULL_ENUM_IN(fn);\
152 if (flags & NDR_OUT) {\
154 NDR_SPOOLSS_PULL_ENUM_OUT(fn);\
158 #define _NDR_CHECK_UINT32(call) do {\
159 enum ndr_err_code _ndr_err; \
161 if (!NDR_ERR_CODE_IS_SUCCESS(_ndr_err)) { \
166 /* TODO: set _ndr_info->flags correct */
167 #define NDR_SPOOLSS_SIZE_ENUM(fn) do { \
169 DATA_BLOB _data_blob_info;\
170 struct ndr_push *_ndr_info = ndr_push_init_ctx(mem_ctx, iconv_convenience);\
171 if (!_ndr_info) return 0;\
172 _ndr_info->flags|=0;\
173 __r.in.level = level;\
174 __r.in.count = count;\
175 __r.out.info = info;\
176 _NDR_CHECK_UINT32(ndr_push___##fn(_ndr_info, NDR_OUT, &__r)); \
177 _data_blob_info = ndr_push_blob(_ndr_info);\
178 return _data_blob_info.length;\
184 enum ndr_err_code ndr_push_spoolss_EnumPrinters(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinters *r)
186 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrinters,{
187 _r.in.flags = r->in.flags;
188 _r.in.server = r->in.server;
190 _r.in.flags = r->in.flags;
191 _r.in.server = r->in.server;
193 return NDR_ERR_SUCCESS;
196 enum ndr_err_code ndr_pull_spoolss_EnumPrinters(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinters *r)
198 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrinters,{
199 r->in.flags = _r.in.flags;
200 r->in.server = _r.in.server;
202 _r.in.flags = r->in.flags;
203 _r.in.server = r->in.server;
205 return NDR_ERR_SUCCESS;
208 uint32_t ndr_size_spoolss_EnumPrinters_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_PrinterInfo *info)
210 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrinters);
216 enum ndr_err_code ndr_push_spoolss_EnumJobs(struct ndr_push *ndr, int flags, const struct spoolss_EnumJobs *r)
218 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumJobs,{
219 _r.in.handle = r->in.handle;
220 _r.in.firstjob = r->in.firstjob;
221 _r.in.numjobs = r->in.numjobs;
223 _r.in.handle = r->in.handle;
224 _r.in.firstjob = r->in.firstjob;
225 _r.in.numjobs = r->in.numjobs;
227 return NDR_ERR_SUCCESS;
230 enum ndr_err_code ndr_pull_spoolss_EnumJobs(struct ndr_pull *ndr, int flags, struct spoolss_EnumJobs *r)
232 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumJobs,{
233 r->in.handle = _r.in.handle;
234 r->in.firstjob = _r.in.firstjob;
235 r->in.numjobs = _r.in.numjobs;
237 _r.in.handle = r->in.handle;
238 _r.in.firstjob = r->in.firstjob;
239 _r.in.numjobs = r->in.numjobs;
241 return NDR_ERR_SUCCESS;
244 uint32_t ndr_size_spoolss_EnumJobss_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_JobInfo *info)
246 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumJobs);
250 spoolss_EnumPrinterDrivers
252 enum ndr_err_code ndr_push_spoolss_EnumPrinterDrivers(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrinterDrivers *r)
254 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrinterDrivers,{
255 _r.in.server = r->in.server;
256 _r.in.environment = r->in.environment;
258 _r.in.server = r->in.server;
259 _r.in.environment = r->in.environment;
261 return NDR_ERR_SUCCESS;
264 enum ndr_err_code ndr_pull_spoolss_EnumPrinterDrivers(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrinterDrivers *r)
266 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrinterDrivers,{
267 r->in.server = _r.in.server;
268 r->in.environment = _r.in.environment;
270 _r.in.server = r->in.server;
271 _r.in.environment = r->in.environment;
273 return NDR_ERR_SUCCESS;
276 uint32_t ndr_size_spoolss_EnumPrinterDrivers_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_DriverInfo *info)
278 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrinterDrivers);
284 enum ndr_err_code ndr_push_spoolss_EnumForms(struct ndr_push *ndr, int flags, const struct spoolss_EnumForms *r)
286 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumForms,{
287 _r.in.handle = r->in.handle;
289 _r.in.handle = r->in.handle;
291 return NDR_ERR_SUCCESS;
294 enum ndr_err_code ndr_pull_spoolss_EnumForms(struct ndr_pull *ndr, int flags, struct spoolss_EnumForms *r)
296 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumForms,{
297 r->in.handle = _r.in.handle;
299 _r.in.handle = r->in.handle;
301 return NDR_ERR_SUCCESS;
304 uint32_t ndr_size_spoolss_EnumForms_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_FormInfo *info)
306 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumForms);
312 enum ndr_err_code ndr_push_spoolss_EnumPorts(struct ndr_push *ndr, int flags, const struct spoolss_EnumPorts *r)
314 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPorts,{
315 _r.in.servername= r->in.servername;
317 _r.in.servername= r->in.servername;
319 return NDR_ERR_SUCCESS;
322 enum ndr_err_code ndr_pull_spoolss_EnumPorts(struct ndr_pull *ndr, int flags, struct spoolss_EnumPorts *r)
324 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPorts,{
325 r->in.servername= _r.in.servername;
327 _r.in.servername= r->in.servername;
329 return NDR_ERR_SUCCESS;
332 uint32_t ndr_size_spoolss_EnumPorts_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_PortInfo *info)
334 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPorts);
340 enum ndr_err_code ndr_push_spoolss_EnumMonitors(struct ndr_push *ndr, int flags, const struct spoolss_EnumMonitors *r)
342 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumMonitors,{
343 _r.in.servername= r->in.servername;
345 _r.in.servername= r->in.servername;
347 return NDR_ERR_SUCCESS;
350 enum ndr_err_code ndr_pull_spoolss_EnumMonitors(struct ndr_pull *ndr, int flags, struct spoolss_EnumMonitors *r)
352 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumMonitors,{
353 r->in.servername= _r.in.servername;
355 _r.in.servername= r->in.servername;
357 return NDR_ERR_SUCCESS;
360 uint32_t ndr_size_spoolss_EnumMonitors_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience, uint32_t level, uint32_t count, union spoolss_MonitorInfo *info)
362 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumMonitors);
366 spoolss_EnumPrintProcessors
368 enum ndr_err_code ndr_push_spoolss_EnumPrintProcessors(struct ndr_push *ndr, int flags, const struct spoolss_EnumPrintProcessors *r)
370 NDR_SPOOLSS_PUSH_ENUM(spoolss_EnumPrintProcessors,{
371 _r.in.servername = r->in.servername;
372 _r.in.environment = r->in.environment;
374 _r.in.servername = r->in.servername;
375 _r.in.environment = r->in.environment;
377 return NDR_ERR_SUCCESS;
380 enum ndr_err_code ndr_pull_spoolss_EnumPrintProcessors(struct ndr_pull *ndr, int flags, struct spoolss_EnumPrintProcessors *r)
382 NDR_SPOOLSS_PULL_ENUM(spoolss_EnumPrintProcessors,{
383 r->in.servername = _r.in.servername;
384 r->in.environment = _r.in.environment;
386 _r.in.servername = r->in.servername;
387 _r.in.environment = r->in.environment;
389 return NDR_ERR_SUCCESS;
392 uint32_t ndr_size_spoolss_EnumPrinterProcessors_info(TALLOC_CTX *mem_ctx, struct smb_iconv_convenience *iconv_convenience,
393 uint32_t level, uint32_t count, union spoolss_PrintProcessorInfo *info)
395 NDR_SPOOLSS_SIZE_ENUM(spoolss_EnumPrintProcessors);
399 spoolss_GetPrinterData
401 enum ndr_err_code ndr_push_spoolss_GetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_GetPrinterData *r)
403 struct _spoolss_GetPrinterData _r;
404 if (flags & NDR_IN) {
405 _r.in.handle = r->in.handle;
406 _r.in.value_name= r->in.value_name;
407 _r.in.offered = r->in.offered;
408 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
410 if (flags & NDR_OUT) {
411 struct ndr_push *_ndr_info;
412 _r.in.handle = r->in.handle;
413 _r.in.value_name= r->in.value_name;
414 _r.in.offered = r->in.offered;
415 _r.out.type = r->out.type;
416 _r.out.data = data_blob(NULL, 0);
417 _r.out.needed = r->out.needed;
418 _r.out.result = r->out.result;
420 struct __spoolss_GetPrinterData __r;
421 _ndr_info = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
422 NDR_ERR_HAVE_NO_MEMORY(_ndr_info);
423 _ndr_info->flags= ndr->flags;
424 __r.in.type = r->out.type;
425 __r.out.data = r->out.data;
426 NDR_CHECK(ndr_push___spoolss_GetPrinterData(_ndr_info, flags, &__r));
427 if (r->in.offered > _ndr_info->offset) {
428 uint32_t _padding_len = r->in.offered - _ndr_info->offset;
429 NDR_CHECK(ndr_push_zero(_ndr_info, _padding_len));
431 _r.out.data = ndr_push_blob(_ndr_info);
433 NDR_CHECK(ndr_push__spoolss_GetPrinterData(ndr, flags, &_r));
435 return NDR_ERR_SUCCESS;
438 enum ndr_err_code ndr_pull_spoolss_GetPrinterData(struct ndr_pull *ndr, int flags, struct spoolss_GetPrinterData *r)
440 struct _spoolss_GetPrinterData _r;
441 if (flags & NDR_IN) {
444 _r.in.handle = r->in.handle;
445 _r.in.value_name= r->in.value_name;
446 _r.in.offered = r->in.offered;
447 _r.out.type = r->out.type;
448 _r.out.data = data_blob(NULL,0),
449 _r.out.needed = r->out.needed;
450 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
451 r->in.handle = _r.in.handle;
452 r->in.value_name= _r.in.value_name;
453 r->in.offered = _r.in.offered;
454 r->out.needed = _r.out.needed;
456 if (flags & NDR_OUT) {
457 _r.in.handle = r->in.handle;
458 _r.in.value_name= r->in.value_name;
459 _r.in.offered = r->in.offered;
460 _r.out.type = r->out.type;
461 _r.out.data = data_blob(NULL,0),
462 _r.out.needed = r->out.needed;
463 _r.out.result = r->out.result;
464 NDR_CHECK(ndr_pull__spoolss_GetPrinterData(ndr, flags, &_r));
465 r->out.type = _r.out.type;
466 ZERO_STRUCT(r->out.data);
467 r->out.needed = _r.out.needed;
468 r->out.result = _r.out.result;
469 if (_r.out.data.length != r->in.offered) {
470 return ndr_pull_error(ndr, NDR_ERR_BUFSIZE,
471 "SPOOLSS Buffer: r->in.offered[%u] doesn't match length of out buffer[%u]",
472 (unsigned)r->in.offered, (unsigned)_r.out.data.length);
474 if (_r.out.data.length > 0 && r->out.needed <= _r.out.data.length) {
475 struct __spoolss_GetPrinterData __r;
476 struct ndr_pull *_ndr_data = ndr_pull_init_blob(&_r.out.data, ndr, ndr->iconv_convenience);
477 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
478 _ndr_data->flags= ndr->flags;
479 __r.in.type = r->out.type;
480 __r.out.data = r->out.data;
481 NDR_CHECK(ndr_pull___spoolss_GetPrinterData(_ndr_data, flags, &__r));
482 r->out.data = __r.out.data;
484 r->out.type = SPOOLSS_PRINTER_DATA_TYPE_NULL;
487 return NDR_ERR_SUCCESS;
491 spoolss_SetPrinterData
493 enum ndr_err_code ndr_push_spoolss_SetPrinterData(struct ndr_push *ndr, int flags, const struct spoolss_SetPrinterData *r)
495 struct _spoolss_SetPrinterData _r;
496 if (flags & NDR_IN) {
497 struct ndr_push *_ndr_data;
498 struct __spoolss_SetPrinterData __r;
499 DATA_BLOB _data_blob_data;
501 _ndr_data = ndr_push_init_ctx(ndr, ndr->iconv_convenience);
502 NDR_ERR_HAVE_NO_MEMORY(_ndr_data);
503 _ndr_data->flags= ndr->flags;
505 __r.in.type = r->in.type;
506 __r.out.data = r->in.data;
507 NDR_CHECK(ndr_push___spoolss_SetPrinterData(_ndr_data, NDR_OUT, &__r));
508 _data_blob_data = ndr_push_blob(_ndr_data);
510 _r.in.handle = r->in.handle;
511 _r.in.value_name= r->in.value_name;
512 _r.in.type = r->in.type;
513 _r.in.data = _data_blob_data;
514 _r.in._offered = _data_blob_data.length;
515 _r.out.result = r->out.result;
516 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
518 if (flags & NDR_OUT) {
519 _r.in.handle = r->in.handle;
520 _r.in.value_name= r->in.value_name;
521 _r.in.type = r->in.type;
522 _r.in.data = data_blob(NULL,0),
523 _r.in._offered = r->in._offered;
524 _r.out.result = r->out.result;
525 NDR_CHECK(ndr_push__spoolss_SetPrinterData(ndr, flags, &_r));
527 return NDR_ERR_SUCCESS;
530 uint32_t _ndr_size_spoolss_DeviceMode(struct spoolss_DeviceMode *devmode, struct smb_iconv_convenience *ic, uint32_t flags)
532 if (!devmode) return 0;
533 return ndr_size_spoolss_DeviceMode(devmode,ic,flags);