2 Unix SMB/CIFS implementation.
3 test suite for spoolss rpc operations
5 Copyright (C) Gerald (Jerry) Carter 2007
6 Copyright (C) Guenther Deschner 2009-2010
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
26 void print_devmode(DEVMODE *pDevModeIn)
28 if (pDevModeIn == NULL) {
29 printf("\tDevice Mode\t= (null)\n");
33 printf("\tDEVMODE:----------\n");
34 printf("\tDeviceName: [%s]\n", pDevModeIn->dmDeviceName);
35 printf("\tSpecVersion: %d\n", pDevModeIn->dmSpecVersion);
36 printf("\tDriverVersion: %d\n", pDevModeIn->dmDriverVersion);
37 printf("\tSize: %d\n", pDevModeIn->dmSize);
38 printf("\tDriverExtra: %d\n", pDevModeIn->dmDriverExtra);
39 printf("\tFields: 0x%x\n", pDevModeIn->dmFields);
41 if (pDevModeIn->dmFields & DM_ORIENTATION)
42 printf("\tOrientation: %d\n", pDevModeIn->dmOrientation);
43 if (pDevModeIn->dmFields & DM_PAPERSIZE)
44 printf("\tPaperSize: %d\n", pDevModeIn->dmPaperSize);
45 if (pDevModeIn->dmFields & DM_PAPERLENGTH)
46 printf("\tPaperLength: %d\n", pDevModeIn->dmPaperLength);
47 if (pDevModeIn->dmFields & DM_PAPERWIDTH)
48 printf("\tPaperWidth: %d\n", pDevModeIn->dmPaperWidth);
49 // if (pDevModeIn->dmFields & DM_POSITION)
50 // printf("\tPosition: %d\n", pDevModeIn->dmPosition);
51 if (pDevModeIn->dmFields & DM_SCALE)
52 printf("\tScale: %d\n", pDevModeIn->dmScale);
53 if (pDevModeIn->dmFields & DM_COPIES)
54 printf("\tCopies: %d\n", pDevModeIn->dmCopies );
55 if (pDevModeIn->dmFields & DM_DEFAULTSOURCE)
56 printf("\tDefaultSource: %d\n", pDevModeIn->dmDefaultSource);
57 if (pDevModeIn->dmFields & DM_PRINTQUALITY)
58 printf("\tPrintQuality: %d\n", pDevModeIn->dmPrintQuality);
59 if (pDevModeIn->dmFields & DM_COLOR)
60 printf("\tColor: %d\n", pDevModeIn->dmColor);
61 if (pDevModeIn->dmFields & DM_DUPLEX)
62 printf("\tDuplex: %d\n", pDevModeIn->dmDuplex);
63 if (pDevModeIn->dmFields & DM_YRESOLUTION)
64 printf("\tYResolution: %d\n", pDevModeIn->dmYResolution);
65 if (pDevModeIn->dmFields & DM_TTOPTION)
66 printf("\tTTOption: %d\n", pDevModeIn->dmTTOption);
67 if (pDevModeIn->dmFields & DM_COLLATE)
68 printf("\tCollate: %d\n", pDevModeIn->dmCollate);
69 if (pDevModeIn->dmFields & DM_FORMNAME)
70 printf("\tForm: [%s]\n", pDevModeIn->dmFormName);
71 if (pDevModeIn->dmFields & DM_LOGPIXELS)
72 printf("\tLogPixels: %d\n", pDevModeIn->dmLogPixels);
73 if (pDevModeIn->dmFields & DM_BITSPERPEL)
74 printf("\tBitsPerPel: %d\n", pDevModeIn->dmBitsPerPel);
75 if (pDevModeIn->dmFields & DM_PELSWIDTH)
76 printf("\tPelsWidth: %d\n", pDevModeIn->dmPelsWidth);
77 if (pDevModeIn->dmFields & DM_PELSHEIGHT)
78 printf("\tPelsHeight: %d\n", pDevModeIn->dmPelsHeight);
79 if (pDevModeIn->dmFields & DM_DISPLAYFLAGS)
80 printf("\tDisplayFlags: %d\n", pDevModeIn->dmDisplayFlags);
81 // if (pDevModeIn->dmFields & DM_NUP)
82 // printf("\tNup: %d\n", pDevModeIn->dmNup);
83 if (pDevModeIn->dmFields & DM_DISPLAYFREQUENCY)
84 printf("\tDisplayFrequency:%d\n", pDevModeIn->dmDisplayFrequency);
85 if (pDevModeIn->dmFields & DM_ICMMETHOD)
86 printf("\tICMMethod: %d\n", pDevModeIn->dmICMMethod);
87 if (pDevModeIn->dmFields & DM_ICMINTENT)
88 printf("\tICMIntent: %d\n", pDevModeIn->dmICMIntent);
89 if (pDevModeIn->dmFields & DM_MEDIATYPE)
90 printf("\tMediaType: %d\n", pDevModeIn->dmMediaType);
91 if (pDevModeIn->dmFields & DM_DITHERTYPE)
92 printf("\tDitherType: %d\n", pDevModeIn->dmDitherType);
93 // if (pDevModeIn->dmFields & DM_PANNINGWIDTH)
94 // printf("\tPanningWidth: %d\n", pDevModeIn->dmPanningWidth);
95 // if (pDevModeIn->dmFields & DM_PANNINGHEIGHT)
96 // printf("\tPanningHeight: %d\n", pDevModeIn->dmPanningHeight);
101 Dump((BYTE*)pDevModeIn, sizeof(DEVMODE), LEADER);
103 if (pDevModeIn->dmDriverExtra) {
104 printf("DriverExtra\n");
105 Dump((BYTE*)pDevModeIn + sizeof(DEVMODE), pDevModeIn->dmDriverExtra, LEADER);
113 void print_acl(const char* str, ACL *acl)
119 printf("\t\tACL Revision \t\t 0x%x\n", acl->AclRevision);
120 printf("\t\tSbz1\t\t 0x%x\n", acl->Sbz1);
121 printf("\t\tSbz2\t\t 0x%x\n", acl->Sbz2);
122 printf("\t\tACL Size\t\t 0x%x\n", acl->AclSize);
123 printf("\t\tACL Count\t\t 0x%x\n", acl->AceCount);
128 void print_sid(const char* str, SID *sid)
133 printf("0x%x\n", sid);
136 printf("\t\tRevision\t\t0x%x\n", sid->Revision);
137 printf("\t\tSubAuthorityCount\t0x%x\n", sid->SubAuthorityCount);
138 printf("\t\tSubAuthority\n\t");
139 while (i < sid->SubAuthorityCount) {
140 printf("\t0x%x", sid->SubAuthority[i]);
149 void print_secdesc(SECURITY_DESCRIPTOR *secdesc)
151 if (secdesc == NULL) {
152 printf("\tSecurity Descriptor\t= (null)\n");
156 printf("\tRevision\t= 0x%x\n", secdesc->Revision);
157 printf("\tSbz1\t\t= 0x%x\n", secdesc->Sbz1);
159 print_sid("\tOwner\t\t= ", secdesc->Owner);
160 print_sid("\tGroup\t\t= ",secdesc->Group);
161 print_acl("\tSacl\t\t= ", secdesc->Sacl);
162 print_acl("\tDacl\t\t= ", secdesc->Dacl);
167 void PrintLastError()
172 status = GetLastError();
174 FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS,
175 NULL, GetLastError(), MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), // Default language
176 (LPTSTR)&lpMsgBuf, 0, NULL);
177 printf("ERROR [0x%x] : %s\n", status, (char*)lpMsgBuf);
184 void print_job_info_1(PJOB_INFO_1 info)
186 printf("\tJob ID\t\t= %d\n", info->JobId);
187 printf("\tPrinter Name\t= %s\n", info->pPrinterName);
188 printf("\tMachine Name\t= %s\n", info->pMachineName);
189 printf("\tUser Name\t= %s\n", info->pUserName);
190 printf("\tDocument\t= %s\n", info->pDocument);
191 printf("\tDatatype\t= %s\n", info->pDatatype);
192 printf("\tStatus\t\t= %s\n", info->pStatus);
193 printf("\tStatus\t= %d\n", info->Status);
194 printf("\tPriority\t= %d\n", info->Priority);
195 printf("\tPosition\t= %d\n", info->Position);
196 printf("\tTotal Pages\t= %d\n", info->TotalPages);
197 printf("\tPages Printed\t= %d\n", info->PagesPrinted);
198 printf("\tSubmitted (DD:MM:YY HH:MM:SS)\t= %d:%d:%d %d:%d:%d UTC\n",
199 info->Submitted.wDay, info->Submitted.wMonth,
200 info->Submitted.wYear, info->Submitted.wHour,
201 info->Submitted.wMinute, info->Submitted.wSecond);
206 void print_job_info_2(PJOB_INFO_2 info)
208 printf("\tJob ID\t\t= %d\n", info->JobId);
209 printf("\tPrinter Name\t= %s\n", info->pPrinterName);
210 printf("\tMachine Name\t= %s\n", info->pMachineName);
211 printf("\tUser Name\t= %s\n", info->pUserName);
212 printf("\tDocument\t= %s\n", info->pDocument);
213 printf("\tDatatype\t= %s\n", info->pDatatype);
214 printf("\tNotify Name\t= %s\n", info->pNotifyName);
215 printf("\tPrint Processor\t= %s\n", info->pPrintProcessor);
216 printf("\tParameters\t= %s\n", info->pParameters);
217 printf("\tDriver Name\t= %s\n", info->pDriverName);
218 printf("\tStatus\t\t= %s\n", info->pStatus);
219 printf("\tStatus\t\t= %d\n", info->Status);
220 printf("\tPriority\t= %d\n", info->Priority);
221 printf("\tPosition\t= %d\n", info->Position);
222 printf("\tTotal Pages\t= %d\n", info->TotalPages);
223 printf("\tPages Printed\t= %d\n", info->PagesPrinted);
224 printf("\tStart Time\t= %d\n", info->StartTime);
225 printf("\tUntil Time\t= %d\n", info->UntilTime);
226 printf("\tTime\t\t= %d\n", info->Time);
227 printf("\tSize\t\t= %d\n", info->Size);
228 printf("\tSubmitted (DD:MM:YY HH:MM:SS)\t= %d:%d:%d %d:%d:%d UTC\n",
229 info->Submitted.wDay, info->Submitted.wMonth,
230 info->Submitted.wYear, info->Submitted.wHour,
231 info->Submitted.wMinute, info->Submitted.wSecond);
232 printf("\tDevice Mode Information\n");
233 printf("\t-----------------------\n");
234 print_devmode(info->pDevMode);
235 printf("\tSecurity Descriptor Information\n");
236 printf("\t-------------------------------\n");
237 print_secdesc(info->pSecurityDescriptor);
242 void print_job_info_3(PJOB_INFO_3 info)
244 printf("\tJob ID\t\t= %d\n", info->JobId);
245 printf("\tJob ID Next Job\t= %d\n", info->NextJobId);
246 printf("\tReserved (must be 0)\t= %d\n",info->Reserved);
251 void print_monitor_info_1(PMONITOR_INFO_1 info)
253 printf("\tMonitor Name\t= %s\n", info->pName);
258 void print_monitor_info_2(PMONITOR_INFO_2 info)
260 printf("\tMonitor Name\t= %s\n", info->pName);
261 printf("\tEnvironment\t= %s\n", info->pEnvironment);
262 printf("\tDLL Name\t= %s\n", info->pDLLName);
267 void print_form_info_1(PFORM_INFO_1 info)
269 printf("\tForm Name\t= %s\n", info->pName);
270 printf("\tFlags\t\t= 0x%x\n", info->Flags);
271 printf("\tSize\t\t= %d x %d\n", info->Size.cx, info->Size.cy);
272 printf("\tRectangle\t= [left]%d [right]%d [top]%d [bottom]%d\n",
273 info->ImageableArea.left, info->ImageableArea.right,
274 info->ImageableArea.top, info->ImageableArea.bottom);
279 void print_printer_info_1(PPRINTER_INFO_1 info)
281 printf("\tPrinter Name\t= %s\n", info->pName);
282 printf("\tDescription\t= %s\n", info->pDescription);
283 printf("\tComment\t\t= %s\n", info->pComment);
284 printf("\tFlags\t\t= 0x%x\n", info->Flags);
289 void print_printer_info_2(PPRINTER_INFO_2 info)
291 printf("\tServer Name\t\t= %s\n", info->pServerName);
292 printf("\tPrinter Name\t\t= %s\n", info->pPrinterName);
293 printf("\tPort Name\t\t= %s\n", info->pPortName);
294 printf("\tShare Name\t\t= %s\n", info->pShareName);
295 printf("\tDriver Name\t\t= %s\n", info->pDriverName);
296 printf("\tComment\t\t\t= %s\n", info->pComment);
297 printf("\tLocation\t\t= %s\n", info->pLocation);
298 printf("\tSeparator File\t\t= %s\n", info->pSepFile);
299 printf("\tDefault Data Type\t= %s\n", info->pDatatype);
300 printf("\tPrint Processor\t\t= %s\n", info->pPrintProcessor);
301 printf("\tParameters\t\t= %s\n", info->pParameters);
302 printf("\tAttributes\t\t= 0x%x\n", info->Attributes);
303 printf("\tPriority\t\t= 0x%x\n", info->Priority);
304 printf("\tDefault Priority\t= 0x%x\n", info->DefaultPriority);
305 printf("\tStart Time\t\t= 0x%x\n", info->StartTime);
306 printf("\tUntil Time\t\t= 0x%x\n", info->UntilTime);
307 printf("\tStatus\t\t\t= 0x%x\n", info->Status);
308 printf("\tcJobs\t\t\t= 0x%x\n", info->cJobs);
309 printf("\tAverage PPM\t\t= 0x%x\n", info->AveragePPM);
311 printf("\tDevice Mode Information\n");
312 printf("\t-----------------------\n");
313 print_devmode(info->pDevMode);
315 printf("\tSecurity Descriptor Information\n");
316 printf("\t-------------------------------\n");
317 print_secdesc(info->pSecurityDescriptor);
322 void print_printer_info_5(PPRINTER_INFO_5 info)
324 printf("\tPrinter Name\t\t\t= %s\n", info->pPrinterName);
325 printf("\tPort Name\t\t\t= %s\n", info->pPortName);
326 printf("\tAttributes\t\t\t= 0x%x\n", info->Attributes);
327 printf("\tDev NotSelect Timeout\t= 0x%x\n", info->DeviceNotSelectedTimeout);
328 printf("\tTX RetryTimeout\t\t= 0x%x\n", info->TransmissionRetryTimeout);
332 void print_printer_info_6(PPRINTER_INFO_6 info)
334 printf("\tStatus\t\t\t= 0x%x\n", info->dwStatus);
338 void print_printer_info_7(PPRINTER_INFO_7 info)
340 printf("\tObject GUID\t\t\t= %s\n", info->pszObjectGUID);
341 printf("\tAction\t\t\t= 0x%x\n", info->dwAction);
345 void print_printer_info_8(PPRINTER_INFO_8 info)
347 print_devmode(info->pDevMode);
350 void print_printer_info_9(PPRINTER_INFO_9 info)
352 print_devmode(info->pDevMode);
355 void print_printer_info_bylevel(DWORD level, LPBYTE buffer, DWORD count)
358 PPRINTER_INFO_1 buffer1 = NULL;
359 PPRINTER_INFO_2 buffer2 = NULL;
360 PPRINTER_INFO_3 buffer3 = NULL;
361 PPRINTER_INFO_4 buffer4 = NULL;
362 PPRINTER_INFO_5 buffer5 = NULL;
363 PPRINTER_INFO_6 buffer6 = NULL;
364 PPRINTER_INFO_7 buffer7 = NULL;
365 PPRINTER_INFO_8 buffer8 = NULL;
373 buffer1 = (PPRINTER_INFO_1)buffer;
376 buffer2 = (PPRINTER_INFO_2)buffer;
379 buffer3 = (PPRINTER_INFO_3)buffer;
382 buffer4 = (PPRINTER_INFO_4)buffer;
385 buffer5 = (PPRINTER_INFO_5)buffer;
388 buffer6 = (PPRINTER_INFO_6)buffer;
391 buffer7 = (PPRINTER_INFO_7)buffer;
394 buffer8 = (PPRINTER_INFO_8)buffer;
400 printf("Printer Info Level %d:\n", level);
404 for (i=0; i<count; i++) {
405 print_printer_info_1(&buffer1[i]);
410 for (i=0; i<count; i++) {
411 print_printer_info_2(&buffer2[i]);
417 for (i=0; i<count; i++) {
418 print_printer_info_3(&buffer3[i]);
423 for (i=0; i<count; i++) {
424 print_printer_info_4(&buffer4[i]);
430 for (i=0; i<count; i++) {
431 print_printer_info_5(&buffer5[i]);
436 for (i=0; i<count; i++) {
437 print_printer_info_6(&buffer6[i]);
442 for (i=0; i<count; i++) {
443 print_printer_info_7(&buffer7[i]);
448 for (i=0; i<count; i++) {
449 print_printer_info_8(&buffer8[i]);
458 void print_printprocessor_info_1(PPRINTPROCESSOR_INFO_1 info)
460 printf("\tPrint Processor Name\t= %s\n", info->pName);
465 void print_driver_info_1(PDRIVER_INFO_1 info)
467 printf("\tDriver Name\t= %s\n\n", info->pName);
472 void print_driver_info_2(PDRIVER_INFO_2 info)
474 printf("\tDriver Name\t= %s\n", info->pName);
475 printf("\tEnvironment\t= %s\n", info->pEnvironment);
476 printf("\tVersion\t\t= %d\n", info->cVersion);
477 printf("\tDriver Path\t= %s\n", info->pDriverPath);
478 printf("\tData File\t= %s\n", info->pDataFile);
479 printf("\tConfig File\t= %s\n\n", info->pConfigFile);
484 void print_driver_info_3(PDRIVER_INFO_3 info)
488 printf("\tDriver Name\t= %s\n", info->pName);
489 printf("\tEnvironment\t= %s\n", info->pEnvironment);
490 printf("\tVersion\t\t= %d\n", info->cVersion);
491 printf("\tDriver Path\t= %s\n", info->pDriverPath);
492 printf("\tData File\t= %s\n", info->pDataFile);
493 printf("\tConfig File\t= %s\n", info->pConfigFile);
494 printf("\tHelp Path\t= %s\n", info->pHelpFile);
495 printf("\tMonitor Name\t= %s\n", info->pMonitorName);
496 printf("\tData Type\t= %s\n", info->pDefaultDataType);
497 ptr = (char*)info->pDependentFiles;
498 while ((ptr != NULL) && (*ptr != '\0')) {
499 printf("\tDependent Files\t= %s\n", ptr);
500 for (;*ptr != '\0'; ptr++)
501 /* printf("%s\n", ptr); */
509 void print_driver_info_4(PDRIVER_INFO_4 info)
513 printf("\tDriver Name\t= %s\n", info->pName);
514 printf("\tEnvironment\t= %s\n", info->pEnvironment);
515 printf("\tVersion\t\t= %d\n", info->cVersion);
516 printf("\tDriver Path\t= %s\n", info->pDriverPath);
517 printf("\tData File\t= %s\n", info->pDataFile);
518 printf("\tConfig File\t= %s\n", info->pConfigFile);
519 printf("\tHelp Path\t= %s\n", info->pHelpFile);
520 printf("\tMonitor Name\t= %s\n", info->pMonitorName);
521 printf("\tData Type\t= %s\n", info->pDefaultDataType);
522 printf("\tPrevious Names\t= %s\n", info->pszzPreviousNames);
523 ptr = (char*)info->pDependentFiles;
524 while ((ptr != NULL) && (*ptr != '\0')) {
525 printf("\tDependent Files\t= %s\n", ptr);
526 for (;*ptr != '\0'; ptr++)
527 /* printf("%s\n", ptr); */
535 void print_driver_info_6(PDRIVER_INFO_6 info)
539 printf("\tDriver Name\t= %s\n", info->pName);
540 printf("\tEnvironment\t= %s\n", info->pEnvironment);
541 printf("\tVersion\t\t= %d\n", info->cVersion);
542 printf("\tDriver Path\t= %s\n", info->pDriverPath);
543 printf("\tData File\t= %s\n", info->pDataFile);
544 printf("\tConfig File\t= %s\n", info->pConfigFile);
545 printf("\tHelp Path\t= %s\n", info->pHelpFile);
546 printf("\tMonitor Name\t= %s\n", info->pMonitorName);
547 printf("\tData Type\t= %s\n", info->pDefaultDataType);
548 printf("\tPrevious Names\t= %s\n", info->pszzPreviousNames);
549 ptr = (char*)info->pDependentFiles;
551 while (*ptr != '\0') {
552 printf("\tDependent Files\t= %s\n", ptr);
553 for (;*ptr != '\0'; ptr++)
554 /* printf("%s\n", ptr); */
559 printf("\tPrevious Names\t= (null)\n");
562 ptr = (char*)info->pszzPreviousNames;
564 while (*ptr != '\0') {
565 printf("\tPrevious Names\t= %s\n", ptr);
566 for (;*ptr != '\0'; ptr++)
567 /* printf("%s\n", ptr); */
572 printf("\tPrevious Names\t= (null)\n");
575 printf("\tDriver Date\t= %d\n", info->ftDriverDate);
576 printf("\tDriver Version\t= %d\n", info->dwlDriverVersion);
577 printf("\tManufacture Name = %s\n", info->pszMfgName);
578 printf("\tOEM URL\t\t= %s\n", info->pszOEMUrl);
579 printf("\tHardware ID\t= %s\n", info->pszHardwareID);
580 printf("\tProvider\t= %s\n", info->pszProvider);
584 void print_doc_info_1(PDOC_INFO_1 info)
586 printf("\tDocument Name\t= %s\n", info->pDocName);
587 printf("\tOutput Filename\t= %s\n", info->pOutputFile);
588 printf("\tDatatype\t= %s\n", info->pDatatype);
592 void print_printer_keys(LPSTR buffer)
600 for (; *p; p = CharNext(p)) {
606 static LPSTR reg_type_str(DWORD type)
614 return "REG_MULTI_SZ";
622 void print_printer_data(LPSTR keyname, LPSTR valuename, DWORD size, LPBYTE buffer, DWORD type)
628 printf("\tKey Name:\t%s\n", keyname);
631 printf("\tValue Name:\t%s\n", valuename);
632 printf("\tSize: 0x%x (%d)\n", size, size);
633 printf("\tType:\t\t%s\n", reg_type_str(type));
637 printf("\t\t%s\n", (LPSTR)buffer);
643 for (; *p; p = CharNext(p)) {
650 printf("\t\t0x%08x\n", (DWORD)*buffer);
653 for (i=0; i < size; i++) {
654 printf("\t0x%x", buffer[i]);
665 void print_printer_enum_values(PRINTER_ENUM_VALUES *info)
667 print_printer_data(NULL, info->pValueName, info->cbData, info->pData, info->dwType);