Line data Source code
1 : /* s3 compat server functions auto-generated by pidl */
2 : #include "bin/default/librpc/gen_ndr/ndr_spoolss.h"
3 : #include "bin/default/librpc/gen_ndr/ndr_spoolss_scompat.h"
4 : #include <librpc/rpc/dcesrv_core.h>
5 : #include <rpc_server/rpc_config.h>
6 : #include <rpc_server/rpc_server.h>
7 : #include <util/debug.h>
8 :
9 : enum s3compat_rpc_dispatch {
10 : S3COMPAT_RPC_DISPATCH_EXTERNAL = 0x00000001,
11 : S3COMPAT_RPC_DISPATCH_INTERNAL = 0x00000002,
12 : };
13 :
14 : /* spoolss - dcerpc server boilerplate generated by pidl */
15 2 : static NTSTATUS spoolss__op_bind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
16 : {
17 : #ifdef DCESRV_INTERFACE_SPOOLSS_BIND
18 : return DCESRV_INTERFACE_SPOOLSS_BIND(context,iface);
19 : #else
20 2 : return NT_STATUS_OK;
21 : #endif
22 : }
23 :
24 2 : static void spoolss__op_unbind(struct dcesrv_connection_context *context, const struct dcesrv_interface *iface)
25 : {
26 : #ifdef DCESRV_INTERFACE_SPOOLSS_UNBIND
27 : DCESRV_INTERFACE_SPOOLSS_UNBIND(context, iface);
28 : #else
29 2 : return;
30 : #endif
31 : }
32 :
33 10 : NTSTATUS spoolss__op_ndr_pull(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_pull *pull, void **r)
34 : {
35 : enum ndr_err_code ndr_err;
36 10 : uint16_t opnum = dce_call->pkt.u.request.opnum;
37 :
38 10 : dce_call->fault_code = 0;
39 :
40 10 : if (opnum >= ndr_table_spoolss.num_calls) {
41 0 : dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
42 0 : return NT_STATUS_NET_WRITE_FAULT;
43 : }
44 :
45 10 : *r = talloc_named(mem_ctx, ndr_table_spoolss.calls[opnum].struct_size, "struct %s", ndr_table_spoolss.calls[opnum].name);
46 10 : NT_STATUS_HAVE_NO_MEMORY(*r);
47 :
48 : /* unravel the NDR for the packet */
49 10 : ndr_err = ndr_table_spoolss.calls[opnum].ndr_pull(pull, NDR_IN, *r);
50 10 : if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
51 0 : dce_call->fault_code = DCERPC_FAULT_NDR;
52 0 : return NT_STATUS_NET_WRITE_FAULT;
53 : }
54 :
55 10 : return NT_STATUS_OK;
56 : }
57 :
58 10 : static NTSTATUS spoolss__op_dispatch_internal(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r, enum s3compat_rpc_dispatch dispatch)
59 : {
60 10 : uint16_t opnum = dce_call->pkt.u.request.opnum;
61 10 : struct pipes_struct *p = NULL;
62 10 : NTSTATUS status = NT_STATUS_OK;
63 10 : bool impersonated = false;
64 :
65 : /* Retrieve pipes struct */
66 10 : p = dcesrv_get_pipes_struct(dce_call->conn);
67 10 : p->dce_call = dce_call;
68 10 : p->mem_ctx = mem_ctx;
69 : /* Reset pipes struct fault state */
70 10 : p->fault_state = 0;
71 :
72 : /* Impersonate */
73 10 : if (dispatch == S3COMPAT_RPC_DISPATCH_EXTERNAL) {
74 10 : impersonated = become_authenticated_pipe_user(dce_call->auth_state->session_info);
75 10 : if (!impersonated) {
76 0 : dce_call->fault_code = DCERPC_FAULT_ACCESS_DENIED;
77 0 : status = NT_STATUS_NET_WRITE_FAULT;
78 0 : goto fail;
79 : }
80 : }
81 :
82 10 : switch (opnum) {
83 0 : case 0: { /* spoolss_EnumPrinters */
84 0 : struct spoolss_EnumPrinters *r2 = (struct spoolss_EnumPrinters *)r;
85 0 : if (DEBUGLEVEL >= 10) {
86 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinters, NDR_IN, r2);
87 : }
88 0 : NDR_ZERO_STRUCT(r2->out);
89 0 : r2->out.count = talloc_zero(r2, uint32_t);
90 0 : if (r2->out.count == NULL) {
91 0 : status = NT_STATUS_NO_MEMORY;
92 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
93 0 : goto fail;
94 : }
95 :
96 0 : r2->out.info = talloc_zero(r2, union spoolss_PrinterInfo *);
97 0 : if (r2->out.info == NULL) {
98 0 : status = NT_STATUS_NO_MEMORY;
99 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
100 0 : goto fail;
101 : }
102 :
103 0 : r2->out.needed = talloc_zero(r2, uint32_t);
104 0 : if (r2->out.needed == NULL) {
105 0 : status = NT_STATUS_NO_MEMORY;
106 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
107 0 : goto fail;
108 : }
109 :
110 0 : r2->out.result = _spoolss_EnumPrinters(p, r2);
111 0 : break;
112 : }
113 2 : case 1: { /* spoolss_OpenPrinter */
114 2 : struct spoolss_OpenPrinter *r2 = (struct spoolss_OpenPrinter *)r;
115 2 : if (DEBUGLEVEL >= 10) {
116 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_OpenPrinter, NDR_IN, r2);
117 : }
118 2 : NDR_ZERO_STRUCT(r2->out);
119 2 : r2->out.handle = talloc_zero(r2, struct policy_handle);
120 2 : if (r2->out.handle == NULL) {
121 0 : status = NT_STATUS_NO_MEMORY;
122 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
123 0 : goto fail;
124 : }
125 :
126 2 : r2->out.result = _spoolss_OpenPrinter(p, r2);
127 2 : break;
128 : }
129 0 : case 2: { /* spoolss_SetJob */
130 0 : struct spoolss_SetJob *r2 = (struct spoolss_SetJob *)r;
131 0 : if (DEBUGLEVEL >= 10) {
132 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetJob, NDR_IN, r2);
133 : }
134 0 : r2->out.result = _spoolss_SetJob(p, r2);
135 0 : break;
136 : }
137 0 : case 3: { /* spoolss_GetJob */
138 0 : struct spoolss_GetJob *r2 = (struct spoolss_GetJob *)r;
139 0 : if (DEBUGLEVEL >= 10) {
140 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetJob, NDR_IN, r2);
141 : }
142 0 : NDR_ZERO_STRUCT(r2->out);
143 0 : r2->out.info = talloc_zero(r2, union spoolss_JobInfo);
144 0 : if (r2->out.info == NULL) {
145 0 : status = NT_STATUS_NO_MEMORY;
146 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
147 0 : goto fail;
148 : }
149 :
150 0 : r2->out.needed = talloc_zero(r2, uint32_t);
151 0 : if (r2->out.needed == NULL) {
152 0 : status = NT_STATUS_NO_MEMORY;
153 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
154 0 : goto fail;
155 : }
156 :
157 0 : r2->out.result = _spoolss_GetJob(p, r2);
158 0 : break;
159 : }
160 0 : case 4: { /* spoolss_EnumJobs */
161 0 : struct spoolss_EnumJobs *r2 = (struct spoolss_EnumJobs *)r;
162 0 : if (DEBUGLEVEL >= 10) {
163 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumJobs, NDR_IN, r2);
164 : }
165 0 : NDR_ZERO_STRUCT(r2->out);
166 0 : r2->out.count = talloc_zero(r2, uint32_t);
167 0 : if (r2->out.count == NULL) {
168 0 : status = NT_STATUS_NO_MEMORY;
169 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
170 0 : goto fail;
171 : }
172 :
173 0 : r2->out.info = talloc_zero(r2, union spoolss_JobInfo *);
174 0 : if (r2->out.info == NULL) {
175 0 : status = NT_STATUS_NO_MEMORY;
176 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
177 0 : goto fail;
178 : }
179 :
180 0 : r2->out.needed = talloc_zero(r2, uint32_t);
181 0 : if (r2->out.needed == NULL) {
182 0 : status = NT_STATUS_NO_MEMORY;
183 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
184 0 : goto fail;
185 : }
186 :
187 0 : r2->out.result = _spoolss_EnumJobs(p, r2);
188 0 : break;
189 : }
190 0 : case 5: { /* spoolss_AddPrinter */
191 0 : struct spoolss_AddPrinter *r2 = (struct spoolss_AddPrinter *)r;
192 0 : if (DEBUGLEVEL >= 10) {
193 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinter, NDR_IN, r2);
194 : }
195 0 : NDR_ZERO_STRUCT(r2->out);
196 0 : r2->out.handle = talloc_zero(r2, struct policy_handle);
197 0 : if (r2->out.handle == NULL) {
198 0 : status = NT_STATUS_NO_MEMORY;
199 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
200 0 : goto fail;
201 : }
202 :
203 0 : r2->out.result = _spoolss_AddPrinter(p, r2);
204 0 : break;
205 : }
206 0 : case 6: { /* spoolss_DeletePrinter */
207 0 : struct spoolss_DeletePrinter *r2 = (struct spoolss_DeletePrinter *)r;
208 0 : if (DEBUGLEVEL >= 10) {
209 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinter, NDR_IN, r2);
210 : }
211 0 : r2->out.result = _spoolss_DeletePrinter(p, r2);
212 0 : break;
213 : }
214 0 : case 7: { /* spoolss_SetPrinter */
215 0 : struct spoolss_SetPrinter *r2 = (struct spoolss_SetPrinter *)r;
216 0 : if (DEBUGLEVEL >= 10) {
217 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPrinter, NDR_IN, r2);
218 : }
219 0 : r2->out.result = _spoolss_SetPrinter(p, r2);
220 0 : break;
221 : }
222 0 : case 8: { /* spoolss_GetPrinter */
223 0 : struct spoolss_GetPrinter *r2 = (struct spoolss_GetPrinter *)r;
224 0 : if (DEBUGLEVEL >= 10) {
225 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinter, NDR_IN, r2);
226 : }
227 0 : NDR_ZERO_STRUCT(r2->out);
228 0 : r2->out.info = talloc_zero(r2, union spoolss_PrinterInfo);
229 0 : if (r2->out.info == NULL) {
230 0 : status = NT_STATUS_NO_MEMORY;
231 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
232 0 : goto fail;
233 : }
234 :
235 0 : r2->out.needed = talloc_zero(r2, uint32_t);
236 0 : if (r2->out.needed == NULL) {
237 0 : status = NT_STATUS_NO_MEMORY;
238 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
239 0 : goto fail;
240 : }
241 :
242 0 : r2->out.result = _spoolss_GetPrinter(p, r2);
243 0 : break;
244 : }
245 0 : case 9: { /* spoolss_AddPrinterDriver */
246 0 : struct spoolss_AddPrinterDriver *r2 = (struct spoolss_AddPrinterDriver *)r;
247 0 : if (DEBUGLEVEL >= 10) {
248 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterDriver, NDR_IN, r2);
249 : }
250 0 : r2->out.result = _spoolss_AddPrinterDriver(p, r2);
251 0 : break;
252 : }
253 0 : case 10: { /* spoolss_EnumPrinterDrivers */
254 0 : struct spoolss_EnumPrinterDrivers *r2 = (struct spoolss_EnumPrinterDrivers *)r;
255 0 : if (DEBUGLEVEL >= 10) {
256 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterDrivers, NDR_IN, r2);
257 : }
258 0 : NDR_ZERO_STRUCT(r2->out);
259 0 : r2->out.count = talloc_zero(r2, uint32_t);
260 0 : if (r2->out.count == NULL) {
261 0 : status = NT_STATUS_NO_MEMORY;
262 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
263 0 : goto fail;
264 : }
265 :
266 0 : r2->out.info = talloc_zero(r2, union spoolss_DriverInfo *);
267 0 : if (r2->out.info == NULL) {
268 0 : status = NT_STATUS_NO_MEMORY;
269 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
270 0 : goto fail;
271 : }
272 :
273 0 : r2->out.needed = talloc_zero(r2, uint32_t);
274 0 : if (r2->out.needed == NULL) {
275 0 : status = NT_STATUS_NO_MEMORY;
276 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
277 0 : goto fail;
278 : }
279 :
280 0 : r2->out.result = _spoolss_EnumPrinterDrivers(p, r2);
281 0 : break;
282 : }
283 0 : case 11: { /* spoolss_GetPrinterDriver */
284 0 : struct spoolss_GetPrinterDriver *r2 = (struct spoolss_GetPrinterDriver *)r;
285 0 : if (DEBUGLEVEL >= 10) {
286 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriver, NDR_IN, r2);
287 : }
288 0 : NDR_ZERO_STRUCT(r2->out);
289 0 : r2->out.info = talloc_zero(r2, union spoolss_DriverInfo);
290 0 : if (r2->out.info == NULL) {
291 0 : status = NT_STATUS_NO_MEMORY;
292 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
293 0 : goto fail;
294 : }
295 :
296 0 : r2->out.needed = talloc_zero(r2, uint32_t);
297 0 : if (r2->out.needed == NULL) {
298 0 : status = NT_STATUS_NO_MEMORY;
299 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
300 0 : goto fail;
301 : }
302 :
303 0 : r2->out.result = _spoolss_GetPrinterDriver(p, r2);
304 0 : break;
305 : }
306 0 : case 12: { /* spoolss_GetPrinterDriverDirectory */
307 0 : struct spoolss_GetPrinterDriverDirectory *r2 = (struct spoolss_GetPrinterDriverDirectory *)r;
308 0 : if (DEBUGLEVEL >= 10) {
309 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriverDirectory, NDR_IN, r2);
310 : }
311 0 : NDR_ZERO_STRUCT(r2->out);
312 0 : r2->out.info = talloc_zero(r2, union spoolss_DriverDirectoryInfo);
313 0 : if (r2->out.info == NULL) {
314 0 : status = NT_STATUS_NO_MEMORY;
315 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
316 0 : goto fail;
317 : }
318 :
319 0 : r2->out.needed = talloc_zero(r2, uint32_t);
320 0 : if (r2->out.needed == NULL) {
321 0 : status = NT_STATUS_NO_MEMORY;
322 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
323 0 : goto fail;
324 : }
325 :
326 0 : r2->out.result = _spoolss_GetPrinterDriverDirectory(p, r2);
327 0 : break;
328 : }
329 0 : case 13: { /* spoolss_DeletePrinterDriver */
330 0 : struct spoolss_DeletePrinterDriver *r2 = (struct spoolss_DeletePrinterDriver *)r;
331 0 : if (DEBUGLEVEL >= 10) {
332 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterDriver, NDR_IN, r2);
333 : }
334 0 : r2->out.result = _spoolss_DeletePrinterDriver(p, r2);
335 0 : break;
336 : }
337 0 : case 14: { /* spoolss_AddPrintProcessor */
338 0 : struct spoolss_AddPrintProcessor *r2 = (struct spoolss_AddPrintProcessor *)r;
339 0 : if (DEBUGLEVEL >= 10) {
340 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrintProcessor, NDR_IN, r2);
341 : }
342 0 : r2->out.result = _spoolss_AddPrintProcessor(p, r2);
343 0 : break;
344 : }
345 0 : case 15: { /* spoolss_EnumPrintProcessors */
346 0 : struct spoolss_EnumPrintProcessors *r2 = (struct spoolss_EnumPrintProcessors *)r;
347 0 : if (DEBUGLEVEL >= 10) {
348 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrintProcessors, NDR_IN, r2);
349 : }
350 0 : NDR_ZERO_STRUCT(r2->out);
351 0 : r2->out.count = talloc_zero(r2, uint32_t);
352 0 : if (r2->out.count == NULL) {
353 0 : status = NT_STATUS_NO_MEMORY;
354 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
355 0 : goto fail;
356 : }
357 :
358 0 : r2->out.info = talloc_zero(r2, union spoolss_PrintProcessorInfo *);
359 0 : if (r2->out.info == NULL) {
360 0 : status = NT_STATUS_NO_MEMORY;
361 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
362 0 : goto fail;
363 : }
364 :
365 0 : r2->out.needed = talloc_zero(r2, uint32_t);
366 0 : if (r2->out.needed == NULL) {
367 0 : status = NT_STATUS_NO_MEMORY;
368 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
369 0 : goto fail;
370 : }
371 :
372 0 : r2->out.result = _spoolss_EnumPrintProcessors(p, r2);
373 0 : break;
374 : }
375 0 : case 16: { /* spoolss_GetPrintProcessorDirectory */
376 0 : struct spoolss_GetPrintProcessorDirectory *r2 = (struct spoolss_GetPrintProcessorDirectory *)r;
377 0 : if (DEBUGLEVEL >= 10) {
378 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrintProcessorDirectory, NDR_IN, r2);
379 : }
380 0 : NDR_ZERO_STRUCT(r2->out);
381 0 : r2->out.info = talloc_zero(r2, union spoolss_PrintProcessorDirectoryInfo);
382 0 : if (r2->out.info == NULL) {
383 0 : status = NT_STATUS_NO_MEMORY;
384 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
385 0 : goto fail;
386 : }
387 :
388 0 : r2->out.needed = talloc_zero(r2, uint32_t);
389 0 : if (r2->out.needed == NULL) {
390 0 : status = NT_STATUS_NO_MEMORY;
391 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
392 0 : goto fail;
393 : }
394 :
395 0 : r2->out.result = _spoolss_GetPrintProcessorDirectory(p, r2);
396 0 : break;
397 : }
398 0 : case 17: { /* spoolss_StartDocPrinter */
399 0 : struct spoolss_StartDocPrinter *r2 = (struct spoolss_StartDocPrinter *)r;
400 0 : if (DEBUGLEVEL >= 10) {
401 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_StartDocPrinter, NDR_IN, r2);
402 : }
403 0 : NDR_ZERO_STRUCT(r2->out);
404 0 : r2->out.job_id = talloc_zero(r2, uint32_t);
405 0 : if (r2->out.job_id == NULL) {
406 0 : status = NT_STATUS_NO_MEMORY;
407 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
408 0 : goto fail;
409 : }
410 :
411 0 : r2->out.result = _spoolss_StartDocPrinter(p, r2);
412 0 : break;
413 : }
414 0 : case 18: { /* spoolss_StartPagePrinter */
415 0 : struct spoolss_StartPagePrinter *r2 = (struct spoolss_StartPagePrinter *)r;
416 0 : if (DEBUGLEVEL >= 10) {
417 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_StartPagePrinter, NDR_IN, r2);
418 : }
419 0 : r2->out.result = _spoolss_StartPagePrinter(p, r2);
420 0 : break;
421 : }
422 0 : case 19: { /* spoolss_WritePrinter */
423 0 : struct spoolss_WritePrinter *r2 = (struct spoolss_WritePrinter *)r;
424 0 : if (DEBUGLEVEL >= 10) {
425 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_WritePrinter, NDR_IN, r2);
426 : }
427 0 : NDR_ZERO_STRUCT(r2->out);
428 0 : r2->out.num_written = talloc_zero(r2, uint32_t);
429 0 : if (r2->out.num_written == NULL) {
430 0 : status = NT_STATUS_NO_MEMORY;
431 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
432 0 : goto fail;
433 : }
434 :
435 0 : r2->out.result = _spoolss_WritePrinter(p, r2);
436 0 : break;
437 : }
438 0 : case 20: { /* spoolss_EndPagePrinter */
439 0 : struct spoolss_EndPagePrinter *r2 = (struct spoolss_EndPagePrinter *)r;
440 0 : if (DEBUGLEVEL >= 10) {
441 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EndPagePrinter, NDR_IN, r2);
442 : }
443 0 : r2->out.result = _spoolss_EndPagePrinter(p, r2);
444 0 : break;
445 : }
446 0 : case 21: { /* spoolss_AbortPrinter */
447 0 : struct spoolss_AbortPrinter *r2 = (struct spoolss_AbortPrinter *)r;
448 0 : if (DEBUGLEVEL >= 10) {
449 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AbortPrinter, NDR_IN, r2);
450 : }
451 0 : r2->out.result = _spoolss_AbortPrinter(p, r2);
452 0 : break;
453 : }
454 0 : case 22: { /* spoolss_ReadPrinter */
455 0 : struct spoolss_ReadPrinter *r2 = (struct spoolss_ReadPrinter *)r;
456 0 : if (DEBUGLEVEL >= 10) {
457 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ReadPrinter, NDR_IN, r2);
458 : }
459 0 : NDR_ZERO_STRUCT(r2->out);
460 0 : r2->out.data = talloc_zero_array(r2, uint8_t, r2->in.data_size);
461 0 : if (r2->out.data == NULL) {
462 0 : status = NT_STATUS_NO_MEMORY;
463 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
464 0 : goto fail;
465 : }
466 :
467 0 : r2->out._data_size = talloc_zero(r2, uint32_t);
468 0 : if (r2->out._data_size == NULL) {
469 0 : status = NT_STATUS_NO_MEMORY;
470 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
471 0 : goto fail;
472 : }
473 :
474 0 : r2->out.result = _spoolss_ReadPrinter(p, r2);
475 0 : break;
476 : }
477 0 : case 23: { /* spoolss_EndDocPrinter */
478 0 : struct spoolss_EndDocPrinter *r2 = (struct spoolss_EndDocPrinter *)r;
479 0 : if (DEBUGLEVEL >= 10) {
480 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EndDocPrinter, NDR_IN, r2);
481 : }
482 0 : r2->out.result = _spoolss_EndDocPrinter(p, r2);
483 0 : break;
484 : }
485 0 : case 24: { /* spoolss_AddJob */
486 0 : struct spoolss_AddJob *r2 = (struct spoolss_AddJob *)r;
487 0 : if (DEBUGLEVEL >= 10) {
488 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddJob, NDR_IN, r2);
489 : }
490 0 : NDR_ZERO_STRUCT(r2->out);
491 0 : r2->out.buffer = r2->in.buffer;
492 0 : r2->out.needed = talloc_zero(r2, uint32_t);
493 0 : if (r2->out.needed == NULL) {
494 0 : status = NT_STATUS_NO_MEMORY;
495 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
496 0 : goto fail;
497 : }
498 :
499 0 : r2->out.result = _spoolss_AddJob(p, r2);
500 0 : break;
501 : }
502 0 : case 25: { /* spoolss_ScheduleJob */
503 0 : struct spoolss_ScheduleJob *r2 = (struct spoolss_ScheduleJob *)r;
504 0 : if (DEBUGLEVEL >= 10) {
505 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ScheduleJob, NDR_IN, r2);
506 : }
507 0 : r2->out.result = _spoolss_ScheduleJob(p, r2);
508 0 : break;
509 : }
510 0 : case 26: { /* spoolss_GetPrinterData */
511 0 : struct spoolss_GetPrinterData *r2 = (struct spoolss_GetPrinterData *)r;
512 0 : if (DEBUGLEVEL >= 10) {
513 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterData, NDR_IN, r2);
514 : }
515 0 : NDR_ZERO_STRUCT(r2->out);
516 0 : r2->out.type = talloc_zero(r2, enum winreg_Type);
517 0 : if (r2->out.type == NULL) {
518 0 : status = NT_STATUS_NO_MEMORY;
519 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
520 0 : goto fail;
521 : }
522 :
523 0 : r2->out.data = talloc_zero_array(r2, uint8_t, r2->in.offered);
524 0 : if (r2->out.data == NULL) {
525 0 : status = NT_STATUS_NO_MEMORY;
526 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
527 0 : goto fail;
528 : }
529 :
530 0 : r2->out.needed = talloc_zero(r2, uint32_t);
531 0 : if (r2->out.needed == NULL) {
532 0 : status = NT_STATUS_NO_MEMORY;
533 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
534 0 : goto fail;
535 : }
536 :
537 0 : r2->out.result = _spoolss_GetPrinterData(p, r2);
538 0 : break;
539 : }
540 0 : case 27: { /* spoolss_SetPrinterData */
541 0 : struct spoolss_SetPrinterData *r2 = (struct spoolss_SetPrinterData *)r;
542 0 : if (DEBUGLEVEL >= 10) {
543 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPrinterData, NDR_IN, r2);
544 : }
545 0 : r2->out.result = _spoolss_SetPrinterData(p, r2);
546 0 : break;
547 : }
548 0 : case 28: { /* spoolss_WaitForPrinterChange */
549 0 : struct spoolss_WaitForPrinterChange *r2 = (struct spoolss_WaitForPrinterChange *)r;
550 0 : if (DEBUGLEVEL >= 10) {
551 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_WaitForPrinterChange, NDR_IN, r2);
552 : }
553 0 : r2->out.result = _spoolss_WaitForPrinterChange(p, r2);
554 0 : break;
555 : }
556 2 : case 29: { /* spoolss_ClosePrinter */
557 2 : struct spoolss_ClosePrinter *r2 = (struct spoolss_ClosePrinter *)r;
558 2 : if (DEBUGLEVEL >= 10) {
559 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ClosePrinter, NDR_IN, r2);
560 : }
561 2 : NDR_ZERO_STRUCT(r2->out);
562 2 : r2->out.handle = r2->in.handle;
563 2 : r2->out.result = _spoolss_ClosePrinter(p, r2);
564 2 : break;
565 : }
566 0 : case 30: { /* spoolss_AddForm */
567 0 : struct spoolss_AddForm *r2 = (struct spoolss_AddForm *)r;
568 0 : if (DEBUGLEVEL >= 10) {
569 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddForm, NDR_IN, r2);
570 : }
571 0 : r2->out.result = _spoolss_AddForm(p, r2);
572 0 : break;
573 : }
574 0 : case 31: { /* spoolss_DeleteForm */
575 0 : struct spoolss_DeleteForm *r2 = (struct spoolss_DeleteForm *)r;
576 0 : if (DEBUGLEVEL >= 10) {
577 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeleteForm, NDR_IN, r2);
578 : }
579 0 : r2->out.result = _spoolss_DeleteForm(p, r2);
580 0 : break;
581 : }
582 0 : case 32: { /* spoolss_GetForm */
583 0 : struct spoolss_GetForm *r2 = (struct spoolss_GetForm *)r;
584 0 : if (DEBUGLEVEL >= 10) {
585 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetForm, NDR_IN, r2);
586 : }
587 0 : NDR_ZERO_STRUCT(r2->out);
588 0 : r2->out.info = talloc_zero(r2, union spoolss_FormInfo);
589 0 : if (r2->out.info == NULL) {
590 0 : status = NT_STATUS_NO_MEMORY;
591 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
592 0 : goto fail;
593 : }
594 :
595 0 : r2->out.needed = talloc_zero(r2, uint32_t);
596 0 : if (r2->out.needed == NULL) {
597 0 : status = NT_STATUS_NO_MEMORY;
598 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
599 0 : goto fail;
600 : }
601 :
602 0 : r2->out.result = _spoolss_GetForm(p, r2);
603 0 : break;
604 : }
605 0 : case 33: { /* spoolss_SetForm */
606 0 : struct spoolss_SetForm *r2 = (struct spoolss_SetForm *)r;
607 0 : if (DEBUGLEVEL >= 10) {
608 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetForm, NDR_IN, r2);
609 : }
610 0 : r2->out.result = _spoolss_SetForm(p, r2);
611 0 : break;
612 : }
613 0 : case 34: { /* spoolss_EnumForms */
614 0 : struct spoolss_EnumForms *r2 = (struct spoolss_EnumForms *)r;
615 0 : if (DEBUGLEVEL >= 10) {
616 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumForms, NDR_IN, r2);
617 : }
618 0 : NDR_ZERO_STRUCT(r2->out);
619 0 : r2->out.count = talloc_zero(r2, uint32_t);
620 0 : if (r2->out.count == NULL) {
621 0 : status = NT_STATUS_NO_MEMORY;
622 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
623 0 : goto fail;
624 : }
625 :
626 0 : r2->out.info = talloc_zero(r2, union spoolss_FormInfo *);
627 0 : if (r2->out.info == NULL) {
628 0 : status = NT_STATUS_NO_MEMORY;
629 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
630 0 : goto fail;
631 : }
632 :
633 0 : r2->out.needed = talloc_zero(r2, uint32_t);
634 0 : if (r2->out.needed == NULL) {
635 0 : status = NT_STATUS_NO_MEMORY;
636 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
637 0 : goto fail;
638 : }
639 :
640 0 : r2->out.result = _spoolss_EnumForms(p, r2);
641 0 : break;
642 : }
643 0 : case 35: { /* spoolss_EnumPorts */
644 0 : struct spoolss_EnumPorts *r2 = (struct spoolss_EnumPorts *)r;
645 0 : if (DEBUGLEVEL >= 10) {
646 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPorts, NDR_IN, r2);
647 : }
648 0 : NDR_ZERO_STRUCT(r2->out);
649 0 : r2->out.count = talloc_zero(r2, uint32_t);
650 0 : if (r2->out.count == NULL) {
651 0 : status = NT_STATUS_NO_MEMORY;
652 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
653 0 : goto fail;
654 : }
655 :
656 0 : r2->out.info = talloc_zero(r2, union spoolss_PortInfo *);
657 0 : if (r2->out.info == NULL) {
658 0 : status = NT_STATUS_NO_MEMORY;
659 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
660 0 : goto fail;
661 : }
662 :
663 0 : r2->out.needed = talloc_zero(r2, uint32_t);
664 0 : if (r2->out.needed == NULL) {
665 0 : status = NT_STATUS_NO_MEMORY;
666 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
667 0 : goto fail;
668 : }
669 :
670 0 : r2->out.result = _spoolss_EnumPorts(p, r2);
671 0 : break;
672 : }
673 0 : case 36: { /* spoolss_EnumMonitors */
674 0 : struct spoolss_EnumMonitors *r2 = (struct spoolss_EnumMonitors *)r;
675 0 : if (DEBUGLEVEL >= 10) {
676 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumMonitors, NDR_IN, r2);
677 : }
678 0 : NDR_ZERO_STRUCT(r2->out);
679 0 : r2->out.count = talloc_zero(r2, uint32_t);
680 0 : if (r2->out.count == NULL) {
681 0 : status = NT_STATUS_NO_MEMORY;
682 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
683 0 : goto fail;
684 : }
685 :
686 0 : r2->out.info = talloc_zero(r2, union spoolss_MonitorInfo *);
687 0 : if (r2->out.info == NULL) {
688 0 : status = NT_STATUS_NO_MEMORY;
689 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
690 0 : goto fail;
691 : }
692 :
693 0 : r2->out.needed = talloc_zero(r2, uint32_t);
694 0 : if (r2->out.needed == NULL) {
695 0 : status = NT_STATUS_NO_MEMORY;
696 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
697 0 : goto fail;
698 : }
699 :
700 0 : r2->out.result = _spoolss_EnumMonitors(p, r2);
701 0 : break;
702 : }
703 0 : case 37: { /* spoolss_AddPort */
704 0 : struct spoolss_AddPort *r2 = (struct spoolss_AddPort *)r;
705 0 : if (DEBUGLEVEL >= 10) {
706 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPort, NDR_IN, r2);
707 : }
708 0 : r2->out.result = _spoolss_AddPort(p, r2);
709 0 : break;
710 : }
711 0 : case 38: { /* spoolss_ConfigurePort */
712 0 : struct spoolss_ConfigurePort *r2 = (struct spoolss_ConfigurePort *)r;
713 0 : if (DEBUGLEVEL >= 10) {
714 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ConfigurePort, NDR_IN, r2);
715 : }
716 0 : r2->out.result = _spoolss_ConfigurePort(p, r2);
717 0 : break;
718 : }
719 0 : case 39: { /* spoolss_DeletePort */
720 0 : struct spoolss_DeletePort *r2 = (struct spoolss_DeletePort *)r;
721 0 : if (DEBUGLEVEL >= 10) {
722 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePort, NDR_IN, r2);
723 : }
724 0 : r2->out.result = _spoolss_DeletePort(p, r2);
725 0 : break;
726 : }
727 0 : case 40: { /* spoolss_CreatePrinterIC */
728 0 : struct spoolss_CreatePrinterIC *r2 = (struct spoolss_CreatePrinterIC *)r;
729 0 : if (DEBUGLEVEL >= 10) {
730 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_CreatePrinterIC, NDR_IN, r2);
731 : }
732 0 : NDR_ZERO_STRUCT(r2->out);
733 0 : r2->out.gdi_handle = talloc_zero(r2, struct policy_handle);
734 0 : if (r2->out.gdi_handle == NULL) {
735 0 : status = NT_STATUS_NO_MEMORY;
736 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
737 0 : goto fail;
738 : }
739 :
740 0 : r2->out.result = _spoolss_CreatePrinterIC(p, r2);
741 0 : break;
742 : }
743 0 : case 41: { /* spoolss_PlayGDIScriptOnPrinterIC */
744 0 : struct spoolss_PlayGDIScriptOnPrinterIC *r2 = (struct spoolss_PlayGDIScriptOnPrinterIC *)r;
745 0 : if (DEBUGLEVEL >= 10) {
746 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_PlayGDIScriptOnPrinterIC, NDR_IN, r2);
747 : }
748 0 : NDR_ZERO_STRUCT(r2->out);
749 0 : r2->out.pOut = talloc_zero_array(r2, uint8_t, r2->in.cOut);
750 0 : if (r2->out.pOut == NULL) {
751 0 : status = NT_STATUS_NO_MEMORY;
752 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
753 0 : goto fail;
754 : }
755 :
756 0 : r2->out.result = _spoolss_PlayGDIScriptOnPrinterIC(p, r2);
757 0 : break;
758 : }
759 0 : case 42: { /* spoolss_DeletePrinterIC */
760 0 : struct spoolss_DeletePrinterIC *r2 = (struct spoolss_DeletePrinterIC *)r;
761 0 : if (DEBUGLEVEL >= 10) {
762 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterIC, NDR_IN, r2);
763 : }
764 0 : NDR_ZERO_STRUCT(r2->out);
765 0 : r2->out.gdi_handle = r2->in.gdi_handle;
766 0 : r2->out.result = _spoolss_DeletePrinterIC(p, r2);
767 0 : break;
768 : }
769 0 : case 43: { /* spoolss_AddPrinterConnection */
770 0 : struct spoolss_AddPrinterConnection *r2 = (struct spoolss_AddPrinterConnection *)r;
771 0 : if (DEBUGLEVEL >= 10) {
772 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterConnection, NDR_IN, r2);
773 : }
774 0 : r2->out.result = _spoolss_AddPrinterConnection(p, r2);
775 0 : break;
776 : }
777 0 : case 44: { /* spoolss_DeletePrinterConnection */
778 0 : struct spoolss_DeletePrinterConnection *r2 = (struct spoolss_DeletePrinterConnection *)r;
779 0 : if (DEBUGLEVEL >= 10) {
780 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterConnection, NDR_IN, r2);
781 : }
782 0 : r2->out.result = _spoolss_DeletePrinterConnection(p, r2);
783 0 : break;
784 : }
785 0 : case 45: { /* spoolss_PrinterMessageBox */
786 0 : struct spoolss_PrinterMessageBox *r2 = (struct spoolss_PrinterMessageBox *)r;
787 0 : if (DEBUGLEVEL >= 10) {
788 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_PrinterMessageBox, NDR_IN, r2);
789 : }
790 0 : r2->out.result = _spoolss_PrinterMessageBox(p, r2);
791 0 : break;
792 : }
793 0 : case 46: { /* spoolss_AddMonitor */
794 0 : struct spoolss_AddMonitor *r2 = (struct spoolss_AddMonitor *)r;
795 0 : if (DEBUGLEVEL >= 10) {
796 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddMonitor, NDR_IN, r2);
797 : }
798 0 : r2->out.result = _spoolss_AddMonitor(p, r2);
799 0 : break;
800 : }
801 0 : case 47: { /* spoolss_DeleteMonitor */
802 0 : struct spoolss_DeleteMonitor *r2 = (struct spoolss_DeleteMonitor *)r;
803 0 : if (DEBUGLEVEL >= 10) {
804 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeleteMonitor, NDR_IN, r2);
805 : }
806 0 : r2->out.result = _spoolss_DeleteMonitor(p, r2);
807 0 : break;
808 : }
809 0 : case 48: { /* spoolss_DeletePrintProcessor */
810 0 : struct spoolss_DeletePrintProcessor *r2 = (struct spoolss_DeletePrintProcessor *)r;
811 0 : if (DEBUGLEVEL >= 10) {
812 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrintProcessor, NDR_IN, r2);
813 : }
814 0 : r2->out.result = _spoolss_DeletePrintProcessor(p, r2);
815 0 : break;
816 : }
817 0 : case 49: { /* spoolss_AddPrintProvidor */
818 0 : struct spoolss_AddPrintProvidor *r2 = (struct spoolss_AddPrintProvidor *)r;
819 0 : if (DEBUGLEVEL >= 10) {
820 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrintProvidor, NDR_IN, r2);
821 : }
822 0 : r2->out.result = _spoolss_AddPrintProvidor(p, r2);
823 0 : break;
824 : }
825 0 : case 50: { /* spoolss_DeletePrintProvidor */
826 0 : struct spoolss_DeletePrintProvidor *r2 = (struct spoolss_DeletePrintProvidor *)r;
827 0 : if (DEBUGLEVEL >= 10) {
828 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrintProvidor, NDR_IN, r2);
829 : }
830 0 : r2->out.result = _spoolss_DeletePrintProvidor(p, r2);
831 0 : break;
832 : }
833 0 : case 51: { /* spoolss_EnumPrintProcessorDataTypes */
834 0 : struct spoolss_EnumPrintProcessorDataTypes *r2 = (struct spoolss_EnumPrintProcessorDataTypes *)r;
835 0 : if (DEBUGLEVEL >= 10) {
836 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrintProcessorDataTypes, NDR_IN, r2);
837 : }
838 0 : NDR_ZERO_STRUCT(r2->out);
839 0 : r2->out.count = talloc_zero(r2, uint32_t);
840 0 : if (r2->out.count == NULL) {
841 0 : status = NT_STATUS_NO_MEMORY;
842 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
843 0 : goto fail;
844 : }
845 :
846 0 : r2->out.info = talloc_zero(r2, union spoolss_PrintProcDataTypesInfo *);
847 0 : if (r2->out.info == NULL) {
848 0 : status = NT_STATUS_NO_MEMORY;
849 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
850 0 : goto fail;
851 : }
852 :
853 0 : r2->out.needed = talloc_zero(r2, uint32_t);
854 0 : if (r2->out.needed == NULL) {
855 0 : status = NT_STATUS_NO_MEMORY;
856 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
857 0 : goto fail;
858 : }
859 :
860 0 : r2->out.result = _spoolss_EnumPrintProcessorDataTypes(p, r2);
861 0 : break;
862 : }
863 0 : case 52: { /* spoolss_ResetPrinter */
864 0 : struct spoolss_ResetPrinter *r2 = (struct spoolss_ResetPrinter *)r;
865 0 : if (DEBUGLEVEL >= 10) {
866 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ResetPrinter, NDR_IN, r2);
867 : }
868 0 : r2->out.result = _spoolss_ResetPrinter(p, r2);
869 0 : break;
870 : }
871 0 : case 53: { /* spoolss_GetPrinterDriver2 */
872 0 : struct spoolss_GetPrinterDriver2 *r2 = (struct spoolss_GetPrinterDriver2 *)r;
873 0 : if (DEBUGLEVEL >= 10) {
874 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriver2, NDR_IN, r2);
875 : }
876 0 : NDR_ZERO_STRUCT(r2->out);
877 0 : r2->out.info = talloc_zero(r2, union spoolss_DriverInfo);
878 0 : if (r2->out.info == NULL) {
879 0 : status = NT_STATUS_NO_MEMORY;
880 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
881 0 : goto fail;
882 : }
883 :
884 0 : r2->out.needed = talloc_zero(r2, uint32_t);
885 0 : if (r2->out.needed == NULL) {
886 0 : status = NT_STATUS_NO_MEMORY;
887 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
888 0 : goto fail;
889 : }
890 :
891 0 : r2->out.server_major_version = talloc_zero(r2, uint32_t);
892 0 : if (r2->out.server_major_version == NULL) {
893 0 : status = NT_STATUS_NO_MEMORY;
894 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
895 0 : goto fail;
896 : }
897 :
898 0 : r2->out.server_minor_version = talloc_zero(r2, uint32_t);
899 0 : if (r2->out.server_minor_version == NULL) {
900 0 : status = NT_STATUS_NO_MEMORY;
901 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
902 0 : goto fail;
903 : }
904 :
905 0 : r2->out.result = _spoolss_GetPrinterDriver2(p, r2);
906 0 : break;
907 : }
908 0 : case 54: { /* spoolss_FindFirstPrinterChangeNotification */
909 0 : struct spoolss_FindFirstPrinterChangeNotification *r2 = (struct spoolss_FindFirstPrinterChangeNotification *)r;
910 0 : if (DEBUGLEVEL >= 10) {
911 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_FindFirstPrinterChangeNotification, NDR_IN, r2);
912 : }
913 0 : r2->out.result = _spoolss_FindFirstPrinterChangeNotification(p, r2);
914 0 : break;
915 : }
916 0 : case 55: { /* spoolss_FindNextPrinterChangeNotification */
917 0 : struct spoolss_FindNextPrinterChangeNotification *r2 = (struct spoolss_FindNextPrinterChangeNotification *)r;
918 0 : if (DEBUGLEVEL >= 10) {
919 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_FindNextPrinterChangeNotification, NDR_IN, r2);
920 : }
921 0 : r2->out.result = _spoolss_FindNextPrinterChangeNotification(p, r2);
922 0 : break;
923 : }
924 0 : case 56: { /* spoolss_FindClosePrinterNotify */
925 0 : struct spoolss_FindClosePrinterNotify *r2 = (struct spoolss_FindClosePrinterNotify *)r;
926 0 : if (DEBUGLEVEL >= 10) {
927 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_FindClosePrinterNotify, NDR_IN, r2);
928 : }
929 0 : r2->out.result = _spoolss_FindClosePrinterNotify(p, r2);
930 0 : break;
931 : }
932 0 : case 57: { /* spoolss_RouterFindFirstPrinterChangeNotificationOld */
933 0 : struct spoolss_RouterFindFirstPrinterChangeNotificationOld *r2 = (struct spoolss_RouterFindFirstPrinterChangeNotificationOld *)r;
934 0 : if (DEBUGLEVEL >= 10) {
935 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterFindFirstPrinterChangeNotificationOld, NDR_IN, r2);
936 : }
937 0 : r2->out.result = _spoolss_RouterFindFirstPrinterChangeNotificationOld(p, r2);
938 0 : break;
939 : }
940 0 : case 58: { /* spoolss_ReplyOpenPrinter */
941 0 : struct spoolss_ReplyOpenPrinter *r2 = (struct spoolss_ReplyOpenPrinter *)r;
942 0 : if (DEBUGLEVEL >= 10) {
943 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ReplyOpenPrinter, NDR_IN, r2);
944 : }
945 0 : NDR_ZERO_STRUCT(r2->out);
946 0 : r2->out.handle = talloc_zero(r2, struct policy_handle);
947 0 : if (r2->out.handle == NULL) {
948 0 : status = NT_STATUS_NO_MEMORY;
949 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
950 0 : goto fail;
951 : }
952 :
953 0 : r2->out.result = _spoolss_ReplyOpenPrinter(p, r2);
954 0 : break;
955 : }
956 0 : case 59: { /* spoolss_RouterReplyPrinter */
957 0 : struct spoolss_RouterReplyPrinter *r2 = (struct spoolss_RouterReplyPrinter *)r;
958 0 : if (DEBUGLEVEL >= 10) {
959 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterReplyPrinter, NDR_IN, r2);
960 : }
961 0 : r2->out.result = _spoolss_RouterReplyPrinter(p, r2);
962 0 : break;
963 : }
964 0 : case 60: { /* spoolss_ReplyClosePrinter */
965 0 : struct spoolss_ReplyClosePrinter *r2 = (struct spoolss_ReplyClosePrinter *)r;
966 0 : if (DEBUGLEVEL >= 10) {
967 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ReplyClosePrinter, NDR_IN, r2);
968 : }
969 0 : NDR_ZERO_STRUCT(r2->out);
970 0 : r2->out.handle = r2->in.handle;
971 0 : r2->out.result = _spoolss_ReplyClosePrinter(p, r2);
972 0 : break;
973 : }
974 0 : case 61: { /* spoolss_AddPortEx */
975 0 : struct spoolss_AddPortEx *r2 = (struct spoolss_AddPortEx *)r;
976 0 : if (DEBUGLEVEL >= 10) {
977 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPortEx, NDR_IN, r2);
978 : }
979 0 : r2->out.result = _spoolss_AddPortEx(p, r2);
980 0 : break;
981 : }
982 0 : case 62: { /* spoolss_RouterFindFirstPrinterChangeNotification */
983 0 : struct spoolss_RouterFindFirstPrinterChangeNotification *r2 = (struct spoolss_RouterFindFirstPrinterChangeNotification *)r;
984 0 : if (DEBUGLEVEL >= 10) {
985 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterFindFirstPrinterChangeNotification, NDR_IN, r2);
986 : }
987 0 : r2->out.result = _spoolss_RouterFindFirstPrinterChangeNotification(p, r2);
988 0 : break;
989 : }
990 0 : case 63: { /* spoolss_SpoolerInit */
991 0 : struct spoolss_SpoolerInit *r2 = (struct spoolss_SpoolerInit *)r;
992 0 : if (DEBUGLEVEL >= 10) {
993 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SpoolerInit, NDR_IN, r2);
994 : }
995 0 : r2->out.result = _spoolss_SpoolerInit(p, r2);
996 0 : break;
997 : }
998 0 : case 64: { /* spoolss_ResetPrinterEx */
999 0 : struct spoolss_ResetPrinterEx *r2 = (struct spoolss_ResetPrinterEx *)r;
1000 0 : if (DEBUGLEVEL >= 10) {
1001 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ResetPrinterEx, NDR_IN, r2);
1002 : }
1003 0 : r2->out.result = _spoolss_ResetPrinterEx(p, r2);
1004 0 : break;
1005 : }
1006 2 : case 65: { /* spoolss_RemoteFindFirstPrinterChangeNotifyEx */
1007 2 : struct spoolss_RemoteFindFirstPrinterChangeNotifyEx *r2 = (struct spoolss_RemoteFindFirstPrinterChangeNotifyEx *)r;
1008 2 : if (DEBUGLEVEL >= 10) {
1009 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RemoteFindFirstPrinterChangeNotifyEx, NDR_IN, r2);
1010 : }
1011 2 : r2->out.result = _spoolss_RemoteFindFirstPrinterChangeNotifyEx(p, r2);
1012 2 : break;
1013 : }
1014 0 : case 66: { /* spoolss_RouterReplyPrinterEx */
1015 0 : struct spoolss_RouterReplyPrinterEx *r2 = (struct spoolss_RouterReplyPrinterEx *)r;
1016 0 : if (DEBUGLEVEL >= 10) {
1017 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterReplyPrinterEx, NDR_IN, r2);
1018 : }
1019 0 : NDR_ZERO_STRUCT(r2->out);
1020 0 : r2->out.reply_result = talloc_zero(r2, uint32_t);
1021 0 : if (r2->out.reply_result == NULL) {
1022 0 : status = NT_STATUS_NO_MEMORY;
1023 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1024 0 : goto fail;
1025 : }
1026 :
1027 0 : r2->out.result = _spoolss_RouterReplyPrinterEx(p, r2);
1028 0 : break;
1029 : }
1030 4 : case 67: { /* spoolss_RouterRefreshPrinterChangeNotify */
1031 4 : struct spoolss_RouterRefreshPrinterChangeNotify *r2 = (struct spoolss_RouterRefreshPrinterChangeNotify *)r;
1032 4 : if (DEBUGLEVEL >= 10) {
1033 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterRefreshPrinterChangeNotify, NDR_IN, r2);
1034 : }
1035 4 : NDR_ZERO_STRUCT(r2->out);
1036 4 : r2->out.info = talloc_zero(r2, struct spoolss_NotifyInfo *);
1037 4 : if (r2->out.info == NULL) {
1038 0 : status = NT_STATUS_NO_MEMORY;
1039 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1040 0 : goto fail;
1041 : }
1042 :
1043 4 : r2->out.result = _spoolss_RouterRefreshPrinterChangeNotify(p, r2);
1044 4 : break;
1045 : }
1046 0 : case 68: { /* spoolss_44 */
1047 0 : struct spoolss_44 *r2 = (struct spoolss_44 *)r;
1048 0 : if (DEBUGLEVEL >= 10) {
1049 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_44, NDR_IN, r2);
1050 : }
1051 0 : r2->out.result = _spoolss_44(p, r2);
1052 0 : break;
1053 : }
1054 0 : case 69: { /* spoolss_OpenPrinterEx */
1055 0 : struct spoolss_OpenPrinterEx *r2 = (struct spoolss_OpenPrinterEx *)r;
1056 0 : if (DEBUGLEVEL >= 10) {
1057 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_OpenPrinterEx, NDR_IN, r2);
1058 : }
1059 0 : NDR_ZERO_STRUCT(r2->out);
1060 0 : r2->out.handle = talloc_zero(r2, struct policy_handle);
1061 0 : if (r2->out.handle == NULL) {
1062 0 : status = NT_STATUS_NO_MEMORY;
1063 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1064 0 : goto fail;
1065 : }
1066 :
1067 0 : r2->out.result = _spoolss_OpenPrinterEx(p, r2);
1068 0 : break;
1069 : }
1070 0 : case 70: { /* spoolss_AddPrinterEx */
1071 0 : struct spoolss_AddPrinterEx *r2 = (struct spoolss_AddPrinterEx *)r;
1072 0 : if (DEBUGLEVEL >= 10) {
1073 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterEx, NDR_IN, r2);
1074 : }
1075 0 : NDR_ZERO_STRUCT(r2->out);
1076 0 : r2->out.handle = talloc_zero(r2, struct policy_handle);
1077 0 : if (r2->out.handle == NULL) {
1078 0 : status = NT_STATUS_NO_MEMORY;
1079 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1080 0 : goto fail;
1081 : }
1082 :
1083 0 : r2->out.result = _spoolss_AddPrinterEx(p, r2);
1084 0 : break;
1085 : }
1086 0 : case 71: { /* spoolss_SetPort */
1087 0 : struct spoolss_SetPort *r2 = (struct spoolss_SetPort *)r;
1088 0 : if (DEBUGLEVEL >= 10) {
1089 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPort, NDR_IN, r2);
1090 : }
1091 0 : r2->out.result = _spoolss_SetPort(p, r2);
1092 0 : break;
1093 : }
1094 0 : case 72: { /* spoolss_EnumPrinterData */
1095 0 : struct spoolss_EnumPrinterData *r2 = (struct spoolss_EnumPrinterData *)r;
1096 0 : if (DEBUGLEVEL >= 10) {
1097 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterData, NDR_IN, r2);
1098 : }
1099 0 : NDR_ZERO_STRUCT(r2->out);
1100 0 : r2->out.value_name = talloc_zero_array(r2, const char, r2->in.value_offered / 2);
1101 0 : if (r2->out.value_name == NULL) {
1102 0 : status = NT_STATUS_NO_MEMORY;
1103 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1104 0 : goto fail;
1105 : }
1106 :
1107 0 : r2->out.value_needed = talloc_zero(r2, uint32_t);
1108 0 : if (r2->out.value_needed == NULL) {
1109 0 : status = NT_STATUS_NO_MEMORY;
1110 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1111 0 : goto fail;
1112 : }
1113 :
1114 0 : r2->out.type = talloc_zero(r2, enum winreg_Type);
1115 0 : if (r2->out.type == NULL) {
1116 0 : status = NT_STATUS_NO_MEMORY;
1117 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1118 0 : goto fail;
1119 : }
1120 :
1121 0 : r2->out.data = talloc_zero_array(r2, uint8_t, r2->in.data_offered);
1122 0 : if (r2->out.data == NULL) {
1123 0 : status = NT_STATUS_NO_MEMORY;
1124 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1125 0 : goto fail;
1126 : }
1127 :
1128 0 : r2->out.data_needed = talloc_zero(r2, uint32_t);
1129 0 : if (r2->out.data_needed == NULL) {
1130 0 : status = NT_STATUS_NO_MEMORY;
1131 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1132 0 : goto fail;
1133 : }
1134 :
1135 0 : r2->out.result = _spoolss_EnumPrinterData(p, r2);
1136 0 : break;
1137 : }
1138 0 : case 73: { /* spoolss_DeletePrinterData */
1139 0 : struct spoolss_DeletePrinterData *r2 = (struct spoolss_DeletePrinterData *)r;
1140 0 : if (DEBUGLEVEL >= 10) {
1141 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterData, NDR_IN, r2);
1142 : }
1143 0 : r2->out.result = _spoolss_DeletePrinterData(p, r2);
1144 0 : break;
1145 : }
1146 0 : case 74: { /* spoolss_4a */
1147 0 : struct spoolss_4a *r2 = (struct spoolss_4a *)r;
1148 0 : if (DEBUGLEVEL >= 10) {
1149 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_4a, NDR_IN, r2);
1150 : }
1151 0 : r2->out.result = _spoolss_4a(p, r2);
1152 0 : break;
1153 : }
1154 0 : case 75: { /* spoolss_4b */
1155 0 : struct spoolss_4b *r2 = (struct spoolss_4b *)r;
1156 0 : if (DEBUGLEVEL >= 10) {
1157 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_4b, NDR_IN, r2);
1158 : }
1159 0 : r2->out.result = _spoolss_4b(p, r2);
1160 0 : break;
1161 : }
1162 0 : case 76: { /* spoolss_4c */
1163 0 : struct spoolss_4c *r2 = (struct spoolss_4c *)r;
1164 0 : if (DEBUGLEVEL >= 10) {
1165 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_4c, NDR_IN, r2);
1166 : }
1167 0 : r2->out.result = _spoolss_4c(p, r2);
1168 0 : break;
1169 : }
1170 0 : case 77: { /* spoolss_SetPrinterDataEx */
1171 0 : struct spoolss_SetPrinterDataEx *r2 = (struct spoolss_SetPrinterDataEx *)r;
1172 0 : if (DEBUGLEVEL >= 10) {
1173 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPrinterDataEx, NDR_IN, r2);
1174 : }
1175 0 : r2->out.result = _spoolss_SetPrinterDataEx(p, r2);
1176 0 : break;
1177 : }
1178 0 : case 78: { /* spoolss_GetPrinterDataEx */
1179 0 : struct spoolss_GetPrinterDataEx *r2 = (struct spoolss_GetPrinterDataEx *)r;
1180 0 : if (DEBUGLEVEL >= 10) {
1181 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDataEx, NDR_IN, r2);
1182 : }
1183 0 : NDR_ZERO_STRUCT(r2->out);
1184 0 : r2->out.type = talloc_zero(r2, enum winreg_Type);
1185 0 : if (r2->out.type == NULL) {
1186 0 : status = NT_STATUS_NO_MEMORY;
1187 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1188 0 : goto fail;
1189 : }
1190 :
1191 0 : r2->out.data = talloc_zero_array(r2, uint8_t, r2->in.offered);
1192 0 : if (r2->out.data == NULL) {
1193 0 : status = NT_STATUS_NO_MEMORY;
1194 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1195 0 : goto fail;
1196 : }
1197 :
1198 0 : r2->out.needed = talloc_zero(r2, uint32_t);
1199 0 : if (r2->out.needed == NULL) {
1200 0 : status = NT_STATUS_NO_MEMORY;
1201 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1202 0 : goto fail;
1203 : }
1204 :
1205 0 : r2->out.result = _spoolss_GetPrinterDataEx(p, r2);
1206 0 : break;
1207 : }
1208 0 : case 79: { /* spoolss_EnumPrinterDataEx */
1209 0 : struct spoolss_EnumPrinterDataEx *r2 = (struct spoolss_EnumPrinterDataEx *)r;
1210 0 : if (DEBUGLEVEL >= 10) {
1211 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterDataEx, NDR_IN, r2);
1212 : }
1213 0 : NDR_ZERO_STRUCT(r2->out);
1214 0 : r2->out.count = talloc_zero(r2, uint32_t);
1215 0 : if (r2->out.count == NULL) {
1216 0 : status = NT_STATUS_NO_MEMORY;
1217 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1218 0 : goto fail;
1219 : }
1220 :
1221 0 : r2->out.info = talloc_zero(r2, struct spoolss_PrinterEnumValues *);
1222 0 : if (r2->out.info == NULL) {
1223 0 : status = NT_STATUS_NO_MEMORY;
1224 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1225 0 : goto fail;
1226 : }
1227 :
1228 0 : r2->out.needed = talloc_zero(r2, uint32_t);
1229 0 : if (r2->out.needed == NULL) {
1230 0 : status = NT_STATUS_NO_MEMORY;
1231 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1232 0 : goto fail;
1233 : }
1234 :
1235 0 : r2->out.result = _spoolss_EnumPrinterDataEx(p, r2);
1236 0 : break;
1237 : }
1238 0 : case 80: { /* spoolss_EnumPrinterKey */
1239 0 : struct spoolss_EnumPrinterKey *r2 = (struct spoolss_EnumPrinterKey *)r;
1240 0 : if (DEBUGLEVEL >= 10) {
1241 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterKey, NDR_IN, r2);
1242 : }
1243 0 : NDR_ZERO_STRUCT(r2->out);
1244 0 : r2->out._ndr_size = talloc_zero(r2, uint32_t);
1245 0 : if (r2->out._ndr_size == NULL) {
1246 0 : status = NT_STATUS_NO_MEMORY;
1247 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1248 0 : goto fail;
1249 : }
1250 :
1251 0 : r2->out.key_buffer = talloc_zero(r2, union spoolss_KeyNames);
1252 0 : if (r2->out.key_buffer == NULL) {
1253 0 : status = NT_STATUS_NO_MEMORY;
1254 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1255 0 : goto fail;
1256 : }
1257 :
1258 0 : r2->out.needed = talloc_zero(r2, uint32_t);
1259 0 : if (r2->out.needed == NULL) {
1260 0 : status = NT_STATUS_NO_MEMORY;
1261 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1262 0 : goto fail;
1263 : }
1264 :
1265 0 : r2->out.result = _spoolss_EnumPrinterKey(p, r2);
1266 0 : break;
1267 : }
1268 0 : case 81: { /* spoolss_DeletePrinterDataEx */
1269 0 : struct spoolss_DeletePrinterDataEx *r2 = (struct spoolss_DeletePrinterDataEx *)r;
1270 0 : if (DEBUGLEVEL >= 10) {
1271 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterDataEx, NDR_IN, r2);
1272 : }
1273 0 : r2->out.result = _spoolss_DeletePrinterDataEx(p, r2);
1274 0 : break;
1275 : }
1276 0 : case 82: { /* spoolss_DeletePrinterKey */
1277 0 : struct spoolss_DeletePrinterKey *r2 = (struct spoolss_DeletePrinterKey *)r;
1278 0 : if (DEBUGLEVEL >= 10) {
1279 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterKey, NDR_IN, r2);
1280 : }
1281 0 : r2->out.result = _spoolss_DeletePrinterKey(p, r2);
1282 0 : break;
1283 : }
1284 0 : case 83: { /* spoolss_53 */
1285 0 : struct spoolss_53 *r2 = (struct spoolss_53 *)r;
1286 0 : if (DEBUGLEVEL >= 10) {
1287 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_53, NDR_IN, r2);
1288 : }
1289 0 : r2->out.result = _spoolss_53(p, r2);
1290 0 : break;
1291 : }
1292 0 : case 84: { /* spoolss_DeletePrinterDriverEx */
1293 0 : struct spoolss_DeletePrinterDriverEx *r2 = (struct spoolss_DeletePrinterDriverEx *)r;
1294 0 : if (DEBUGLEVEL >= 10) {
1295 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterDriverEx, NDR_IN, r2);
1296 : }
1297 0 : r2->out.result = _spoolss_DeletePrinterDriverEx(p, r2);
1298 0 : break;
1299 : }
1300 0 : case 85: { /* spoolss_AddPerMachineConnection */
1301 0 : struct spoolss_AddPerMachineConnection *r2 = (struct spoolss_AddPerMachineConnection *)r;
1302 0 : if (DEBUGLEVEL >= 10) {
1303 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPerMachineConnection, NDR_IN, r2);
1304 : }
1305 0 : r2->out.result = _spoolss_AddPerMachineConnection(p, r2);
1306 0 : break;
1307 : }
1308 0 : case 86: { /* spoolss_DeletePerMachineConnection */
1309 0 : struct spoolss_DeletePerMachineConnection *r2 = (struct spoolss_DeletePerMachineConnection *)r;
1310 0 : if (DEBUGLEVEL >= 10) {
1311 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePerMachineConnection, NDR_IN, r2);
1312 : }
1313 0 : r2->out.result = _spoolss_DeletePerMachineConnection(p, r2);
1314 0 : break;
1315 : }
1316 0 : case 87: { /* spoolss_EnumPerMachineConnections */
1317 0 : struct spoolss_EnumPerMachineConnections *r2 = (struct spoolss_EnumPerMachineConnections *)r;
1318 0 : if (DEBUGLEVEL >= 10) {
1319 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPerMachineConnections, NDR_IN, r2);
1320 : }
1321 0 : NDR_ZERO_STRUCT(r2->out);
1322 0 : r2->out.count = talloc_zero(r2, uint32_t);
1323 0 : if (r2->out.count == NULL) {
1324 0 : status = NT_STATUS_NO_MEMORY;
1325 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1326 0 : goto fail;
1327 : }
1328 :
1329 0 : r2->out.info = talloc_zero(r2, struct spoolss_PrinterInfo4 *);
1330 0 : if (r2->out.info == NULL) {
1331 0 : status = NT_STATUS_NO_MEMORY;
1332 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1333 0 : goto fail;
1334 : }
1335 :
1336 0 : r2->out.needed = talloc_zero(r2, uint32_t);
1337 0 : if (r2->out.needed == NULL) {
1338 0 : status = NT_STATUS_NO_MEMORY;
1339 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1340 0 : goto fail;
1341 : }
1342 :
1343 0 : r2->out.result = _spoolss_EnumPerMachineConnections(p, r2);
1344 0 : break;
1345 : }
1346 0 : case 88: { /* spoolss_XcvData */
1347 0 : struct spoolss_XcvData *r2 = (struct spoolss_XcvData *)r;
1348 0 : if (DEBUGLEVEL >= 10) {
1349 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_XcvData, NDR_IN, r2);
1350 : }
1351 0 : NDR_ZERO_STRUCT(r2->out);
1352 0 : r2->out.status_code = r2->in.status_code;
1353 0 : r2->out.out_data = talloc_zero_array(r2, uint8_t, r2->in.out_data_size);
1354 0 : if (r2->out.out_data == NULL) {
1355 0 : status = NT_STATUS_NO_MEMORY;
1356 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1357 0 : goto fail;
1358 : }
1359 :
1360 0 : r2->out.needed = talloc_zero(r2, uint32_t);
1361 0 : if (r2->out.needed == NULL) {
1362 0 : status = NT_STATUS_NO_MEMORY;
1363 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1364 0 : goto fail;
1365 : }
1366 :
1367 0 : r2->out.result = _spoolss_XcvData(p, r2);
1368 0 : break;
1369 : }
1370 0 : case 89: { /* spoolss_AddPrinterDriverEx */
1371 0 : struct spoolss_AddPrinterDriverEx *r2 = (struct spoolss_AddPrinterDriverEx *)r;
1372 0 : if (DEBUGLEVEL >= 10) {
1373 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterDriverEx, NDR_IN, r2);
1374 : }
1375 0 : r2->out.result = _spoolss_AddPrinterDriverEx(p, r2);
1376 0 : break;
1377 : }
1378 0 : case 90: { /* spoolss_5a */
1379 0 : struct spoolss_5a *r2 = (struct spoolss_5a *)r;
1380 0 : if (DEBUGLEVEL >= 10) {
1381 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5a, NDR_IN, r2);
1382 : }
1383 0 : r2->out.result = _spoolss_5a(p, r2);
1384 0 : break;
1385 : }
1386 0 : case 91: { /* spoolss_5b */
1387 0 : struct spoolss_5b *r2 = (struct spoolss_5b *)r;
1388 0 : if (DEBUGLEVEL >= 10) {
1389 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5b, NDR_IN, r2);
1390 : }
1391 0 : r2->out.result = _spoolss_5b(p, r2);
1392 0 : break;
1393 : }
1394 0 : case 92: { /* spoolss_5c */
1395 0 : struct spoolss_5c *r2 = (struct spoolss_5c *)r;
1396 0 : if (DEBUGLEVEL >= 10) {
1397 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5c, NDR_IN, r2);
1398 : }
1399 0 : r2->out.result = _spoolss_5c(p, r2);
1400 0 : break;
1401 : }
1402 0 : case 93: { /* spoolss_5d */
1403 0 : struct spoolss_5d *r2 = (struct spoolss_5d *)r;
1404 0 : if (DEBUGLEVEL >= 10) {
1405 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5d, NDR_IN, r2);
1406 : }
1407 0 : r2->out.result = _spoolss_5d(p, r2);
1408 0 : break;
1409 : }
1410 0 : case 94: { /* spoolss_5e */
1411 0 : struct spoolss_5e *r2 = (struct spoolss_5e *)r;
1412 0 : if (DEBUGLEVEL >= 10) {
1413 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5e, NDR_IN, r2);
1414 : }
1415 0 : r2->out.result = _spoolss_5e(p, r2);
1416 0 : break;
1417 : }
1418 0 : case 95: { /* spoolss_5f */
1419 0 : struct spoolss_5f *r2 = (struct spoolss_5f *)r;
1420 0 : if (DEBUGLEVEL >= 10) {
1421 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5f, NDR_IN, r2);
1422 : }
1423 0 : r2->out.result = _spoolss_5f(p, r2);
1424 0 : break;
1425 : }
1426 0 : case 96: { /* spoolss_60 */
1427 0 : struct spoolss_60 *r2 = (struct spoolss_60 *)r;
1428 0 : if (DEBUGLEVEL >= 10) {
1429 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_60, NDR_IN, r2);
1430 : }
1431 0 : r2->out.result = _spoolss_60(p, r2);
1432 0 : break;
1433 : }
1434 0 : case 97: { /* spoolss_SendRecvBidiData */
1435 0 : struct spoolss_SendRecvBidiData *r2 = (struct spoolss_SendRecvBidiData *)r;
1436 0 : if (DEBUGLEVEL >= 10) {
1437 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SendRecvBidiData, NDR_IN, r2);
1438 : }
1439 0 : NDR_ZERO_STRUCT(r2->out);
1440 0 : r2->out.ppRespData = talloc_zero(r2, struct RPC_BIDI_RESPONSE_CONTAINER *);
1441 0 : if (r2->out.ppRespData == NULL) {
1442 0 : status = NT_STATUS_NO_MEMORY;
1443 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1444 0 : goto fail;
1445 : }
1446 :
1447 0 : r2->out.result = _spoolss_SendRecvBidiData(p, r2);
1448 0 : break;
1449 : }
1450 0 : case 98: { /* spoolss_62 */
1451 0 : struct spoolss_62 *r2 = (struct spoolss_62 *)r;
1452 0 : if (DEBUGLEVEL >= 10) {
1453 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_62, NDR_IN, r2);
1454 : }
1455 0 : r2->out.result = _spoolss_62(p, r2);
1456 0 : break;
1457 : }
1458 0 : case 99: { /* spoolss_63 */
1459 0 : struct spoolss_63 *r2 = (struct spoolss_63 *)r;
1460 0 : if (DEBUGLEVEL >= 10) {
1461 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_63, NDR_IN, r2);
1462 : }
1463 0 : r2->out.result = _spoolss_63(p, r2);
1464 0 : break;
1465 : }
1466 0 : case 100: { /* spoolss_64 */
1467 0 : struct spoolss_64 *r2 = (struct spoolss_64 *)r;
1468 0 : if (DEBUGLEVEL >= 10) {
1469 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_64, NDR_IN, r2);
1470 : }
1471 0 : r2->out.result = _spoolss_64(p, r2);
1472 0 : break;
1473 : }
1474 0 : case 101: { /* spoolss_65 */
1475 0 : struct spoolss_65 *r2 = (struct spoolss_65 *)r;
1476 0 : if (DEBUGLEVEL >= 10) {
1477 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_65, NDR_IN, r2);
1478 : }
1479 0 : r2->out.result = _spoolss_65(p, r2);
1480 0 : break;
1481 : }
1482 0 : case 102: { /* spoolss_GetCorePrinterDrivers */
1483 0 : struct spoolss_GetCorePrinterDrivers *r2 = (struct spoolss_GetCorePrinterDrivers *)r;
1484 0 : if (DEBUGLEVEL >= 10) {
1485 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetCorePrinterDrivers, NDR_IN, r2);
1486 : }
1487 0 : NDR_ZERO_STRUCT(r2->out);
1488 0 : r2->out.core_printer_drivers = talloc_zero_array(r2, struct spoolss_CorePrinterDriver, r2->in.core_printer_driver_count);
1489 0 : if (r2->out.core_printer_drivers == NULL) {
1490 0 : status = NT_STATUS_NO_MEMORY;
1491 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1492 0 : goto fail;
1493 : }
1494 :
1495 0 : r2->out.result = _spoolss_GetCorePrinterDrivers(p, r2);
1496 0 : break;
1497 : }
1498 0 : case 103: { /* spoolss_67 */
1499 0 : struct spoolss_67 *r2 = (struct spoolss_67 *)r;
1500 0 : if (DEBUGLEVEL >= 10) {
1501 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_67, NDR_IN, r2);
1502 : }
1503 0 : r2->out.result = _spoolss_67(p, r2);
1504 0 : break;
1505 : }
1506 0 : case 104: { /* spoolss_GetPrinterDriverPackagePath */
1507 0 : struct spoolss_GetPrinterDriverPackagePath *r2 = (struct spoolss_GetPrinterDriverPackagePath *)r;
1508 0 : if (DEBUGLEVEL >= 10) {
1509 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriverPackagePath, NDR_IN, r2);
1510 : }
1511 0 : NDR_ZERO_STRUCT(r2->out);
1512 0 : r2->out.driver_package_cab = r2->in.driver_package_cab;
1513 0 : r2->out.required = talloc_zero(r2, uint32_t);
1514 0 : if (r2->out.required == NULL) {
1515 0 : status = NT_STATUS_NO_MEMORY;
1516 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1517 0 : goto fail;
1518 : }
1519 :
1520 0 : r2->out.result = _spoolss_GetPrinterDriverPackagePath(p, r2);
1521 0 : break;
1522 : }
1523 0 : case 105: { /* spoolss_69 */
1524 0 : struct spoolss_69 *r2 = (struct spoolss_69 *)r;
1525 0 : if (DEBUGLEVEL >= 10) {
1526 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_69, NDR_IN, r2);
1527 : }
1528 0 : r2->out.result = _spoolss_69(p, r2);
1529 0 : break;
1530 : }
1531 0 : case 106: { /* spoolss_6a */
1532 0 : struct spoolss_6a *r2 = (struct spoolss_6a *)r;
1533 0 : if (DEBUGLEVEL >= 10) {
1534 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6a, NDR_IN, r2);
1535 : }
1536 0 : r2->out.result = _spoolss_6a(p, r2);
1537 0 : break;
1538 : }
1539 0 : case 107: { /* spoolss_6b */
1540 0 : struct spoolss_6b *r2 = (struct spoolss_6b *)r;
1541 0 : if (DEBUGLEVEL >= 10) {
1542 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6b, NDR_IN, r2);
1543 : }
1544 0 : r2->out.result = _spoolss_6b(p, r2);
1545 0 : break;
1546 : }
1547 0 : case 108: { /* spoolss_6c */
1548 0 : struct spoolss_6c *r2 = (struct spoolss_6c *)r;
1549 0 : if (DEBUGLEVEL >= 10) {
1550 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6c, NDR_IN, r2);
1551 : }
1552 0 : r2->out.result = _spoolss_6c(p, r2);
1553 0 : break;
1554 : }
1555 0 : case 109: { /* spoolss_6d */
1556 0 : struct spoolss_6d *r2 = (struct spoolss_6d *)r;
1557 0 : if (DEBUGLEVEL >= 10) {
1558 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6d, NDR_IN, r2);
1559 : }
1560 0 : r2->out.result = _spoolss_6d(p, r2);
1561 0 : break;
1562 : }
1563 0 : case 110: { /* spoolss_GetJobNamedPropertyValue */
1564 0 : struct spoolss_GetJobNamedPropertyValue *r2 = (struct spoolss_GetJobNamedPropertyValue *)r;
1565 0 : if (DEBUGLEVEL >= 10) {
1566 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetJobNamedPropertyValue, NDR_IN, r2);
1567 : }
1568 0 : NDR_ZERO_STRUCT(r2->out);
1569 0 : r2->out.pValue = talloc_zero(r2, struct spoolss_PrintPropertyValue);
1570 0 : if (r2->out.pValue == NULL) {
1571 0 : status = NT_STATUS_NO_MEMORY;
1572 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1573 0 : goto fail;
1574 : }
1575 :
1576 0 : r2->out.result = _spoolss_GetJobNamedPropertyValue(p, r2);
1577 0 : break;
1578 : }
1579 0 : case 111: { /* spoolss_SetJobNamedProperty */
1580 0 : struct spoolss_SetJobNamedProperty *r2 = (struct spoolss_SetJobNamedProperty *)r;
1581 0 : if (DEBUGLEVEL >= 10) {
1582 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetJobNamedProperty, NDR_IN, r2);
1583 : }
1584 0 : r2->out.result = _spoolss_SetJobNamedProperty(p, r2);
1585 0 : break;
1586 : }
1587 0 : case 112: { /* spoolss_DeleteJobNamedProperty */
1588 0 : struct spoolss_DeleteJobNamedProperty *r2 = (struct spoolss_DeleteJobNamedProperty *)r;
1589 0 : if (DEBUGLEVEL >= 10) {
1590 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeleteJobNamedProperty, NDR_IN, r2);
1591 : }
1592 0 : r2->out.result = _spoolss_DeleteJobNamedProperty(p, r2);
1593 0 : break;
1594 : }
1595 0 : case 113: { /* spoolss_EnumJobNamedProperties */
1596 0 : struct spoolss_EnumJobNamedProperties *r2 = (struct spoolss_EnumJobNamedProperties *)r;
1597 0 : if (DEBUGLEVEL >= 10) {
1598 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumJobNamedProperties, NDR_IN, r2);
1599 : }
1600 0 : NDR_ZERO_STRUCT(r2->out);
1601 0 : r2->out.pcProperties = talloc_zero(r2, uint32_t);
1602 0 : if (r2->out.pcProperties == NULL) {
1603 0 : status = NT_STATUS_NO_MEMORY;
1604 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1605 0 : goto fail;
1606 : }
1607 :
1608 0 : r2->out.ppProperties = talloc_zero(r2, struct spoolss_PrintNamedProperty *);
1609 0 : if (r2->out.ppProperties == NULL) {
1610 0 : status = NT_STATUS_NO_MEMORY;
1611 0 : p->fault_state = DCERPC_FAULT_CANT_PERFORM;
1612 0 : goto fail;
1613 : }
1614 :
1615 0 : r2->out.result = _spoolss_EnumJobNamedProperties(p, r2);
1616 0 : break;
1617 : }
1618 0 : case 114: { /* spoolss_72 */
1619 0 : struct spoolss_72 *r2 = (struct spoolss_72 *)r;
1620 0 : if (DEBUGLEVEL >= 10) {
1621 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_72, NDR_IN, r2);
1622 : }
1623 0 : r2->out.result = _spoolss_72(p, r2);
1624 0 : break;
1625 : }
1626 0 : case 115: { /* spoolss_73 */
1627 0 : struct spoolss_73 *r2 = (struct spoolss_73 *)r;
1628 0 : if (DEBUGLEVEL >= 10) {
1629 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_73, NDR_IN, r2);
1630 : }
1631 0 : r2->out.result = _spoolss_73(p, r2);
1632 0 : break;
1633 : }
1634 0 : case 116: { /* spoolss_LogJobInfoForBranchOffice */
1635 0 : struct spoolss_LogJobInfoForBranchOffice *r2 = (struct spoolss_LogJobInfoForBranchOffice *)r;
1636 0 : if (DEBUGLEVEL >= 10) {
1637 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_LogJobInfoForBranchOffice, NDR_IN, r2);
1638 : }
1639 0 : r2->out.result = _spoolss_LogJobInfoForBranchOffice(p, r2);
1640 0 : break;
1641 : }
1642 0 : default:
1643 0 : dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
1644 0 : break;
1645 : }
1646 :
1647 10 : fail:
1648 : /* Unimpersonate */
1649 10 : if (impersonated) {
1650 10 : unbecome_authenticated_pipe_user();
1651 : }
1652 :
1653 10 : p->dce_call = NULL;
1654 10 : p->mem_ctx = NULL;
1655 : /* Check pipes struct fault state */
1656 10 : if (p->fault_state != 0) {
1657 0 : dce_call->fault_code = p->fault_state;
1658 : }
1659 10 : if (dce_call->fault_code != 0) {
1660 0 : status = NT_STATUS_NET_WRITE_FAULT;
1661 : }
1662 :
1663 10 : return status;
1664 : }
1665 :
1666 10 : NTSTATUS spoolss__op_dispatch(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
1667 : {
1668 10 : return spoolss__op_dispatch_internal(dce_call, mem_ctx, r, S3COMPAT_RPC_DISPATCH_EXTERNAL);
1669 : }
1670 :
1671 10 : NTSTATUS spoolss__op_reply(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
1672 : {
1673 10 : uint16_t opnum = dce_call->pkt.u.request.opnum;
1674 :
1675 10 : switch (opnum) {
1676 0 : case 0: { /* spoolss_EnumPrinters */
1677 0 : struct spoolss_EnumPrinters *r2 = (struct spoolss_EnumPrinters *)r;
1678 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1679 0 : DEBUG(5,("function spoolss_EnumPrinters replied async\n"));
1680 : }
1681 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1682 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinters, NDR_OUT | NDR_SET_VALUES, r2);
1683 : }
1684 0 : if (dce_call->fault_code != 0) {
1685 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrinters\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1686 : }
1687 0 : break;
1688 : }
1689 2 : case 1: { /* spoolss_OpenPrinter */
1690 2 : struct spoolss_OpenPrinter *r2 = (struct spoolss_OpenPrinter *)r;
1691 2 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1692 0 : DEBUG(5,("function spoolss_OpenPrinter replied async\n"));
1693 : }
1694 2 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1695 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_OpenPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1696 : }
1697 2 : if (dce_call->fault_code != 0) {
1698 0 : DBG_WARNING("dcerpc_fault %s in spoolss_OpenPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1699 : }
1700 2 : break;
1701 : }
1702 0 : case 2: { /* spoolss_SetJob */
1703 0 : struct spoolss_SetJob *r2 = (struct spoolss_SetJob *)r;
1704 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1705 0 : DEBUG(5,("function spoolss_SetJob replied async\n"));
1706 : }
1707 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1708 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetJob, NDR_OUT | NDR_SET_VALUES, r2);
1709 : }
1710 0 : if (dce_call->fault_code != 0) {
1711 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetJob\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1712 : }
1713 0 : break;
1714 : }
1715 0 : case 3: { /* spoolss_GetJob */
1716 0 : struct spoolss_GetJob *r2 = (struct spoolss_GetJob *)r;
1717 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1718 0 : DEBUG(5,("function spoolss_GetJob replied async\n"));
1719 : }
1720 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1721 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetJob, NDR_OUT | NDR_SET_VALUES, r2);
1722 : }
1723 0 : if (dce_call->fault_code != 0) {
1724 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetJob\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1725 : }
1726 0 : break;
1727 : }
1728 0 : case 4: { /* spoolss_EnumJobs */
1729 0 : struct spoolss_EnumJobs *r2 = (struct spoolss_EnumJobs *)r;
1730 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1731 0 : DEBUG(5,("function spoolss_EnumJobs replied async\n"));
1732 : }
1733 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1734 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumJobs, NDR_OUT | NDR_SET_VALUES, r2);
1735 : }
1736 0 : if (dce_call->fault_code != 0) {
1737 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumJobs\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1738 : }
1739 0 : break;
1740 : }
1741 0 : case 5: { /* spoolss_AddPrinter */
1742 0 : struct spoolss_AddPrinter *r2 = (struct spoolss_AddPrinter *)r;
1743 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1744 0 : DEBUG(5,("function spoolss_AddPrinter replied async\n"));
1745 : }
1746 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1747 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1748 : }
1749 0 : if (dce_call->fault_code != 0) {
1750 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1751 : }
1752 0 : break;
1753 : }
1754 0 : case 6: { /* spoolss_DeletePrinter */
1755 0 : struct spoolss_DeletePrinter *r2 = (struct spoolss_DeletePrinter *)r;
1756 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1757 0 : DEBUG(5,("function spoolss_DeletePrinter replied async\n"));
1758 : }
1759 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1760 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinter, NDR_OUT | NDR_SET_VALUES, r2);
1761 : }
1762 0 : if (dce_call->fault_code != 0) {
1763 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1764 : }
1765 0 : break;
1766 : }
1767 0 : case 7: { /* spoolss_SetPrinter */
1768 0 : struct spoolss_SetPrinter *r2 = (struct spoolss_SetPrinter *)r;
1769 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1770 0 : DEBUG(5,("function spoolss_SetPrinter replied async\n"));
1771 : }
1772 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1773 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1774 : }
1775 0 : if (dce_call->fault_code != 0) {
1776 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1777 : }
1778 0 : break;
1779 : }
1780 0 : case 8: { /* spoolss_GetPrinter */
1781 0 : struct spoolss_GetPrinter *r2 = (struct spoolss_GetPrinter *)r;
1782 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1783 0 : DEBUG(5,("function spoolss_GetPrinter replied async\n"));
1784 : }
1785 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1786 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1787 : }
1788 0 : if (dce_call->fault_code != 0) {
1789 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1790 : }
1791 0 : break;
1792 : }
1793 0 : case 9: { /* spoolss_AddPrinterDriver */
1794 0 : struct spoolss_AddPrinterDriver *r2 = (struct spoolss_AddPrinterDriver *)r;
1795 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1796 0 : DEBUG(5,("function spoolss_AddPrinterDriver replied async\n"));
1797 : }
1798 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1799 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterDriver, NDR_OUT | NDR_SET_VALUES, r2);
1800 : }
1801 0 : if (dce_call->fault_code != 0) {
1802 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrinterDriver\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1803 : }
1804 0 : break;
1805 : }
1806 0 : case 10: { /* spoolss_EnumPrinterDrivers */
1807 0 : struct spoolss_EnumPrinterDrivers *r2 = (struct spoolss_EnumPrinterDrivers *)r;
1808 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1809 0 : DEBUG(5,("function spoolss_EnumPrinterDrivers replied async\n"));
1810 : }
1811 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1812 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterDrivers, NDR_OUT | NDR_SET_VALUES, r2);
1813 : }
1814 0 : if (dce_call->fault_code != 0) {
1815 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrinterDrivers\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1816 : }
1817 0 : break;
1818 : }
1819 0 : case 11: { /* spoolss_GetPrinterDriver */
1820 0 : struct spoolss_GetPrinterDriver *r2 = (struct spoolss_GetPrinterDriver *)r;
1821 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1822 0 : DEBUG(5,("function spoolss_GetPrinterDriver replied async\n"));
1823 : }
1824 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1825 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriver, NDR_OUT | NDR_SET_VALUES, r2);
1826 : }
1827 0 : if (dce_call->fault_code != 0) {
1828 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinterDriver\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1829 : }
1830 0 : break;
1831 : }
1832 0 : case 12: { /* spoolss_GetPrinterDriverDirectory */
1833 0 : struct spoolss_GetPrinterDriverDirectory *r2 = (struct spoolss_GetPrinterDriverDirectory *)r;
1834 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1835 0 : DEBUG(5,("function spoolss_GetPrinterDriverDirectory replied async\n"));
1836 : }
1837 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1838 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriverDirectory, NDR_OUT | NDR_SET_VALUES, r2);
1839 : }
1840 0 : if (dce_call->fault_code != 0) {
1841 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinterDriverDirectory\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1842 : }
1843 0 : break;
1844 : }
1845 0 : case 13: { /* spoolss_DeletePrinterDriver */
1846 0 : struct spoolss_DeletePrinterDriver *r2 = (struct spoolss_DeletePrinterDriver *)r;
1847 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1848 0 : DEBUG(5,("function spoolss_DeletePrinterDriver replied async\n"));
1849 : }
1850 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1851 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterDriver, NDR_OUT | NDR_SET_VALUES, r2);
1852 : }
1853 0 : if (dce_call->fault_code != 0) {
1854 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterDriver\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1855 : }
1856 0 : break;
1857 : }
1858 0 : case 14: { /* spoolss_AddPrintProcessor */
1859 0 : struct spoolss_AddPrintProcessor *r2 = (struct spoolss_AddPrintProcessor *)r;
1860 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1861 0 : DEBUG(5,("function spoolss_AddPrintProcessor replied async\n"));
1862 : }
1863 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1864 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrintProcessor, NDR_OUT | NDR_SET_VALUES, r2);
1865 : }
1866 0 : if (dce_call->fault_code != 0) {
1867 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrintProcessor\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1868 : }
1869 0 : break;
1870 : }
1871 0 : case 15: { /* spoolss_EnumPrintProcessors */
1872 0 : struct spoolss_EnumPrintProcessors *r2 = (struct spoolss_EnumPrintProcessors *)r;
1873 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1874 0 : DEBUG(5,("function spoolss_EnumPrintProcessors replied async\n"));
1875 : }
1876 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1877 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrintProcessors, NDR_OUT | NDR_SET_VALUES, r2);
1878 : }
1879 0 : if (dce_call->fault_code != 0) {
1880 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrintProcessors\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1881 : }
1882 0 : break;
1883 : }
1884 0 : case 16: { /* spoolss_GetPrintProcessorDirectory */
1885 0 : struct spoolss_GetPrintProcessorDirectory *r2 = (struct spoolss_GetPrintProcessorDirectory *)r;
1886 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1887 0 : DEBUG(5,("function spoolss_GetPrintProcessorDirectory replied async\n"));
1888 : }
1889 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1890 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrintProcessorDirectory, NDR_OUT | NDR_SET_VALUES, r2);
1891 : }
1892 0 : if (dce_call->fault_code != 0) {
1893 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrintProcessorDirectory\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1894 : }
1895 0 : break;
1896 : }
1897 0 : case 17: { /* spoolss_StartDocPrinter */
1898 0 : struct spoolss_StartDocPrinter *r2 = (struct spoolss_StartDocPrinter *)r;
1899 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1900 0 : DEBUG(5,("function spoolss_StartDocPrinter replied async\n"));
1901 : }
1902 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1903 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_StartDocPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1904 : }
1905 0 : if (dce_call->fault_code != 0) {
1906 0 : DBG_WARNING("dcerpc_fault %s in spoolss_StartDocPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1907 : }
1908 0 : break;
1909 : }
1910 0 : case 18: { /* spoolss_StartPagePrinter */
1911 0 : struct spoolss_StartPagePrinter *r2 = (struct spoolss_StartPagePrinter *)r;
1912 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1913 0 : DEBUG(5,("function spoolss_StartPagePrinter replied async\n"));
1914 : }
1915 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1916 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_StartPagePrinter, NDR_OUT | NDR_SET_VALUES, r2);
1917 : }
1918 0 : if (dce_call->fault_code != 0) {
1919 0 : DBG_WARNING("dcerpc_fault %s in spoolss_StartPagePrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1920 : }
1921 0 : break;
1922 : }
1923 0 : case 19: { /* spoolss_WritePrinter */
1924 0 : struct spoolss_WritePrinter *r2 = (struct spoolss_WritePrinter *)r;
1925 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1926 0 : DEBUG(5,("function spoolss_WritePrinter replied async\n"));
1927 : }
1928 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1929 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_WritePrinter, NDR_OUT | NDR_SET_VALUES, r2);
1930 : }
1931 0 : if (dce_call->fault_code != 0) {
1932 0 : DBG_WARNING("dcerpc_fault %s in spoolss_WritePrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1933 : }
1934 0 : break;
1935 : }
1936 0 : case 20: { /* spoolss_EndPagePrinter */
1937 0 : struct spoolss_EndPagePrinter *r2 = (struct spoolss_EndPagePrinter *)r;
1938 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1939 0 : DEBUG(5,("function spoolss_EndPagePrinter replied async\n"));
1940 : }
1941 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1942 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EndPagePrinter, NDR_OUT | NDR_SET_VALUES, r2);
1943 : }
1944 0 : if (dce_call->fault_code != 0) {
1945 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EndPagePrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1946 : }
1947 0 : break;
1948 : }
1949 0 : case 21: { /* spoolss_AbortPrinter */
1950 0 : struct spoolss_AbortPrinter *r2 = (struct spoolss_AbortPrinter *)r;
1951 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1952 0 : DEBUG(5,("function spoolss_AbortPrinter replied async\n"));
1953 : }
1954 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1955 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AbortPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1956 : }
1957 0 : if (dce_call->fault_code != 0) {
1958 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AbortPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1959 : }
1960 0 : break;
1961 : }
1962 0 : case 22: { /* spoolss_ReadPrinter */
1963 0 : struct spoolss_ReadPrinter *r2 = (struct spoolss_ReadPrinter *)r;
1964 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1965 0 : DEBUG(5,("function spoolss_ReadPrinter replied async\n"));
1966 : }
1967 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1968 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ReadPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1969 : }
1970 0 : if (dce_call->fault_code != 0) {
1971 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ReadPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1972 : }
1973 0 : break;
1974 : }
1975 0 : case 23: { /* spoolss_EndDocPrinter */
1976 0 : struct spoolss_EndDocPrinter *r2 = (struct spoolss_EndDocPrinter *)r;
1977 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1978 0 : DEBUG(5,("function spoolss_EndDocPrinter replied async\n"));
1979 : }
1980 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1981 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EndDocPrinter, NDR_OUT | NDR_SET_VALUES, r2);
1982 : }
1983 0 : if (dce_call->fault_code != 0) {
1984 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EndDocPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1985 : }
1986 0 : break;
1987 : }
1988 0 : case 24: { /* spoolss_AddJob */
1989 0 : struct spoolss_AddJob *r2 = (struct spoolss_AddJob *)r;
1990 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
1991 0 : DEBUG(5,("function spoolss_AddJob replied async\n"));
1992 : }
1993 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
1994 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddJob, NDR_OUT | NDR_SET_VALUES, r2);
1995 : }
1996 0 : if (dce_call->fault_code != 0) {
1997 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddJob\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
1998 : }
1999 0 : break;
2000 : }
2001 0 : case 25: { /* spoolss_ScheduleJob */
2002 0 : struct spoolss_ScheduleJob *r2 = (struct spoolss_ScheduleJob *)r;
2003 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2004 0 : DEBUG(5,("function spoolss_ScheduleJob replied async\n"));
2005 : }
2006 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2007 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ScheduleJob, NDR_OUT | NDR_SET_VALUES, r2);
2008 : }
2009 0 : if (dce_call->fault_code != 0) {
2010 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ScheduleJob\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2011 : }
2012 0 : break;
2013 : }
2014 0 : case 26: { /* spoolss_GetPrinterData */
2015 0 : struct spoolss_GetPrinterData *r2 = (struct spoolss_GetPrinterData *)r;
2016 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2017 0 : DEBUG(5,("function spoolss_GetPrinterData replied async\n"));
2018 : }
2019 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2020 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterData, NDR_OUT | NDR_SET_VALUES, r2);
2021 : }
2022 0 : if (dce_call->fault_code != 0) {
2023 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinterData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2024 : }
2025 0 : break;
2026 : }
2027 0 : case 27: { /* spoolss_SetPrinterData */
2028 0 : struct spoolss_SetPrinterData *r2 = (struct spoolss_SetPrinterData *)r;
2029 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2030 0 : DEBUG(5,("function spoolss_SetPrinterData replied async\n"));
2031 : }
2032 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2033 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPrinterData, NDR_OUT | NDR_SET_VALUES, r2);
2034 : }
2035 0 : if (dce_call->fault_code != 0) {
2036 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetPrinterData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2037 : }
2038 0 : break;
2039 : }
2040 0 : case 28: { /* spoolss_WaitForPrinterChange */
2041 0 : struct spoolss_WaitForPrinterChange *r2 = (struct spoolss_WaitForPrinterChange *)r;
2042 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2043 0 : DEBUG(5,("function spoolss_WaitForPrinterChange replied async\n"));
2044 : }
2045 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2046 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_WaitForPrinterChange, NDR_OUT | NDR_SET_VALUES, r2);
2047 : }
2048 0 : if (dce_call->fault_code != 0) {
2049 0 : DBG_WARNING("dcerpc_fault %s in spoolss_WaitForPrinterChange\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2050 : }
2051 0 : break;
2052 : }
2053 2 : case 29: { /* spoolss_ClosePrinter */
2054 2 : struct spoolss_ClosePrinter *r2 = (struct spoolss_ClosePrinter *)r;
2055 2 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2056 0 : DEBUG(5,("function spoolss_ClosePrinter replied async\n"));
2057 : }
2058 2 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2059 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ClosePrinter, NDR_OUT | NDR_SET_VALUES, r2);
2060 : }
2061 2 : if (dce_call->fault_code != 0) {
2062 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ClosePrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2063 : }
2064 2 : break;
2065 : }
2066 0 : case 30: { /* spoolss_AddForm */
2067 0 : struct spoolss_AddForm *r2 = (struct spoolss_AddForm *)r;
2068 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2069 0 : DEBUG(5,("function spoolss_AddForm replied async\n"));
2070 : }
2071 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2072 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddForm, NDR_OUT | NDR_SET_VALUES, r2);
2073 : }
2074 0 : if (dce_call->fault_code != 0) {
2075 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddForm\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2076 : }
2077 0 : break;
2078 : }
2079 0 : case 31: { /* spoolss_DeleteForm */
2080 0 : struct spoolss_DeleteForm *r2 = (struct spoolss_DeleteForm *)r;
2081 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2082 0 : DEBUG(5,("function spoolss_DeleteForm replied async\n"));
2083 : }
2084 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2085 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeleteForm, NDR_OUT | NDR_SET_VALUES, r2);
2086 : }
2087 0 : if (dce_call->fault_code != 0) {
2088 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeleteForm\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2089 : }
2090 0 : break;
2091 : }
2092 0 : case 32: { /* spoolss_GetForm */
2093 0 : struct spoolss_GetForm *r2 = (struct spoolss_GetForm *)r;
2094 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2095 0 : DEBUG(5,("function spoolss_GetForm replied async\n"));
2096 : }
2097 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2098 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetForm, NDR_OUT | NDR_SET_VALUES, r2);
2099 : }
2100 0 : if (dce_call->fault_code != 0) {
2101 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetForm\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2102 : }
2103 0 : break;
2104 : }
2105 0 : case 33: { /* spoolss_SetForm */
2106 0 : struct spoolss_SetForm *r2 = (struct spoolss_SetForm *)r;
2107 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2108 0 : DEBUG(5,("function spoolss_SetForm replied async\n"));
2109 : }
2110 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2111 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetForm, NDR_OUT | NDR_SET_VALUES, r2);
2112 : }
2113 0 : if (dce_call->fault_code != 0) {
2114 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetForm\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2115 : }
2116 0 : break;
2117 : }
2118 0 : case 34: { /* spoolss_EnumForms */
2119 0 : struct spoolss_EnumForms *r2 = (struct spoolss_EnumForms *)r;
2120 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2121 0 : DEBUG(5,("function spoolss_EnumForms replied async\n"));
2122 : }
2123 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2124 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumForms, NDR_OUT | NDR_SET_VALUES, r2);
2125 : }
2126 0 : if (dce_call->fault_code != 0) {
2127 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumForms\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2128 : }
2129 0 : break;
2130 : }
2131 0 : case 35: { /* spoolss_EnumPorts */
2132 0 : struct spoolss_EnumPorts *r2 = (struct spoolss_EnumPorts *)r;
2133 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2134 0 : DEBUG(5,("function spoolss_EnumPorts replied async\n"));
2135 : }
2136 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2137 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPorts, NDR_OUT | NDR_SET_VALUES, r2);
2138 : }
2139 0 : if (dce_call->fault_code != 0) {
2140 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPorts\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2141 : }
2142 0 : break;
2143 : }
2144 0 : case 36: { /* spoolss_EnumMonitors */
2145 0 : struct spoolss_EnumMonitors *r2 = (struct spoolss_EnumMonitors *)r;
2146 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2147 0 : DEBUG(5,("function spoolss_EnumMonitors replied async\n"));
2148 : }
2149 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2150 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumMonitors, NDR_OUT | NDR_SET_VALUES, r2);
2151 : }
2152 0 : if (dce_call->fault_code != 0) {
2153 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumMonitors\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2154 : }
2155 0 : break;
2156 : }
2157 0 : case 37: { /* spoolss_AddPort */
2158 0 : struct spoolss_AddPort *r2 = (struct spoolss_AddPort *)r;
2159 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2160 0 : DEBUG(5,("function spoolss_AddPort replied async\n"));
2161 : }
2162 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2163 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPort, NDR_OUT | NDR_SET_VALUES, r2);
2164 : }
2165 0 : if (dce_call->fault_code != 0) {
2166 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPort\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2167 : }
2168 0 : break;
2169 : }
2170 0 : case 38: { /* spoolss_ConfigurePort */
2171 0 : struct spoolss_ConfigurePort *r2 = (struct spoolss_ConfigurePort *)r;
2172 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2173 0 : DEBUG(5,("function spoolss_ConfigurePort replied async\n"));
2174 : }
2175 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2176 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ConfigurePort, NDR_OUT | NDR_SET_VALUES, r2);
2177 : }
2178 0 : if (dce_call->fault_code != 0) {
2179 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ConfigurePort\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2180 : }
2181 0 : break;
2182 : }
2183 0 : case 39: { /* spoolss_DeletePort */
2184 0 : struct spoolss_DeletePort *r2 = (struct spoolss_DeletePort *)r;
2185 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2186 0 : DEBUG(5,("function spoolss_DeletePort replied async\n"));
2187 : }
2188 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2189 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePort, NDR_OUT | NDR_SET_VALUES, r2);
2190 : }
2191 0 : if (dce_call->fault_code != 0) {
2192 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePort\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2193 : }
2194 0 : break;
2195 : }
2196 0 : case 40: { /* spoolss_CreatePrinterIC */
2197 0 : struct spoolss_CreatePrinterIC *r2 = (struct spoolss_CreatePrinterIC *)r;
2198 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2199 0 : DEBUG(5,("function spoolss_CreatePrinterIC replied async\n"));
2200 : }
2201 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2202 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_CreatePrinterIC, NDR_OUT | NDR_SET_VALUES, r2);
2203 : }
2204 0 : if (dce_call->fault_code != 0) {
2205 0 : DBG_WARNING("dcerpc_fault %s in spoolss_CreatePrinterIC\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2206 : }
2207 0 : break;
2208 : }
2209 0 : case 41: { /* spoolss_PlayGDIScriptOnPrinterIC */
2210 0 : struct spoolss_PlayGDIScriptOnPrinterIC *r2 = (struct spoolss_PlayGDIScriptOnPrinterIC *)r;
2211 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2212 0 : DEBUG(5,("function spoolss_PlayGDIScriptOnPrinterIC replied async\n"));
2213 : }
2214 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2215 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_PlayGDIScriptOnPrinterIC, NDR_OUT | NDR_SET_VALUES, r2);
2216 : }
2217 0 : if (dce_call->fault_code != 0) {
2218 0 : DBG_WARNING("dcerpc_fault %s in spoolss_PlayGDIScriptOnPrinterIC\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2219 : }
2220 0 : break;
2221 : }
2222 0 : case 42: { /* spoolss_DeletePrinterIC */
2223 0 : struct spoolss_DeletePrinterIC *r2 = (struct spoolss_DeletePrinterIC *)r;
2224 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2225 0 : DEBUG(5,("function spoolss_DeletePrinterIC replied async\n"));
2226 : }
2227 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2228 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterIC, NDR_OUT | NDR_SET_VALUES, r2);
2229 : }
2230 0 : if (dce_call->fault_code != 0) {
2231 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterIC\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2232 : }
2233 0 : break;
2234 : }
2235 0 : case 43: { /* spoolss_AddPrinterConnection */
2236 0 : struct spoolss_AddPrinterConnection *r2 = (struct spoolss_AddPrinterConnection *)r;
2237 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2238 0 : DEBUG(5,("function spoolss_AddPrinterConnection replied async\n"));
2239 : }
2240 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2241 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterConnection, NDR_OUT | NDR_SET_VALUES, r2);
2242 : }
2243 0 : if (dce_call->fault_code != 0) {
2244 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrinterConnection\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2245 : }
2246 0 : break;
2247 : }
2248 0 : case 44: { /* spoolss_DeletePrinterConnection */
2249 0 : struct spoolss_DeletePrinterConnection *r2 = (struct spoolss_DeletePrinterConnection *)r;
2250 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2251 0 : DEBUG(5,("function spoolss_DeletePrinterConnection replied async\n"));
2252 : }
2253 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2254 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterConnection, NDR_OUT | NDR_SET_VALUES, r2);
2255 : }
2256 0 : if (dce_call->fault_code != 0) {
2257 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterConnection\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2258 : }
2259 0 : break;
2260 : }
2261 0 : case 45: { /* spoolss_PrinterMessageBox */
2262 0 : struct spoolss_PrinterMessageBox *r2 = (struct spoolss_PrinterMessageBox *)r;
2263 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2264 0 : DEBUG(5,("function spoolss_PrinterMessageBox replied async\n"));
2265 : }
2266 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2267 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_PrinterMessageBox, NDR_OUT | NDR_SET_VALUES, r2);
2268 : }
2269 0 : if (dce_call->fault_code != 0) {
2270 0 : DBG_WARNING("dcerpc_fault %s in spoolss_PrinterMessageBox\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2271 : }
2272 0 : break;
2273 : }
2274 0 : case 46: { /* spoolss_AddMonitor */
2275 0 : struct spoolss_AddMonitor *r2 = (struct spoolss_AddMonitor *)r;
2276 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2277 0 : DEBUG(5,("function spoolss_AddMonitor replied async\n"));
2278 : }
2279 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2280 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddMonitor, NDR_OUT | NDR_SET_VALUES, r2);
2281 : }
2282 0 : if (dce_call->fault_code != 0) {
2283 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddMonitor\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2284 : }
2285 0 : break;
2286 : }
2287 0 : case 47: { /* spoolss_DeleteMonitor */
2288 0 : struct spoolss_DeleteMonitor *r2 = (struct spoolss_DeleteMonitor *)r;
2289 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2290 0 : DEBUG(5,("function spoolss_DeleteMonitor replied async\n"));
2291 : }
2292 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2293 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeleteMonitor, NDR_OUT | NDR_SET_VALUES, r2);
2294 : }
2295 0 : if (dce_call->fault_code != 0) {
2296 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeleteMonitor\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2297 : }
2298 0 : break;
2299 : }
2300 0 : case 48: { /* spoolss_DeletePrintProcessor */
2301 0 : struct spoolss_DeletePrintProcessor *r2 = (struct spoolss_DeletePrintProcessor *)r;
2302 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2303 0 : DEBUG(5,("function spoolss_DeletePrintProcessor replied async\n"));
2304 : }
2305 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2306 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrintProcessor, NDR_OUT | NDR_SET_VALUES, r2);
2307 : }
2308 0 : if (dce_call->fault_code != 0) {
2309 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrintProcessor\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2310 : }
2311 0 : break;
2312 : }
2313 0 : case 49: { /* spoolss_AddPrintProvidor */
2314 0 : struct spoolss_AddPrintProvidor *r2 = (struct spoolss_AddPrintProvidor *)r;
2315 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2316 0 : DEBUG(5,("function spoolss_AddPrintProvidor replied async\n"));
2317 : }
2318 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2319 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrintProvidor, NDR_OUT | NDR_SET_VALUES, r2);
2320 : }
2321 0 : if (dce_call->fault_code != 0) {
2322 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrintProvidor\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2323 : }
2324 0 : break;
2325 : }
2326 0 : case 50: { /* spoolss_DeletePrintProvidor */
2327 0 : struct spoolss_DeletePrintProvidor *r2 = (struct spoolss_DeletePrintProvidor *)r;
2328 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2329 0 : DEBUG(5,("function spoolss_DeletePrintProvidor replied async\n"));
2330 : }
2331 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2332 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrintProvidor, NDR_OUT | NDR_SET_VALUES, r2);
2333 : }
2334 0 : if (dce_call->fault_code != 0) {
2335 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrintProvidor\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2336 : }
2337 0 : break;
2338 : }
2339 0 : case 51: { /* spoolss_EnumPrintProcessorDataTypes */
2340 0 : struct spoolss_EnumPrintProcessorDataTypes *r2 = (struct spoolss_EnumPrintProcessorDataTypes *)r;
2341 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2342 0 : DEBUG(5,("function spoolss_EnumPrintProcessorDataTypes replied async\n"));
2343 : }
2344 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2345 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrintProcessorDataTypes, NDR_OUT | NDR_SET_VALUES, r2);
2346 : }
2347 0 : if (dce_call->fault_code != 0) {
2348 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrintProcessorDataTypes\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2349 : }
2350 0 : break;
2351 : }
2352 0 : case 52: { /* spoolss_ResetPrinter */
2353 0 : struct spoolss_ResetPrinter *r2 = (struct spoolss_ResetPrinter *)r;
2354 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2355 0 : DEBUG(5,("function spoolss_ResetPrinter replied async\n"));
2356 : }
2357 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2358 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ResetPrinter, NDR_OUT | NDR_SET_VALUES, r2);
2359 : }
2360 0 : if (dce_call->fault_code != 0) {
2361 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ResetPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2362 : }
2363 0 : break;
2364 : }
2365 0 : case 53: { /* spoolss_GetPrinterDriver2 */
2366 0 : struct spoolss_GetPrinterDriver2 *r2 = (struct spoolss_GetPrinterDriver2 *)r;
2367 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2368 0 : DEBUG(5,("function spoolss_GetPrinterDriver2 replied async\n"));
2369 : }
2370 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2371 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriver2, NDR_OUT | NDR_SET_VALUES, r2);
2372 : }
2373 0 : if (dce_call->fault_code != 0) {
2374 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinterDriver2\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2375 : }
2376 0 : break;
2377 : }
2378 0 : case 54: { /* spoolss_FindFirstPrinterChangeNotification */
2379 0 : struct spoolss_FindFirstPrinterChangeNotification *r2 = (struct spoolss_FindFirstPrinterChangeNotification *)r;
2380 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2381 0 : DEBUG(5,("function spoolss_FindFirstPrinterChangeNotification replied async\n"));
2382 : }
2383 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2384 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_FindFirstPrinterChangeNotification, NDR_OUT | NDR_SET_VALUES, r2);
2385 : }
2386 0 : if (dce_call->fault_code != 0) {
2387 0 : DBG_WARNING("dcerpc_fault %s in spoolss_FindFirstPrinterChangeNotification\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2388 : }
2389 0 : break;
2390 : }
2391 0 : case 55: { /* spoolss_FindNextPrinterChangeNotification */
2392 0 : struct spoolss_FindNextPrinterChangeNotification *r2 = (struct spoolss_FindNextPrinterChangeNotification *)r;
2393 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2394 0 : DEBUG(5,("function spoolss_FindNextPrinterChangeNotification replied async\n"));
2395 : }
2396 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2397 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_FindNextPrinterChangeNotification, NDR_OUT | NDR_SET_VALUES, r2);
2398 : }
2399 0 : if (dce_call->fault_code != 0) {
2400 0 : DBG_WARNING("dcerpc_fault %s in spoolss_FindNextPrinterChangeNotification\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2401 : }
2402 0 : break;
2403 : }
2404 0 : case 56: { /* spoolss_FindClosePrinterNotify */
2405 0 : struct spoolss_FindClosePrinterNotify *r2 = (struct spoolss_FindClosePrinterNotify *)r;
2406 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2407 0 : DEBUG(5,("function spoolss_FindClosePrinterNotify replied async\n"));
2408 : }
2409 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2410 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_FindClosePrinterNotify, NDR_OUT | NDR_SET_VALUES, r2);
2411 : }
2412 0 : if (dce_call->fault_code != 0) {
2413 0 : DBG_WARNING("dcerpc_fault %s in spoolss_FindClosePrinterNotify\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2414 : }
2415 0 : break;
2416 : }
2417 0 : case 57: { /* spoolss_RouterFindFirstPrinterChangeNotificationOld */
2418 0 : struct spoolss_RouterFindFirstPrinterChangeNotificationOld *r2 = (struct spoolss_RouterFindFirstPrinterChangeNotificationOld *)r;
2419 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2420 0 : DEBUG(5,("function spoolss_RouterFindFirstPrinterChangeNotificationOld replied async\n"));
2421 : }
2422 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2423 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterFindFirstPrinterChangeNotificationOld, NDR_OUT | NDR_SET_VALUES, r2);
2424 : }
2425 0 : if (dce_call->fault_code != 0) {
2426 0 : DBG_WARNING("dcerpc_fault %s in spoolss_RouterFindFirstPrinterChangeNotificationOld\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2427 : }
2428 0 : break;
2429 : }
2430 0 : case 58: { /* spoolss_ReplyOpenPrinter */
2431 0 : struct spoolss_ReplyOpenPrinter *r2 = (struct spoolss_ReplyOpenPrinter *)r;
2432 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2433 0 : DEBUG(5,("function spoolss_ReplyOpenPrinter replied async\n"));
2434 : }
2435 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2436 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ReplyOpenPrinter, NDR_OUT | NDR_SET_VALUES, r2);
2437 : }
2438 0 : if (dce_call->fault_code != 0) {
2439 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ReplyOpenPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2440 : }
2441 0 : break;
2442 : }
2443 0 : case 59: { /* spoolss_RouterReplyPrinter */
2444 0 : struct spoolss_RouterReplyPrinter *r2 = (struct spoolss_RouterReplyPrinter *)r;
2445 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2446 0 : DEBUG(5,("function spoolss_RouterReplyPrinter replied async\n"));
2447 : }
2448 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2449 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterReplyPrinter, NDR_OUT | NDR_SET_VALUES, r2);
2450 : }
2451 0 : if (dce_call->fault_code != 0) {
2452 0 : DBG_WARNING("dcerpc_fault %s in spoolss_RouterReplyPrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2453 : }
2454 0 : break;
2455 : }
2456 0 : case 60: { /* spoolss_ReplyClosePrinter */
2457 0 : struct spoolss_ReplyClosePrinter *r2 = (struct spoolss_ReplyClosePrinter *)r;
2458 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2459 0 : DEBUG(5,("function spoolss_ReplyClosePrinter replied async\n"));
2460 : }
2461 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2462 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ReplyClosePrinter, NDR_OUT | NDR_SET_VALUES, r2);
2463 : }
2464 0 : if (dce_call->fault_code != 0) {
2465 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ReplyClosePrinter\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2466 : }
2467 0 : break;
2468 : }
2469 0 : case 61: { /* spoolss_AddPortEx */
2470 0 : struct spoolss_AddPortEx *r2 = (struct spoolss_AddPortEx *)r;
2471 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2472 0 : DEBUG(5,("function spoolss_AddPortEx replied async\n"));
2473 : }
2474 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2475 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPortEx, NDR_OUT | NDR_SET_VALUES, r2);
2476 : }
2477 0 : if (dce_call->fault_code != 0) {
2478 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPortEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2479 : }
2480 0 : break;
2481 : }
2482 0 : case 62: { /* spoolss_RouterFindFirstPrinterChangeNotification */
2483 0 : struct spoolss_RouterFindFirstPrinterChangeNotification *r2 = (struct spoolss_RouterFindFirstPrinterChangeNotification *)r;
2484 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2485 0 : DEBUG(5,("function spoolss_RouterFindFirstPrinterChangeNotification replied async\n"));
2486 : }
2487 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2488 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterFindFirstPrinterChangeNotification, NDR_OUT | NDR_SET_VALUES, r2);
2489 : }
2490 0 : if (dce_call->fault_code != 0) {
2491 0 : DBG_WARNING("dcerpc_fault %s in spoolss_RouterFindFirstPrinterChangeNotification\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2492 : }
2493 0 : break;
2494 : }
2495 0 : case 63: { /* spoolss_SpoolerInit */
2496 0 : struct spoolss_SpoolerInit *r2 = (struct spoolss_SpoolerInit *)r;
2497 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2498 0 : DEBUG(5,("function spoolss_SpoolerInit replied async\n"));
2499 : }
2500 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2501 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SpoolerInit, NDR_OUT | NDR_SET_VALUES, r2);
2502 : }
2503 0 : if (dce_call->fault_code != 0) {
2504 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SpoolerInit\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2505 : }
2506 0 : break;
2507 : }
2508 0 : case 64: { /* spoolss_ResetPrinterEx */
2509 0 : struct spoolss_ResetPrinterEx *r2 = (struct spoolss_ResetPrinterEx *)r;
2510 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2511 0 : DEBUG(5,("function spoolss_ResetPrinterEx replied async\n"));
2512 : }
2513 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2514 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_ResetPrinterEx, NDR_OUT | NDR_SET_VALUES, r2);
2515 : }
2516 0 : if (dce_call->fault_code != 0) {
2517 0 : DBG_WARNING("dcerpc_fault %s in spoolss_ResetPrinterEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2518 : }
2519 0 : break;
2520 : }
2521 2 : case 65: { /* spoolss_RemoteFindFirstPrinterChangeNotifyEx */
2522 2 : struct spoolss_RemoteFindFirstPrinterChangeNotifyEx *r2 = (struct spoolss_RemoteFindFirstPrinterChangeNotifyEx *)r;
2523 2 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2524 0 : DEBUG(5,("function spoolss_RemoteFindFirstPrinterChangeNotifyEx replied async\n"));
2525 : }
2526 2 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2527 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RemoteFindFirstPrinterChangeNotifyEx, NDR_OUT | NDR_SET_VALUES, r2);
2528 : }
2529 2 : if (dce_call->fault_code != 0) {
2530 0 : DBG_WARNING("dcerpc_fault %s in spoolss_RemoteFindFirstPrinterChangeNotifyEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2531 : }
2532 2 : break;
2533 : }
2534 0 : case 66: { /* spoolss_RouterReplyPrinterEx */
2535 0 : struct spoolss_RouterReplyPrinterEx *r2 = (struct spoolss_RouterReplyPrinterEx *)r;
2536 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2537 0 : DEBUG(5,("function spoolss_RouterReplyPrinterEx replied async\n"));
2538 : }
2539 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2540 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterReplyPrinterEx, NDR_OUT | NDR_SET_VALUES, r2);
2541 : }
2542 0 : if (dce_call->fault_code != 0) {
2543 0 : DBG_WARNING("dcerpc_fault %s in spoolss_RouterReplyPrinterEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2544 : }
2545 0 : break;
2546 : }
2547 4 : case 67: { /* spoolss_RouterRefreshPrinterChangeNotify */
2548 4 : struct spoolss_RouterRefreshPrinterChangeNotify *r2 = (struct spoolss_RouterRefreshPrinterChangeNotify *)r;
2549 4 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2550 0 : DEBUG(5,("function spoolss_RouterRefreshPrinterChangeNotify replied async\n"));
2551 : }
2552 4 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2553 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_RouterRefreshPrinterChangeNotify, NDR_OUT | NDR_SET_VALUES, r2);
2554 : }
2555 4 : if (dce_call->fault_code != 0) {
2556 0 : DBG_WARNING("dcerpc_fault %s in spoolss_RouterRefreshPrinterChangeNotify\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2557 : }
2558 4 : break;
2559 : }
2560 0 : case 68: { /* spoolss_44 */
2561 0 : struct spoolss_44 *r2 = (struct spoolss_44 *)r;
2562 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2563 0 : DEBUG(5,("function spoolss_44 replied async\n"));
2564 : }
2565 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2566 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_44, NDR_OUT | NDR_SET_VALUES, r2);
2567 : }
2568 0 : if (dce_call->fault_code != 0) {
2569 0 : DBG_WARNING("dcerpc_fault %s in spoolss_44\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2570 : }
2571 0 : break;
2572 : }
2573 0 : case 69: { /* spoolss_OpenPrinterEx */
2574 0 : struct spoolss_OpenPrinterEx *r2 = (struct spoolss_OpenPrinterEx *)r;
2575 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2576 0 : DEBUG(5,("function spoolss_OpenPrinterEx replied async\n"));
2577 : }
2578 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2579 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_OpenPrinterEx, NDR_OUT | NDR_SET_VALUES, r2);
2580 : }
2581 0 : if (dce_call->fault_code != 0) {
2582 0 : DBG_WARNING("dcerpc_fault %s in spoolss_OpenPrinterEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2583 : }
2584 0 : break;
2585 : }
2586 0 : case 70: { /* spoolss_AddPrinterEx */
2587 0 : struct spoolss_AddPrinterEx *r2 = (struct spoolss_AddPrinterEx *)r;
2588 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2589 0 : DEBUG(5,("function spoolss_AddPrinterEx replied async\n"));
2590 : }
2591 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2592 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterEx, NDR_OUT | NDR_SET_VALUES, r2);
2593 : }
2594 0 : if (dce_call->fault_code != 0) {
2595 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrinterEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2596 : }
2597 0 : break;
2598 : }
2599 0 : case 71: { /* spoolss_SetPort */
2600 0 : struct spoolss_SetPort *r2 = (struct spoolss_SetPort *)r;
2601 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2602 0 : DEBUG(5,("function spoolss_SetPort replied async\n"));
2603 : }
2604 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2605 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPort, NDR_OUT | NDR_SET_VALUES, r2);
2606 : }
2607 0 : if (dce_call->fault_code != 0) {
2608 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetPort\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2609 : }
2610 0 : break;
2611 : }
2612 0 : case 72: { /* spoolss_EnumPrinterData */
2613 0 : struct spoolss_EnumPrinterData *r2 = (struct spoolss_EnumPrinterData *)r;
2614 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2615 0 : DEBUG(5,("function spoolss_EnumPrinterData replied async\n"));
2616 : }
2617 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2618 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterData, NDR_OUT | NDR_SET_VALUES, r2);
2619 : }
2620 0 : if (dce_call->fault_code != 0) {
2621 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrinterData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2622 : }
2623 0 : break;
2624 : }
2625 0 : case 73: { /* spoolss_DeletePrinterData */
2626 0 : struct spoolss_DeletePrinterData *r2 = (struct spoolss_DeletePrinterData *)r;
2627 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2628 0 : DEBUG(5,("function spoolss_DeletePrinterData replied async\n"));
2629 : }
2630 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2631 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterData, NDR_OUT | NDR_SET_VALUES, r2);
2632 : }
2633 0 : if (dce_call->fault_code != 0) {
2634 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2635 : }
2636 0 : break;
2637 : }
2638 0 : case 74: { /* spoolss_4a */
2639 0 : struct spoolss_4a *r2 = (struct spoolss_4a *)r;
2640 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2641 0 : DEBUG(5,("function spoolss_4a replied async\n"));
2642 : }
2643 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2644 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_4a, NDR_OUT | NDR_SET_VALUES, r2);
2645 : }
2646 0 : if (dce_call->fault_code != 0) {
2647 0 : DBG_WARNING("dcerpc_fault %s in spoolss_4a\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2648 : }
2649 0 : break;
2650 : }
2651 0 : case 75: { /* spoolss_4b */
2652 0 : struct spoolss_4b *r2 = (struct spoolss_4b *)r;
2653 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2654 0 : DEBUG(5,("function spoolss_4b replied async\n"));
2655 : }
2656 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2657 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_4b, NDR_OUT | NDR_SET_VALUES, r2);
2658 : }
2659 0 : if (dce_call->fault_code != 0) {
2660 0 : DBG_WARNING("dcerpc_fault %s in spoolss_4b\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2661 : }
2662 0 : break;
2663 : }
2664 0 : case 76: { /* spoolss_4c */
2665 0 : struct spoolss_4c *r2 = (struct spoolss_4c *)r;
2666 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2667 0 : DEBUG(5,("function spoolss_4c replied async\n"));
2668 : }
2669 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2670 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_4c, NDR_OUT | NDR_SET_VALUES, r2);
2671 : }
2672 0 : if (dce_call->fault_code != 0) {
2673 0 : DBG_WARNING("dcerpc_fault %s in spoolss_4c\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2674 : }
2675 0 : break;
2676 : }
2677 0 : case 77: { /* spoolss_SetPrinterDataEx */
2678 0 : struct spoolss_SetPrinterDataEx *r2 = (struct spoolss_SetPrinterDataEx *)r;
2679 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2680 0 : DEBUG(5,("function spoolss_SetPrinterDataEx replied async\n"));
2681 : }
2682 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2683 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetPrinterDataEx, NDR_OUT | NDR_SET_VALUES, r2);
2684 : }
2685 0 : if (dce_call->fault_code != 0) {
2686 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetPrinterDataEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2687 : }
2688 0 : break;
2689 : }
2690 0 : case 78: { /* spoolss_GetPrinterDataEx */
2691 0 : struct spoolss_GetPrinterDataEx *r2 = (struct spoolss_GetPrinterDataEx *)r;
2692 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2693 0 : DEBUG(5,("function spoolss_GetPrinterDataEx replied async\n"));
2694 : }
2695 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2696 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDataEx, NDR_OUT | NDR_SET_VALUES, r2);
2697 : }
2698 0 : if (dce_call->fault_code != 0) {
2699 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinterDataEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2700 : }
2701 0 : break;
2702 : }
2703 0 : case 79: { /* spoolss_EnumPrinterDataEx */
2704 0 : struct spoolss_EnumPrinterDataEx *r2 = (struct spoolss_EnumPrinterDataEx *)r;
2705 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2706 0 : DEBUG(5,("function spoolss_EnumPrinterDataEx replied async\n"));
2707 : }
2708 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2709 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterDataEx, NDR_OUT | NDR_SET_VALUES, r2);
2710 : }
2711 0 : if (dce_call->fault_code != 0) {
2712 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrinterDataEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2713 : }
2714 0 : break;
2715 : }
2716 0 : case 80: { /* spoolss_EnumPrinterKey */
2717 0 : struct spoolss_EnumPrinterKey *r2 = (struct spoolss_EnumPrinterKey *)r;
2718 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2719 0 : DEBUG(5,("function spoolss_EnumPrinterKey replied async\n"));
2720 : }
2721 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2722 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPrinterKey, NDR_OUT | NDR_SET_VALUES, r2);
2723 : }
2724 0 : if (dce_call->fault_code != 0) {
2725 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPrinterKey\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2726 : }
2727 0 : break;
2728 : }
2729 0 : case 81: { /* spoolss_DeletePrinterDataEx */
2730 0 : struct spoolss_DeletePrinterDataEx *r2 = (struct spoolss_DeletePrinterDataEx *)r;
2731 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2732 0 : DEBUG(5,("function spoolss_DeletePrinterDataEx replied async\n"));
2733 : }
2734 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2735 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterDataEx, NDR_OUT | NDR_SET_VALUES, r2);
2736 : }
2737 0 : if (dce_call->fault_code != 0) {
2738 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterDataEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2739 : }
2740 0 : break;
2741 : }
2742 0 : case 82: { /* spoolss_DeletePrinterKey */
2743 0 : struct spoolss_DeletePrinterKey *r2 = (struct spoolss_DeletePrinterKey *)r;
2744 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2745 0 : DEBUG(5,("function spoolss_DeletePrinterKey replied async\n"));
2746 : }
2747 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2748 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterKey, NDR_OUT | NDR_SET_VALUES, r2);
2749 : }
2750 0 : if (dce_call->fault_code != 0) {
2751 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterKey\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2752 : }
2753 0 : break;
2754 : }
2755 0 : case 83: { /* spoolss_53 */
2756 0 : struct spoolss_53 *r2 = (struct spoolss_53 *)r;
2757 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2758 0 : DEBUG(5,("function spoolss_53 replied async\n"));
2759 : }
2760 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2761 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_53, NDR_OUT | NDR_SET_VALUES, r2);
2762 : }
2763 0 : if (dce_call->fault_code != 0) {
2764 0 : DBG_WARNING("dcerpc_fault %s in spoolss_53\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2765 : }
2766 0 : break;
2767 : }
2768 0 : case 84: { /* spoolss_DeletePrinterDriverEx */
2769 0 : struct spoolss_DeletePrinterDriverEx *r2 = (struct spoolss_DeletePrinterDriverEx *)r;
2770 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2771 0 : DEBUG(5,("function spoolss_DeletePrinterDriverEx replied async\n"));
2772 : }
2773 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2774 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePrinterDriverEx, NDR_OUT | NDR_SET_VALUES, r2);
2775 : }
2776 0 : if (dce_call->fault_code != 0) {
2777 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePrinterDriverEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2778 : }
2779 0 : break;
2780 : }
2781 0 : case 85: { /* spoolss_AddPerMachineConnection */
2782 0 : struct spoolss_AddPerMachineConnection *r2 = (struct spoolss_AddPerMachineConnection *)r;
2783 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2784 0 : DEBUG(5,("function spoolss_AddPerMachineConnection replied async\n"));
2785 : }
2786 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2787 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPerMachineConnection, NDR_OUT | NDR_SET_VALUES, r2);
2788 : }
2789 0 : if (dce_call->fault_code != 0) {
2790 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPerMachineConnection\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2791 : }
2792 0 : break;
2793 : }
2794 0 : case 86: { /* spoolss_DeletePerMachineConnection */
2795 0 : struct spoolss_DeletePerMachineConnection *r2 = (struct spoolss_DeletePerMachineConnection *)r;
2796 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2797 0 : DEBUG(5,("function spoolss_DeletePerMachineConnection replied async\n"));
2798 : }
2799 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2800 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeletePerMachineConnection, NDR_OUT | NDR_SET_VALUES, r2);
2801 : }
2802 0 : if (dce_call->fault_code != 0) {
2803 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeletePerMachineConnection\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2804 : }
2805 0 : break;
2806 : }
2807 0 : case 87: { /* spoolss_EnumPerMachineConnections */
2808 0 : struct spoolss_EnumPerMachineConnections *r2 = (struct spoolss_EnumPerMachineConnections *)r;
2809 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2810 0 : DEBUG(5,("function spoolss_EnumPerMachineConnections replied async\n"));
2811 : }
2812 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2813 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumPerMachineConnections, NDR_OUT | NDR_SET_VALUES, r2);
2814 : }
2815 0 : if (dce_call->fault_code != 0) {
2816 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumPerMachineConnections\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2817 : }
2818 0 : break;
2819 : }
2820 0 : case 88: { /* spoolss_XcvData */
2821 0 : struct spoolss_XcvData *r2 = (struct spoolss_XcvData *)r;
2822 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2823 0 : DEBUG(5,("function spoolss_XcvData replied async\n"));
2824 : }
2825 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2826 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_XcvData, NDR_OUT | NDR_SET_VALUES, r2);
2827 : }
2828 0 : if (dce_call->fault_code != 0) {
2829 0 : DBG_WARNING("dcerpc_fault %s in spoolss_XcvData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2830 : }
2831 0 : break;
2832 : }
2833 0 : case 89: { /* spoolss_AddPrinterDriverEx */
2834 0 : struct spoolss_AddPrinterDriverEx *r2 = (struct spoolss_AddPrinterDriverEx *)r;
2835 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2836 0 : DEBUG(5,("function spoolss_AddPrinterDriverEx replied async\n"));
2837 : }
2838 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2839 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_AddPrinterDriverEx, NDR_OUT | NDR_SET_VALUES, r2);
2840 : }
2841 0 : if (dce_call->fault_code != 0) {
2842 0 : DBG_WARNING("dcerpc_fault %s in spoolss_AddPrinterDriverEx\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2843 : }
2844 0 : break;
2845 : }
2846 0 : case 90: { /* spoolss_5a */
2847 0 : struct spoolss_5a *r2 = (struct spoolss_5a *)r;
2848 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2849 0 : DEBUG(5,("function spoolss_5a replied async\n"));
2850 : }
2851 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2852 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5a, NDR_OUT | NDR_SET_VALUES, r2);
2853 : }
2854 0 : if (dce_call->fault_code != 0) {
2855 0 : DBG_WARNING("dcerpc_fault %s in spoolss_5a\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2856 : }
2857 0 : break;
2858 : }
2859 0 : case 91: { /* spoolss_5b */
2860 0 : struct spoolss_5b *r2 = (struct spoolss_5b *)r;
2861 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2862 0 : DEBUG(5,("function spoolss_5b replied async\n"));
2863 : }
2864 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2865 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5b, NDR_OUT | NDR_SET_VALUES, r2);
2866 : }
2867 0 : if (dce_call->fault_code != 0) {
2868 0 : DBG_WARNING("dcerpc_fault %s in spoolss_5b\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2869 : }
2870 0 : break;
2871 : }
2872 0 : case 92: { /* spoolss_5c */
2873 0 : struct spoolss_5c *r2 = (struct spoolss_5c *)r;
2874 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2875 0 : DEBUG(5,("function spoolss_5c replied async\n"));
2876 : }
2877 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2878 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5c, NDR_OUT | NDR_SET_VALUES, r2);
2879 : }
2880 0 : if (dce_call->fault_code != 0) {
2881 0 : DBG_WARNING("dcerpc_fault %s in spoolss_5c\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2882 : }
2883 0 : break;
2884 : }
2885 0 : case 93: { /* spoolss_5d */
2886 0 : struct spoolss_5d *r2 = (struct spoolss_5d *)r;
2887 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2888 0 : DEBUG(5,("function spoolss_5d replied async\n"));
2889 : }
2890 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2891 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5d, NDR_OUT | NDR_SET_VALUES, r2);
2892 : }
2893 0 : if (dce_call->fault_code != 0) {
2894 0 : DBG_WARNING("dcerpc_fault %s in spoolss_5d\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2895 : }
2896 0 : break;
2897 : }
2898 0 : case 94: { /* spoolss_5e */
2899 0 : struct spoolss_5e *r2 = (struct spoolss_5e *)r;
2900 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2901 0 : DEBUG(5,("function spoolss_5e replied async\n"));
2902 : }
2903 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2904 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5e, NDR_OUT | NDR_SET_VALUES, r2);
2905 : }
2906 0 : if (dce_call->fault_code != 0) {
2907 0 : DBG_WARNING("dcerpc_fault %s in spoolss_5e\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2908 : }
2909 0 : break;
2910 : }
2911 0 : case 95: { /* spoolss_5f */
2912 0 : struct spoolss_5f *r2 = (struct spoolss_5f *)r;
2913 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2914 0 : DEBUG(5,("function spoolss_5f replied async\n"));
2915 : }
2916 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2917 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_5f, NDR_OUT | NDR_SET_VALUES, r2);
2918 : }
2919 0 : if (dce_call->fault_code != 0) {
2920 0 : DBG_WARNING("dcerpc_fault %s in spoolss_5f\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2921 : }
2922 0 : break;
2923 : }
2924 0 : case 96: { /* spoolss_60 */
2925 0 : struct spoolss_60 *r2 = (struct spoolss_60 *)r;
2926 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2927 0 : DEBUG(5,("function spoolss_60 replied async\n"));
2928 : }
2929 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2930 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_60, NDR_OUT | NDR_SET_VALUES, r2);
2931 : }
2932 0 : if (dce_call->fault_code != 0) {
2933 0 : DBG_WARNING("dcerpc_fault %s in spoolss_60\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2934 : }
2935 0 : break;
2936 : }
2937 0 : case 97: { /* spoolss_SendRecvBidiData */
2938 0 : struct spoolss_SendRecvBidiData *r2 = (struct spoolss_SendRecvBidiData *)r;
2939 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2940 0 : DEBUG(5,("function spoolss_SendRecvBidiData replied async\n"));
2941 : }
2942 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2943 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SendRecvBidiData, NDR_OUT | NDR_SET_VALUES, r2);
2944 : }
2945 0 : if (dce_call->fault_code != 0) {
2946 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SendRecvBidiData\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2947 : }
2948 0 : break;
2949 : }
2950 0 : case 98: { /* spoolss_62 */
2951 0 : struct spoolss_62 *r2 = (struct spoolss_62 *)r;
2952 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2953 0 : DEBUG(5,("function spoolss_62 replied async\n"));
2954 : }
2955 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2956 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_62, NDR_OUT | NDR_SET_VALUES, r2);
2957 : }
2958 0 : if (dce_call->fault_code != 0) {
2959 0 : DBG_WARNING("dcerpc_fault %s in spoolss_62\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2960 : }
2961 0 : break;
2962 : }
2963 0 : case 99: { /* spoolss_63 */
2964 0 : struct spoolss_63 *r2 = (struct spoolss_63 *)r;
2965 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2966 0 : DEBUG(5,("function spoolss_63 replied async\n"));
2967 : }
2968 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2969 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_63, NDR_OUT | NDR_SET_VALUES, r2);
2970 : }
2971 0 : if (dce_call->fault_code != 0) {
2972 0 : DBG_WARNING("dcerpc_fault %s in spoolss_63\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2973 : }
2974 0 : break;
2975 : }
2976 0 : case 100: { /* spoolss_64 */
2977 0 : struct spoolss_64 *r2 = (struct spoolss_64 *)r;
2978 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2979 0 : DEBUG(5,("function spoolss_64 replied async\n"));
2980 : }
2981 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2982 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_64, NDR_OUT | NDR_SET_VALUES, r2);
2983 : }
2984 0 : if (dce_call->fault_code != 0) {
2985 0 : DBG_WARNING("dcerpc_fault %s in spoolss_64\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2986 : }
2987 0 : break;
2988 : }
2989 0 : case 101: { /* spoolss_65 */
2990 0 : struct spoolss_65 *r2 = (struct spoolss_65 *)r;
2991 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
2992 0 : DEBUG(5,("function spoolss_65 replied async\n"));
2993 : }
2994 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
2995 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_65, NDR_OUT | NDR_SET_VALUES, r2);
2996 : }
2997 0 : if (dce_call->fault_code != 0) {
2998 0 : DBG_WARNING("dcerpc_fault %s in spoolss_65\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
2999 : }
3000 0 : break;
3001 : }
3002 0 : case 102: { /* spoolss_GetCorePrinterDrivers */
3003 0 : struct spoolss_GetCorePrinterDrivers *r2 = (struct spoolss_GetCorePrinterDrivers *)r;
3004 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3005 0 : DEBUG(5,("function spoolss_GetCorePrinterDrivers replied async\n"));
3006 : }
3007 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3008 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetCorePrinterDrivers, NDR_OUT | NDR_SET_VALUES, r2);
3009 : }
3010 0 : if (dce_call->fault_code != 0) {
3011 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetCorePrinterDrivers\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3012 : }
3013 0 : break;
3014 : }
3015 0 : case 103: { /* spoolss_67 */
3016 0 : struct spoolss_67 *r2 = (struct spoolss_67 *)r;
3017 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3018 0 : DEBUG(5,("function spoolss_67 replied async\n"));
3019 : }
3020 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3021 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_67, NDR_OUT | NDR_SET_VALUES, r2);
3022 : }
3023 0 : if (dce_call->fault_code != 0) {
3024 0 : DBG_WARNING("dcerpc_fault %s in spoolss_67\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3025 : }
3026 0 : break;
3027 : }
3028 0 : case 104: { /* spoolss_GetPrinterDriverPackagePath */
3029 0 : struct spoolss_GetPrinterDriverPackagePath *r2 = (struct spoolss_GetPrinterDriverPackagePath *)r;
3030 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3031 0 : DEBUG(5,("function spoolss_GetPrinterDriverPackagePath replied async\n"));
3032 : }
3033 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3034 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetPrinterDriverPackagePath, NDR_OUT | NDR_SET_VALUES, r2);
3035 : }
3036 0 : if (dce_call->fault_code != 0) {
3037 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetPrinterDriverPackagePath\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3038 : }
3039 0 : break;
3040 : }
3041 0 : case 105: { /* spoolss_69 */
3042 0 : struct spoolss_69 *r2 = (struct spoolss_69 *)r;
3043 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3044 0 : DEBUG(5,("function spoolss_69 replied async\n"));
3045 : }
3046 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3047 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_69, NDR_OUT | NDR_SET_VALUES, r2);
3048 : }
3049 0 : if (dce_call->fault_code != 0) {
3050 0 : DBG_WARNING("dcerpc_fault %s in spoolss_69\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3051 : }
3052 0 : break;
3053 : }
3054 0 : case 106: { /* spoolss_6a */
3055 0 : struct spoolss_6a *r2 = (struct spoolss_6a *)r;
3056 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3057 0 : DEBUG(5,("function spoolss_6a replied async\n"));
3058 : }
3059 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3060 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6a, NDR_OUT | NDR_SET_VALUES, r2);
3061 : }
3062 0 : if (dce_call->fault_code != 0) {
3063 0 : DBG_WARNING("dcerpc_fault %s in spoolss_6a\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3064 : }
3065 0 : break;
3066 : }
3067 0 : case 107: { /* spoolss_6b */
3068 0 : struct spoolss_6b *r2 = (struct spoolss_6b *)r;
3069 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3070 0 : DEBUG(5,("function spoolss_6b replied async\n"));
3071 : }
3072 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3073 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6b, NDR_OUT | NDR_SET_VALUES, r2);
3074 : }
3075 0 : if (dce_call->fault_code != 0) {
3076 0 : DBG_WARNING("dcerpc_fault %s in spoolss_6b\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3077 : }
3078 0 : break;
3079 : }
3080 0 : case 108: { /* spoolss_6c */
3081 0 : struct spoolss_6c *r2 = (struct spoolss_6c *)r;
3082 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3083 0 : DEBUG(5,("function spoolss_6c replied async\n"));
3084 : }
3085 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3086 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6c, NDR_OUT | NDR_SET_VALUES, r2);
3087 : }
3088 0 : if (dce_call->fault_code != 0) {
3089 0 : DBG_WARNING("dcerpc_fault %s in spoolss_6c\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3090 : }
3091 0 : break;
3092 : }
3093 0 : case 109: { /* spoolss_6d */
3094 0 : struct spoolss_6d *r2 = (struct spoolss_6d *)r;
3095 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3096 0 : DEBUG(5,("function spoolss_6d replied async\n"));
3097 : }
3098 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3099 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_6d, NDR_OUT | NDR_SET_VALUES, r2);
3100 : }
3101 0 : if (dce_call->fault_code != 0) {
3102 0 : DBG_WARNING("dcerpc_fault %s in spoolss_6d\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3103 : }
3104 0 : break;
3105 : }
3106 0 : case 110: { /* spoolss_GetJobNamedPropertyValue */
3107 0 : struct spoolss_GetJobNamedPropertyValue *r2 = (struct spoolss_GetJobNamedPropertyValue *)r;
3108 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3109 0 : DEBUG(5,("function spoolss_GetJobNamedPropertyValue replied async\n"));
3110 : }
3111 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3112 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_GetJobNamedPropertyValue, NDR_OUT | NDR_SET_VALUES, r2);
3113 : }
3114 0 : if (dce_call->fault_code != 0) {
3115 0 : DBG_WARNING("dcerpc_fault %s in spoolss_GetJobNamedPropertyValue\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3116 : }
3117 0 : break;
3118 : }
3119 0 : case 111: { /* spoolss_SetJobNamedProperty */
3120 0 : struct spoolss_SetJobNamedProperty *r2 = (struct spoolss_SetJobNamedProperty *)r;
3121 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3122 0 : DEBUG(5,("function spoolss_SetJobNamedProperty replied async\n"));
3123 : }
3124 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3125 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_SetJobNamedProperty, NDR_OUT | NDR_SET_VALUES, r2);
3126 : }
3127 0 : if (dce_call->fault_code != 0) {
3128 0 : DBG_WARNING("dcerpc_fault %s in spoolss_SetJobNamedProperty\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3129 : }
3130 0 : break;
3131 : }
3132 0 : case 112: { /* spoolss_DeleteJobNamedProperty */
3133 0 : struct spoolss_DeleteJobNamedProperty *r2 = (struct spoolss_DeleteJobNamedProperty *)r;
3134 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3135 0 : DEBUG(5,("function spoolss_DeleteJobNamedProperty replied async\n"));
3136 : }
3137 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3138 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_DeleteJobNamedProperty, NDR_OUT | NDR_SET_VALUES, r2);
3139 : }
3140 0 : if (dce_call->fault_code != 0) {
3141 0 : DBG_WARNING("dcerpc_fault %s in spoolss_DeleteJobNamedProperty\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3142 : }
3143 0 : break;
3144 : }
3145 0 : case 113: { /* spoolss_EnumJobNamedProperties */
3146 0 : struct spoolss_EnumJobNamedProperties *r2 = (struct spoolss_EnumJobNamedProperties *)r;
3147 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3148 0 : DEBUG(5,("function spoolss_EnumJobNamedProperties replied async\n"));
3149 : }
3150 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3151 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_EnumJobNamedProperties, NDR_OUT | NDR_SET_VALUES, r2);
3152 : }
3153 0 : if (dce_call->fault_code != 0) {
3154 0 : DBG_WARNING("dcerpc_fault %s in spoolss_EnumJobNamedProperties\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3155 : }
3156 0 : break;
3157 : }
3158 0 : case 114: { /* spoolss_72 */
3159 0 : struct spoolss_72 *r2 = (struct spoolss_72 *)r;
3160 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3161 0 : DEBUG(5,("function spoolss_72 replied async\n"));
3162 : }
3163 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3164 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_72, NDR_OUT | NDR_SET_VALUES, r2);
3165 : }
3166 0 : if (dce_call->fault_code != 0) {
3167 0 : DBG_WARNING("dcerpc_fault %s in spoolss_72\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3168 : }
3169 0 : break;
3170 : }
3171 0 : case 115: { /* spoolss_73 */
3172 0 : struct spoolss_73 *r2 = (struct spoolss_73 *)r;
3173 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3174 0 : DEBUG(5,("function spoolss_73 replied async\n"));
3175 : }
3176 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3177 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_73, NDR_OUT | NDR_SET_VALUES, r2);
3178 : }
3179 0 : if (dce_call->fault_code != 0) {
3180 0 : DBG_WARNING("dcerpc_fault %s in spoolss_73\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3181 : }
3182 0 : break;
3183 : }
3184 0 : case 116: { /* spoolss_LogJobInfoForBranchOffice */
3185 0 : struct spoolss_LogJobInfoForBranchOffice *r2 = (struct spoolss_LogJobInfoForBranchOffice *)r;
3186 0 : if (dce_call->state_flags & DCESRV_CALL_STATE_FLAG_ASYNC) {
3187 0 : DEBUG(5,("function spoolss_LogJobInfoForBranchOffice replied async\n"));
3188 : }
3189 0 : if (DEBUGLEVEL >= 10 && dce_call->fault_code == 0) {
3190 0 : NDR_PRINT_FUNCTION_DEBUG(spoolss_LogJobInfoForBranchOffice, NDR_OUT | NDR_SET_VALUES, r2);
3191 : }
3192 0 : if (dce_call->fault_code != 0) {
3193 0 : DBG_WARNING("dcerpc_fault %s in spoolss_LogJobInfoForBranchOffice\n", dcerpc_errstr(mem_ctx, dce_call->fault_code));
3194 : }
3195 0 : break;
3196 : }
3197 0 : default:
3198 0 : dce_call->fault_code = DCERPC_FAULT_OP_RNG_ERROR;
3199 0 : break;
3200 : }
3201 :
3202 10 : if (dce_call->fault_code != 0) {
3203 0 : return NT_STATUS_NET_WRITE_FAULT;
3204 : }
3205 :
3206 10 : return NT_STATUS_OK;
3207 : }
3208 :
3209 10 : NTSTATUS spoolss__op_ndr_push(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, struct ndr_push *push, const void *r)
3210 : {
3211 : enum ndr_err_code ndr_err;
3212 10 : uint16_t opnum = dce_call->pkt.u.request.opnum;
3213 :
3214 10 : ndr_err = ndr_table_spoolss.calls[opnum].ndr_push(push, NDR_OUT, r);
3215 10 : if (!NDR_ERR_CODE_IS_SUCCESS(ndr_err)) {
3216 0 : dce_call->fault_code = DCERPC_FAULT_NDR;
3217 0 : return NT_STATUS_NET_WRITE_FAULT;
3218 : }
3219 :
3220 10 : return NT_STATUS_OK;
3221 : }
3222 :
3223 0 : NTSTATUS spoolss__op_local(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx, void *r)
3224 : {
3225 0 : return spoolss__op_dispatch_internal(dce_call, mem_ctx, r, S3COMPAT_RPC_DISPATCH_INTERNAL);
3226 : }
3227 :
3228 : static const struct dcesrv_interface dcesrv_spoolss_interface = {
3229 : .name = "spoolss",
3230 : .syntax_id = {{0x12345678,0x1234,0xabcd,{0xef,0x00},{0x01,0x23,0x45,0x67,0x89,0xab}},1.0},
3231 : .bind = spoolss__op_bind,
3232 : .unbind = spoolss__op_unbind,
3233 : .ndr_pull = spoolss__op_ndr_pull,
3234 : .dispatch = spoolss__op_dispatch,
3235 : .reply = spoolss__op_reply,
3236 : .ndr_push = spoolss__op_ndr_push,
3237 : .local = spoolss__op_local,
3238 : #ifdef DCESRV_INTERFACE_SPOOLSS_FLAGS
3239 : .flags = DCESRV_INTERFACE_SPOOLSS_FLAGS
3240 : #else
3241 : .flags = 0
3242 : #endif
3243 : };
3244 :
3245 2 : static NTSTATUS spoolss__op_init_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
3246 : {
3247 : uint32_t i;
3248 : NTSTATUS ret;
3249 :
3250 : #ifdef DCESRV_INTERFACE_SPOOLSS_NCACN_NP_SECONDARY_ENDPOINT
3251 : const char *ncacn_np_secondary_endpoint = DCESRV_INTERFACE_SPOOLSS_NCACN_NP_SECONDARY_ENDPOINT;
3252 : #else
3253 2 : const char *ncacn_np_secondary_endpoint = NULL;
3254 : #endif
3255 :
3256 6 : for (i=0;i<ndr_table_spoolss.endpoints->count;i++) {
3257 4 : const char *name = ndr_table_spoolss.endpoints->names[i];
3258 :
3259 4 : ret = dcesrv_interface_register(dce_ctx, name, ncacn_np_secondary_endpoint, &dcesrv_spoolss_interface, NULL);
3260 4 : if (!NT_STATUS_IS_OK(ret)) {
3261 0 : DBG_ERR("Failed to register endpoint '%s'\n",name);
3262 0 : return ret;
3263 : }
3264 : }
3265 :
3266 2 : return NT_STATUS_OK;
3267 : }
3268 :
3269 2 : static NTSTATUS spoolss__op_shutdown_server(struct dcesrv_context *dce_ctx, const struct dcesrv_endpoint_server *ep_server)
3270 : {
3271 2 : return NT_STATUS_OK;
3272 : }
3273 :
3274 0 : static bool spoolss__op_interface_by_uuid(struct dcesrv_interface *iface, const struct GUID *uuid, uint32_t if_version)
3275 : {
3276 0 : if (dcesrv_spoolss_interface.syntax_id.if_version == if_version && GUID_equal(&dcesrv_spoolss_interface.syntax_id.uuid, uuid)) {
3277 0 : memcpy(iface,&dcesrv_spoolss_interface, sizeof(*iface));
3278 0 : return true;
3279 : }
3280 :
3281 0 : return false;
3282 : }
3283 :
3284 0 : static bool spoolss__op_interface_by_name(struct dcesrv_interface *iface, const char *name)
3285 : {
3286 0 : if (strcmp(dcesrv_spoolss_interface.name, name)==0) {
3287 0 : memcpy(iface, &dcesrv_spoolss_interface, sizeof(*iface));
3288 0 : return true;
3289 : }
3290 :
3291 0 : return false;
3292 : }
3293 :
3294 : static const struct dcesrv_endpoint_server spoolss_ep_server = {
3295 : /* fill in our name */
3296 : .name = "spoolss",
3297 :
3298 : /* Initialization flag */
3299 : .initialized = false,
3300 :
3301 : /* fill in all the operations */
3302 : #ifdef DCESRV_INTERFACE_SPOOLSS_INIT_SERVER
3303 : .init_server = DCESRV_INTERFACE_SPOOLSS_INIT_SERVER,
3304 : #else
3305 : .init_server = spoolss__op_init_server,
3306 : #endif
3307 : #ifdef DCESRV_INTERFACE_SPOOLSS_SHUTDOWN_SERVER
3308 : .shutdown_server = DCESRV_INTERFACE_SPOOLSS_SHUTDOWN_SERVER,
3309 : #else
3310 : .shutdown_server = spoolss__op_shutdown_server,
3311 : #endif
3312 : .interface_by_uuid = spoolss__op_interface_by_uuid,
3313 : .interface_by_name = spoolss__op_interface_by_name
3314 : };
3315 :
3316 2 : const struct dcesrv_endpoint_server *spoolss_get_ep_server(void)
3317 : {
3318 2 : return &spoolss_ep_server;
3319 : }
|