r5505: make usage of bitmap's :-)
[samba.git] / source4 / librpc / idl / spoolss.idl
index a78dabd533b6a06a880df69618cd13430ef01740..aff4f25664ba3f94b9f60a1bfaf0548c0e14dd07 100644 (file)
@@ -1,17 +1,62 @@
+#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;
@@ -30,7 +75,7 @@
                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(
+       );
 }