+#include "idl_types.h"
+
/*
spoolss interface definitions
*/
-[ uuid(12345678-1234-abcd-ef00-0123456789ab),
+[ uuid("12345678-1234-abcd-ef00-0123456789ab"),
version(1.0),
- pointer_default(unique)
+ endpoint("ncacn_np:[\\pipe\\spoolss]"),
+ pointer_default(unique),
+ helpstring("Spooler SubSystem"),
+ depends(security)
] interface spoolss
{
- /******************/
- /* Function: 0x00 */
+ typedef struct {
+ uint16 year;
+ uint16 month;
+ uint16 day_of_week;
+ uint16 day;
+ uint16 hour;
+ uint16 minute;
+ uint16 second;
+ uint16 millisecond;
+ } spoolss_Time;
+
+ typedef struct {
+ [relative] nstring *printername;
+ [relative] nstring *servername;
+ uint32 cjobs;
+ uint32 total_jobs;
+ uint32 total_bytes;
+ spoolss_Time time;
+ uint32 global_counter;
+ uint32 total_pages;
+ uint32 version;
+ uint32 unknown10;
+ uint32 unknown11;
+ uint32 unknown12;
+ uint32 session_counter;
+ uint32 unknown14;
+ uint32 printer_errors;
+ uint32 unknown16;
+ uint32 unknown17;
+ uint32 unknown18;
+ uint32 unknown19;
+ uint32 change_id;
+ uint32 unknown21;
+ uint32 status;
+ uint32 unknown23;
+ uint32 c_setprinter;
+ uint16 unknown25;
+ uint16 unknown26;
+ uint32 unknown27;
+ uint32 unknown28;
+ uint32 unknown29;
+ } spoolss_PrinterInfo0;
typedef struct {
- nstring devicename;
+ string32 devicename;
uint16 specversion;
uint16 driverversion;
uint16 size;
uint16 yresolution;
uint16 ttoption;
uint16 collate;
- nstring formname;
+ string32 formname;
uint16 logpixels;
uint32 bitsperpel;
uint32 pelswidth;
uint8 private[driverextra];
} spoolss_DeviceMode;
- typedef struct {
+ typedef [public] struct {
uint32 flags;
- [relative] nstring name;
- [relative] nstring description;
- [relative] nstring comment;
+ [relative] nstring *name;
+ [relative] nstring *description;
+ [relative] nstring *comment;
} spoolss_PrinterInfo1;
- typedef struct {
- [relative] nstring servername;
- [relative] nstring printername;
- [relative] nstring sharename;
- [relative] nstring portname;
- [relative] nstring drivername;
- [relative] nstring comment;
- [relative] nstring location;
+ typedef [public] struct {
+ [relative] nstring *servername;
+ [relative] nstring *printername;
+ [relative] nstring *sharename;
+ [relative] nstring *portname;
+ [relative] nstring *drivername;
+ [relative] nstring *comment;
+ [relative] nstring *location;
[relative] spoolss_DeviceMode *devmode;
- [relative] nstring sepfile;
- [relative] nstring printprocessor;
- [relative] nstring datatype;
- [relative] nstring parameters;
- [relative] security_descriptor *secdesc;
+ [relative] nstring *sepfile;
+ [relative] nstring *printprocessor;
+ [relative] nstring *datatype;
+ [relative] nstring *parameters;
+ [relative,subcontext(0)] security_descriptor *secdesc;
uint32 attributes;
uint32 priority;
uint32 defaultpriority;
typedef struct {
uint32 flags;
- security_descriptor secdesc;
+ [subcontext(0)] security_descriptor secdesc;
} spoolss_PrinterInfo3;
typedef struct {
- [relative] nstring printername;
- [relative] nstring servername;
+ [relative] nstring *printername;
+ [relative] nstring *servername;
uint32 attributes;
} spoolss_PrinterInfo4;
- typedef struct {
- [relative] nstring printername;
- [relative] nstring portname;
+ typedef [public] struct {
+ [relative] nstring *printername;
+ [relative] nstring *portname;
uint32 attributes;
uint32 device_not_selected_timeout;
uint32 transmission_retry_timeout;
} spoolss_PrinterInfo6;
typedef struct {
- [relative] nstring guid; /* text form of printer guid */
+ [relative] nstring *guid; /* text form of printer guid */
uint32 action;
} spoolss_PrinterInfo7;
typedef [nodiscriminant,public] union {
+ [case(0)] spoolss_PrinterInfo0 info0;
[case(1)] spoolss_PrinterInfo1 info1;
[case(2)] spoolss_PrinterInfo2 info2;
[case(3)] spoolss_PrinterInfo3 info3;
[case(7)] spoolss_PrinterInfo7 info7;
} spoolss_PrinterInfo;
- WERROR spoolss_EnumPrinters(
- [in] uint32 flags,
- [in] unistr *server,
- [in] uint32 level,
- [in,out] DATA_BLOB *buffer,
+ const int PRINTER_ENUM_DEFAULT = 0x00000001;
+ const int PRINTER_ENUM_LOCAL = 0x00000002;
+ const int PRINTER_ENUM_CONNECTIONS = 0x00000004;
+ const int PRINTER_ENUM_FAVORITE = 0x00000004;
+ const int PRINTER_ENUM_NAME = 0x00000008;
+ const int PRINTER_ENUM_REMOTE = 0x00000010;
+ const int PRINTER_ENUM_SHARED = 0x00000020;
+ const int PRINTER_ENUM_NETWORK = 0x00000040;
+
+ /******************/
+ /* Function: 0x00 */
+ [noprint,nopull,nopush] WERROR spoolss_EnumPrinters(
+ [in] uint32 flags,
+ [in] unistr *server,
+ [in] uint32 level,
+ [in] DATA_BLOB *buffer,
+ /* [out,subcontext(4),switch_is(level)] spoolss_PrinterInfo *info[count],*/
+ [out,subcontext(4),switch_is(level)] spoolss_PrinterInfo **info,
[in,out,ref] uint32 *buf_size,
- [out] uint32 count
- );
+ [out] uint32 count
+ );
/******************/
/* Function: 0x01 */
+ typedef struct {
+ uint32 foo;
+ } spoolss_Devmode;
+
+ typedef struct {
+ uint32 size;
+ spoolss_Devmode *devmode;
+ } spoolss_DevmodeContainer;
+
WERROR spoolss_OpenPrinter(
- [in] unistr *server,
- [in] unistr *printer,
- [in] DATA_BLOB *buffer,
- [in] uint32 access_mask,
- [out,ref] policy_handle *handle
- );
+ [in] unistr *printername,
+ [in] unistr *datatype,
+ [in] spoolss_DevmodeContainer devmode_ctr,
+ [in] uint32 access_mask,
+ [out,ref] policy_handle *handle
+ );
/******************/
/* Function: 0x02 */
- NTSTATUS spoolss_02(
- );
+ WERROR spoolss_SetJob(
+ [in,ref] policy_handle *handle,
+ [in] uint32 job_id,
+ [in] uint32 level,
+ [in] uint32 command
+ );
/******************/
/* Function: 0x03 */
- NTSTATUS spoolss_03(
- );
+ WERROR spoolss_GetJob(
+ [in,ref] policy_handle *handle,
+ [in] uint32 job_id,
+ [in] uint32 level,
+ [in] DATA_BLOB *buffer,
+ [out,subcontext(4),switch_is(level)] spoolss_JobInfo *info,
+ [in,out,ref] uint32 *buf_size
+ );
+
+ typedef struct {
+ uint32 job_id;
+ [relative] nstring *printer_name;
+ [relative] nstring *server_name;
+ [relative] nstring *user_name;
+ [relative] nstring *document_name;
+ [relative] nstring *data_type;
+ [relative] nstring *text_status;
+ uint32 status;
+ uint32 priority;
+ uint32 position;
+ uint32 total_pages;
+ uint32 pages_printed;
+ spoolss_Time time;
+ } spoolss_JobInfo1;
+
+ typedef [nodiscriminant,public] union {
+ [case(1)] spoolss_JobInfo1 info1;
+ } spoolss_JobInfo;
/******************/
/* Function: 0x04 */
- NTSTATUS spoolss_EnumJobs(
+ [noprint,nopull,nopush] WERROR spoolss_EnumJobs(
[in,ref] policy_handle *handle,
[in] uint32 firstjob,
[in] uint32 numjobs,
[in] uint32 level,
- [in,out] DATA_BLOB *buffer,
+ [in] DATA_BLOB *buffer,
+ /* [out,subcontext(4),switch_is(level)] spoolss_JobInfo *info[count],*/
+ [out,subcontext(4),switch_is(level)] spoolss_JobInfo **info,
[in,out,ref] uint32 *buf_size,
- [out] uint32 numjobs
- );
+ [out] uint32 count
+ );
/******************/
/* Function: 0x05 */
- NTSTATUS spoolss_05(
- );
+ WERROR spoolss_AddPrinter(
+ /* This function is not implemented in Samba 3 as no
+ clients have been observed using it. */
+ );
/******************/
/* Function: 0x06 */
- NTSTATUS spoolss_06(
- );
+ WERROR spoolss_DeletePrinter(
+ );
/******************/
/* Function: 0x07 */
- NTSTATUS spoolss_07(
- );
+ WERROR spoolss_SetPrinter(
+ );
/******************/
/* Function: 0x08 */
[in,ref] policy_handle *handle,
[in] uint32 level,
[in] DATA_BLOB *buffer,
- [out,subcontext,switch_is(level)] spoolss_PrinterInfo *info,
+ [out,subcontext(4),switch_is(level)] spoolss_PrinterInfo *info,
[in,out,ref] uint32 *buf_size
- );
+ );
/******************/
/* Function: 0x09 */
- NTSTATUS spoolss_09(
- );
+ WERROR spoolss_AddPrinterDriver(
+ );
+
+ typedef struct {
+ [relative] nstring *driver_name;
+ } spoolss_DriverInfo1;
+
+ typedef struct {
+ uint32 version;
+ [relative] nstring *driver_name;
+ [relative] nstring *architecture;
+ [relative] nstring *driver_path;
+ [relative] nstring *data_file;
+ [relative] nstring *config_file;
+ } spoolss_DriverInfo2;
+
+ typedef struct {
+ uint32 version;
+ [relative] nstring *driver_name;
+ [relative] nstring *architecture;
+ [relative] nstring *driver_path;
+ [relative] nstring *data_file;
+ [relative] nstring *config_file;
+ [relative] nstring *help_file;
+ [relative] nstring *dependent_files; /* array */
+ [relative] nstring *monitor_name;
+ [relative] nstring *default_datatype;
+ } spoolss_DriverInfo3;
+
+ typedef [nodiscriminant,public] union {
+ [case(1)] spoolss_DriverInfo1 info1;
+ [case(2)] spoolss_DriverInfo2 info2;
+ [case(3)] spoolss_DriverInfo3 info3;
+ } spoolss_DriverInfo;
/******************/
/* Function: 0x0a */
- NTSTATUS spoolss_0a(
- );
+ [noprint,nopull,nopush] WERROR spoolss_EnumPrinterDrivers(
+ [in] unistr *server,
+ [in] unistr *environment,
+ [in] uint32 level,
+ [in] DATA_BLOB *buffer,
+ /* [out,subcontext(4),switch_is(level)] spoolss_DriverInfo *info[count],*/
+ [out,subcontext(4),switch_is(level)] spoolss_DriverInfo **info,
+ [in,out,ref] uint32 *buf_size,
+ [out] uint32 count
+ );
/******************/
/* Function: 0x0b */
- NTSTATUS spoolss_0b(
- );
+ WERROR spoolss_GetPrinterDriver(
+ );
/******************/
/* Function: 0x0c */
- NTSTATUS spoolss_0c(
- );
+ WERROR spoolss_GetPrinterDriverDirectory(
+ );
/******************/
/* Function: 0x0d */
- NTSTATUS spoolss_0d(
- );
+ WERROR spoolss_DeletePrinterDriver(
+ [in,ref] policy_handle *handle,
+ [in] unistr *server,
+ [in] unistr architecture,
+ [in] unistr driver
+ );
/******************/
/* Function: 0x0e */
- NTSTATUS spoolss_0e(
- );
+ WERROR spoolss_AddPrintProcessor(
+ );
/******************/
/* Function: 0x0f */
- NTSTATUS spoolss_0f(
- );
+ WERROR spoolss_EnumPrintProcessors(
+ );
/******************/
/* Function: 0x10 */
- NTSTATUS spoolss_10(
- );
+ WERROR spoolss_GetPrintProcessorDirectory(
+ );
/******************/
/* Function: 0x11 */
- NTSTATUS spoolss_11(
- );
+ WERROR spoolss_StartDocPrinter(
+ );
/******************/
/* Function: 0x12 */
- NTSTATUS spoolss_StartPagePrinter(
+ WERROR spoolss_StartPagePrinter(
[in,ref] policy_handle *handle
- );
+ );
/******************/
/* Function: 0x13 */
- NTSTATUS spoolss_13(
- );
+ WERROR spoolss_WritePrinter(
+ );
/******************/
/* Function: 0x14 */
- NTSTATUS spoolss_EndPagePrinter(
+ WERROR spoolss_EndPagePrinter(
[in,ref] policy_handle *handle
- );
+ );
/******************/
/* Function: 0x15 */
- NTSTATUS spoolss_15(
- );
+ WERROR spoolss_AbortPrinter(
+ );
/******************/
/* Function: 0x16 */
- NTSTATUS spoolss_16(
- );
+ WERROR spoolss_ReadPrinter(
+ );
/******************/
/* Function: 0x17 */
- NTSTATUS spoolss_EndDocPrinter(
- );
+ WERROR spoolss_EndDocPrinter(
+ );
/******************/
/* Function: 0x18 */
- NTSTATUS spoolss_18(
- );
+ WERROR spoolss_AddJob(
+ );
/******************/
/* Function: 0x19 */
- NTSTATUS spoolss_19(
- );
+ WERROR spoolss_ScheduleJob(
+ );
/******************/
/* Function: 0x1a */
- NTSTATUS spoolss_1a(
- );
+ WERROR spoolss_GetPrinterData(
+ [in,ref] policy_handle *handle,
+ [in] unistr value_name,
+ [out] uint32 type,
+ [out] DATA_BLOB buffer,
+ [in,out,ref] uint32 *buf_size
+ );
/******************/
/* Function: 0x1b */
- NTSTATUS spoolss_1b(
- );
+ WERROR spoolss_SetPrinterData(
+ [in,ref] policy_handle *handle,
+ [in] unistr value_name,
+ [in] uint32 type,
+ [in] DATA_BLOB buffer,
+ [in] uint32 real_len
+ );
/******************/
/* Function: 0x1c */
- NTSTATUS spoolss_1c(
- );
+ WERROR spoolss_WaitForPrinterChange(
+ );
/******************/
/* Function: 0x1d */
WERROR spoolss_ClosePrinter(
[in,out,ref] policy_handle *handle
- );
+ );
+
+ typedef struct {
+ uint32 flags;
+ [relative] unistr *formname;
+ uint32 width;
+ uint32 length;
+ uint32 left;
+ uint32 top;
+ uint32 right;
+ uint32 bottom;
+ } spoolss_AddFormInfo1;
+
+ typedef union {
+ [case(1)] spoolss_AddFormInfo1 *info1;
+ } spoolss_AddFormInfo;
/******************/
/* Function: 0x1e */
- NTSTATUS spoolss_1e(
- );
+ WERROR spoolss_AddForm(
+ [in,ref] policy_handle *handle,
+ [in] uint32 level,
+ [in,switch_is(level)] spoolss_AddFormInfo info
+ );
/******************/
/* Function: 0x1f */
- NTSTATUS spoolss_1f(
- );
+ WERROR spoolss_DeleteForm(
+ [in,ref] policy_handle *handle,
+ [in] unistr formname
+ );
/******************/
/* Function: 0x20 */
- NTSTATUS spoolss_20(
- );
+ typedef struct {
+ uint32 flags;
+ [relative] nstring *formname;
+ uint32 width;
+ uint32 length;
+ uint32 left;
+ uint32 top;
+ uint32 right;
+ uint32 bottom;
+ } spoolss_FormInfo1;
+
+ WERROR spoolss_GetForm(
+ [in,ref] policy_handle *handle,
+ [in] unistr formname,
+ [in] uint32 level,
+ [in] DATA_BLOB *buffer,
+ [out,subcontext(4),switch_is(level)] spoolss_FormInfo *info,
+ [in,out,ref] uint32 *buf_size
+ );
+
+ typedef struct {
+ uint32 flags;
+ unistr *formname;
+ uint32 width;
+ uint32 length;
+ uint32 left;
+ uint32 top;
+ uint32 right;
+ uint32 bottom;
+ } spoolss_SetFormInfo1;
+
+ typedef union {
+ [case(1)] spoolss_AddFormInfo1 *info1;
+ } spoolss_SetFormInfo;
/******************/
/* Function: 0x21 */
- NTSTATUS spoolss_21(
- );
+ WERROR spoolss_SetForm(
+ [in,ref] policy_handle *handle,
+ [in] unistr formname,
+ [in] uint32 level,
+ [in,switch_is(level)] spoolss_SetFormInfo info
+ );
+
+ typedef [nodiscriminant,public] union {
+ [case(1)] spoolss_FormInfo1 info1;
+ } spoolss_FormInfo;
/******************/
/* Function: 0x22 */
- NTSTATUS spoolss_22(
- );
+ [noprint,nopull,nopush] WERROR spoolss_EnumForms(
+ [in,ref] policy_handle *handle,
+ [in] uint32 level,
+ [in] DATA_BLOB *buffer,
+ /* [out,subcontext(4),switch_is(level)] spoolss_FormInfo *info[count],*/
+ [out,subcontext(4),switch_is(level)] spoolss_FormInfo **info,
+ [in,out,ref] uint32 *buf_size,
+ [out] uint32 count
+ );
+
+ typedef [flag(RELATIVE_CURRENT)] struct {
+ [relative] nstring *port_name;
+ } spoolss_PortInfo1;
+
+ typedef bitmap {
+ SPOOLSS_PORT_TYPE_WRITE = 0x00000001,
+ SPOOLSS_PORT_TYPE_READ = 0x00000002,
+ SPOOLSS_PORT_TYPE_REDIRECTED = 0x00000004,
+ SPOOLSS_PORT_TYPE_NET_ATTACHED = 0x00000008
+ } spoolss_PortType;
+
+ typedef struct {
+ [relative] nstring *port_name;
+ [relative] nstring *monitor_name;
+ [relative] nstring *description;
+ spoolss_PortType port_type;
+ uint32 reserved;
+ } spoolss_PortInfo2;
+
+ typedef [nondiscriminant,public] union {
+ [case(1)] spoolss_PortInfo1 info1;
+ [case(2)] spoolss_PortInfo2 info2;
+ } spoolss_PortInfo;
/******************/
/* Function: 0x23 */
- NTSTATUS spoolss_23(
- );
+ [noprint,nopull,nopush] WERROR spoolss_EnumPorts(
+ [in] unistr *servername,
+ [in] uint32 level,
+ [in] DATA_BLOB *buffer,
+ /* [out,subcontext(4),switch_is(level)] spoolss_PortInfo *info[count], */
+ [out,subcontext(4),switch_is(level)] spoolss_PortInfo **info,
+ [in,out,ref] uint32 *buf_size,
+ [out] uint32 count
+ );
/******************/
/* Function: 0x24 */
- NTSTATUS spoolss_24(
- );
+ WERROR spoolss_EnumMonitors(
+ );
/******************/
/* Function: 0x25 */
- NTSTATUS spoolss_25(
- );
+ WERROR spoolss_AddPort(
+ );
/******************/
/* Function: 0x26 */
- NTSTATUS spoolss_26(
- );
+ WERROR spoolss_ConfigurePort(
+ );
/******************/
/* Function: 0x27 */
- NTSTATUS spoolss_27(
- );
+ WERROR spoolss_DeletePort(
+ );
/******************/
/* Function: 0x28 */
- NTSTATUS spoolss_28(
- );
+ WERROR spoolss_CreatePrinterIC(
+ );
/******************/
/* Function: 0x29 */
- NTSTATUS spoolss_29(
- );
+ WERROR spoolss_PlayGDIScriptOnPrinterIC(
+ );
/******************/
/* Function: 0x2a */
- NTSTATUS spoolss_2a(
- );
+ WERROR spoolss_DeletePrinterIC(
+ );
/******************/
/* Function: 0x2b */
- NTSTATUS spoolss_2b(
- );
+ WERROR spoolss_AddPrinterConnection(
+ );
/******************/
/* Function: 0x2c */
- NTSTATUS spoolss_2c(
- );
+ WERROR spoolss_DeletePrinterConnection(
+ );
/******************/
/* Function: 0x2d */
- NTSTATUS spoolss_2d(
- );
+ WERROR spoolss_PrinterMessageBox(
+ /* Marked as obsolete in MSDN. "Not necessary and has
+ no effect". */
+ );
/******************/
/* Function: 0x2e */
- NTSTATUS spoolss_2e(
- );
+ WERROR spoolss_AddMonitor(
+ );
/******************/
/* Function: 0x2f */
- NTSTATUS spoolss_2f(
- );
+ WERROR spoolss_DeleteMonitor(
+ );
/******************/
/* Function: 0x30 */
- NTSTATUS spoolss_30(
- );
+ WERROR spoolss_DeletePrintProcessor(
+ );
/******************/
/* Function: 0x31 */
- NTSTATUS spoolss_31(
- );
+ WERROR spoolss_AddPrintProvidor(
+ );
/******************/
/* Function: 0x32 */
- NTSTATUS spoolss_32(
- );
+ WERROR spoolss_DeletePrintProvidor(
+ );
/******************/
/* Function: 0x33 */
- NTSTATUS spoolss_33(
- );
+ WERROR spoolss_EnumPrintProcDataTypes(
+ );
/******************/
/* Function: 0x34 */
- NTSTATUS spoolss_34(
- );
+ WERROR spoolss_ResetPrinter(
+ );
/******************/
/* Function: 0x35 */
- NTSTATUS spoolss_35(
- );
+ WERROR spoolss_GetPrinterDriver2(
+ [in,ref] policy_handle *handle,
+ [in] unistr *architecture,
+ [in] uint32 level,
+ [in,out] DATA_BLOB *buffer,
+ [in,out,ref] uint32 *buf_size,
+ [in] uint32 client_major_version,
+ [in] uint32 client_minor_version,
+ [out] uint32 server_major_version,
+ [out] uint32 server_minor_version
+ );
/******************/
/* Function: 0x36 */
- NTSTATUS spoolss_36(
- );
+ WERROR spoolss_FindFirstPrinterChangeNotification(
+ );
/******************/
/* Function: 0x37 */
- NTSTATUS spoolss_37(
- );
+ WERROR spoolss_FindNextPrinterChangeNotification(
+ );
/******************/
/* Function: 0x38 */
- NTSTATUS spoolss_38(
- );
+ WERROR spoolss_FindClosePrinterNotify(
+ );
/******************/
/* Function: 0x39 */
- NTSTATUS spoolss_39(
- );
+ WERROR spoolss_RouterFindFirstPrinterChangeNotificationOld(
+ );
/******************/
/* Function: 0x3a */
- NTSTATUS spoolss_3a(
- );
+ WERROR spoolss_ReplyOpenPrinter(
+ );
/******************/
/* Function: 0x3b */
- NTSTATUS spoolss_3b(
- );
+ WERROR spoolss_RouterReplyPrinter(
+ );
/******************/
/* Function: 0x3c */
- NTSTATUS spoolss_3c(
- );
+ WERROR spoolss_ReplyClosePrinter(
+ );
/******************/
/* Function: 0x3d */
- NTSTATUS spoolss_3d(
- );
+ WERROR spoolss_AddPortEx(
+ );
/******************/
/* Function: 0x3e */
- NTSTATUS spoolss_3e(
- );
+ WERROR spoolss_RouterFindFirstPrinterChangeNotification(
+ );
/******************/
/* Function: 0x3f */
- NTSTATUS spoolss_3f(
- );
+ WERROR spoolss_SpoolerInit(
+ );
/******************/
/* Function: 0x40 */
- NTSTATUS spoolss_40(
- );
+ WERROR spoolss_ResetPrinterEx(
+ );
/******************/
/* Function: 0x41 */
- NTSTATUS spoolss_41(
- );
+ WERROR spoolss_RemoteFindFirstPrinterChangeNotifyEx(
+ );
/******************/
/* Function: 0x42 */
- NTSTATUS spoolss_42(
- );
+ WERROR spoolss_RouterRefreshPrinterChangeNotification(
+ );
/******************/
/* Function: 0x43 */
- NTSTATUS spoolss_43(
- );
+ WERROR spoolss_RemoteFindNextPrinterChangeNotifyEx(
+ );
/******************/
/* Function: 0x44 */
- NTSTATUS spoolss_44(
- );
-
- typedef struct {
- uint32 foo;
- } spoolss_Devmode;
-
- typedef struct {
- uint32 size;
- spoolss_Devmode *devmode;
- } spoolss_DevmodeContainer;
+ WERROR spoolss_44(
+ );
typedef struct {
uint32 size;
[in] unistr *printername,
[in] unistr *datatype,
[in] spoolss_DevmodeContainer devmode_ctr,
- [in] uint32 access_required,
+ [in] uint32 access_mask,
[in] uint32 level,
[in,switch_is(level)] spoolss_UserLevel userlevel,
[out,ref] policy_handle *handle
- );
+ );
/******************/
/* Function: 0x46 */
- NTSTATUS spoolss_46(
- );
+ WERROR spoolss_AddPrinterEx(
+ [in] unistr *server,
+ [in] uint32 level,
+ [in,switch_is(level)] spoolss_PrinterInfo *info,
+ [in] spoolss_DevmodeContainer devmode_ctr,
+ [in] security_descriptor *secdesc,
+ [in] uint32 ulevel,
+ [in,switch_is(ulevel)] spoolss_UserLevel userlevel
+ );
/******************/
/* Function: 0x47 */
- NTSTATUS spoolss_47(
- );
+ WERROR spoolss_47(
+ );
/******************/
/* Function: 0x48 */
[in,ref] policy_handle *handle,
[in] uint32 enum_index,
[in] uint32 value_offered,
- [out] DATA_BLOB value,
+ [out] lstring value_name,
[out] uint32 value_needed,
[out] uint32 printerdata_type,
- [out] DATA_BLOB data,
+ [out] DATA_BLOB buffer,
[in,out,ref] uint32 *data_size
- );
+ );
/******************/
/* Function: 0x49 */
- NTSTATUS spoolss_49(
- );
+ WERROR spoolss_DeletePrinterData(
+ [in,ref] policy_handle *handle,
+ [in] unistr value_name
+ );
/******************/
/* Function: 0x4a */
- NTSTATUS spoolss_4a(
- );
+ WERROR spoolss_4a(
+ );
/******************/
/* Function: 0x4b */
- NTSTATUS spoolss_4b(
- );
+ WERROR spoolss_4b(
+ );
/******************/
/* Function: 0x4c */
- NTSTATUS spoolss_4c(
- );
+ WERROR spoolss_4c(
+ );
/******************/
/* Function: 0x4d */
- NTSTATUS spoolss_4d(
- );
+ WERROR spoolss_SetPrinterDataEx(
+ [in,ref] policy_handle *handle,
+ [in] unistr key_name,
+ [in] unistr value_name,
+ [in] uint32 type,
+ [in] DATA_BLOB buffer,
+ [in,out,ref] uint32 *buf_size
+ );
/******************/
/* Function: 0x4e */
- NTSTATUS spoolss_4e(
- );
+ WERROR spoolss_GetPrinterDataEx(
+ [in,ref] policy_handle *handle,
+ [in] unistr key_name,
+ [in] unistr value_name,
+ [out] uint32 type,
+ [out] DATA_BLOB buffer,
+ [in,out,ref] uint32 *buf_size
+ );
/******************/
/* Function: 0x4f */
- NTSTATUS spoolss_4f(
- );
+ WERROR spoolss_EnumPrinterDataEx(
+ [in,ref] policy_handle *handle,
+ [in] unistr key_name,
+ [out] DATA_BLOB buffer,
+ [in,out] uint32 buf_size,
+ [out] uint32 count
+ );
/******************/
/* Function: 0x50 */
- NTSTATUS spoolss_50(
- );
+ WERROR spoolss_EnumPrinterKey(
+ );
/******************/
/* Function: 0x51 */
- NTSTATUS spoolss_51(
- );
+ WERROR spoolss_DeletePrinterDataEx(
+ [in,ref] policy_handle *handle,
+ [in] unistr key_name,
+ [in] unistr value_name
+ );
/******************/
/* Function: 0x52 */
- NTSTATUS spoolss_52(
- );
+ WERROR spoolss_DeletePrinterKey(
+ );
/******************/
/* Function: 0x53 */
- NTSTATUS spoolss_53(
- );
+ WERROR spoolss_53(
+ );
/******************/
/* Function: 0x54 */
- NTSTATUS spoolss_54(
- );
+ WERROR spoolss_DeletePrinterDriverEx(
+ );
/******************/
/* Function: 0x55 */
- NTSTATUS spoolss_55(
- );
+ WERROR spoolss_55(
+ );
/******************/
/* Function: 0x56 */
- NTSTATUS spoolss_56(
- );
+ WERROR spoolss_56(
+ );
/******************/
/* Function: 0x57 */
- NTSTATUS spoolss_57(
- );
+ WERROR spoolss_57(
+ );
/******************/
/* Function: 0x58 */
- NTSTATUS spoolss_58(
- );
+ WERROR spoolss_58(
+ );
/******************/
/* Function: 0x59 */
- NTSTATUS spoolss_59(
- );
+ WERROR spoolss_AddPrinterDriverEx(
+ );
/******************/
/* Function: 0x5a */
- NTSTATUS spoolss_5a(
- );
+ WERROR spoolss_5a(
+ );
/******************/
/* Function: 0x5b */
- NTSTATUS spoolss_5b(
- );
+ WERROR spoolss_5b(
+ );
/******************/
/* Function: 0x5c */
- NTSTATUS spoolss_5c(
- );
+ WERROR spoolss_5c(
+ );
/******************/
/* Function: 0x5d */
- NTSTATUS spoolss_5d(
- );
+ WERROR spoolss_5d(
+ );
/******************/
/* Function: 0x5e */
- NTSTATUS spoolss_5e(
- );
+ WERROR spoolss_5e(
+ );
/******************/
/* Function: 0x5f */
- NTSTATUS spoolss_5f(
- );
-
+ WERROR spoolss_5f(
+ );
}