s3-spoolss: use pidl for _spoolss_EnumPrinterKey.
[ira/wip.git] / source3 / rpc_server / srv_spoolss.c
index c3fafbd10d5cec92d88644b8c5a5cfb67baa94e2..1b9cdb343845ed9d7c8bc6b53059ff3936d4062c 100644 (file)
@@ -54,57 +54,16 @@ static bool proxy_spoolss_call(pipes_struct *p, uint8_t opnum)
 
 static bool api_spoolss_open_printer(pipes_struct *p)
 {
-       SPOOL_Q_OPEN_PRINTER q_u;
-       SPOOL_R_OPEN_PRINTER r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_open_printer("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_open_printer: unable to unmarshall SPOOL_Q_OPEN_PRINTER.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_open_printer( p, &q_u, &r_u);
-       
-       if (!spoolss_io_r_open_printer("",&r_u,rdata,0)){
-               DEBUG(0,("spoolss_io_r_open_printer: unable to marshall SPOOL_R_OPEN_PRINTER.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_OPENPRINTER);
 }
 
-
 /********************************************************************
  * api_spoolss_open_printer_ex
  ********************************************************************/
 
 static bool api_spoolss_open_printer_ex(pipes_struct *p)
 {
-       SPOOL_Q_OPEN_PRINTER_EX q_u;
-       SPOOL_R_OPEN_PRINTER_EX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_open_printer_ex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_open_printer_ex: unable to unmarshall SPOOL_Q_OPEN_PRINTER_EX.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_open_printer_ex( p, &q_u, &r_u);
-
-       if (!spoolss_io_r_open_printer_ex("",&r_u,rdata,0)){
-               DEBUG(0,("spoolss_io_r_open_printer_ex: unable to marshall SPOOL_R_OPEN_PRINTER_EX.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_OPENPRINTEREX);
 }
 
 /********************************************************************
@@ -115,28 +74,7 @@ static bool api_spoolss_open_printer_ex(pipes_struct *p)
 
 static bool api_spoolss_getprinterdata(pipes_struct *p)
 {
-       SPOOL_Q_GETPRINTERDATA q_u;
-       SPOOL_R_GETPRINTERDATA r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       /* read the stream and fill the struct */
-       if (!spoolss_io_q_getprinterdata("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getprinterdata: unable to unmarshall SPOOL_Q_GETPRINTERDATA.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_getprinterdata( p, &q_u, &r_u);
-
-       if (!spoolss_io_r_getprinterdata("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_getprinterdata: unable to marshall SPOOL_R_GETPRINTERDATA.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETPRINTERDATA);
 }
 
 /********************************************************************
@@ -202,27 +140,7 @@ static bool api_spoolss_deleteprinterdriver(pipes_struct *p)
 
 static bool api_spoolss_rffpcnex(pipes_struct *p)
 {
-       SPOOL_Q_RFFPCNEX q_u;
-       SPOOL_R_RFFPCNEX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_rffpcnex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_rffpcnex: unable to unmarshall SPOOL_Q_RFFPCNEX.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_rffpcnex(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_rffpcnex("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_rffpcnex: unable to marshall SPOOL_R_RFFPCNEX.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_REMOTEFINDFIRSTPRINTERCHANGENOTIFYEX);
 }
 
 
@@ -239,30 +157,7 @@ static bool api_spoolss_rffpcnex(pipes_struct *p)
 
 static bool api_spoolss_rfnpcnex(pipes_struct *p)
 {
-       SPOOL_Q_RFNPCNEX q_u;
-       SPOOL_R_RFNPCNEX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_rfnpcnex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_rfnpcnex: unable to unmarshall SPOOL_Q_RFNPCNEX.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_rfnpcnex(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_rfnpcnex("", &r_u, rdata, 0)) {
-               SAFE_FREE(r_u.info.data);
-               DEBUG(0,("spoolss_io_r_rfnpcnex: unable to marshall SPOOL_R_RFNPCNEX.\n"));
-               return False;
-       }
-
-       SAFE_FREE(r_u.info.data);
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ROUTERREFRESHPRINTERCHANGENOTIFY);
 }
 
 
@@ -274,27 +169,7 @@ static bool api_spoolss_rfnpcnex(pipes_struct *p)
 
 static bool api_spoolss_enumprinters(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTERS q_u;
-       SPOOL_R_ENUMPRINTERS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_enumprinters("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumprinters: unable to unmarshall SPOOL_Q_ENUMPRINTERS.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_enumprinters( p, &q_u, &r_u);
-
-       if (!spoolss_io_r_enumprinters("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_enumprinters: unable to marshall SPOOL_R_ENUMPRINTERS.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPRINTERS);
 }
 
 /********************************************************************
@@ -305,27 +180,7 @@ static bool api_spoolss_enumprinters(pipes_struct *p)
 
 static bool api_spoolss_getprinter(pipes_struct *p)
 {
-       SPOOL_Q_GETPRINTER q_u;
-       SPOOL_R_GETPRINTER r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_getprinter("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getprinter: unable to unmarshall SPOOL_Q_GETPRINTER.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_getprinter(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_getprinter("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_getprinter: unable to marshall SPOOL_R_GETPRINTER.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETPRINTER);
 }
 
 /********************************************************************
@@ -336,27 +191,7 @@ static bool api_spoolss_getprinter(pipes_struct *p)
 
 static bool api_spoolss_getprinterdriver2(pipes_struct *p)
 {
-       SPOOL_Q_GETPRINTERDRIVER2 q_u;
-       SPOOL_R_GETPRINTERDRIVER2 r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_getprinterdriver2("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getprinterdriver2: unable to unmarshall SPOOL_Q_GETPRINTERDRIVER2.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_getprinterdriver2(p, &q_u, &r_u);
-       
-       if(!spoolss_io_r_getprinterdriver2("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_getprinterdriver2: unable to marshall SPOOL_R_GETPRINTERDRIVER2.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETPRINTERDRIVER2);
 }
 
 /********************************************************************
@@ -386,27 +221,7 @@ static bool api_spoolss_endpageprinter(pipes_struct *p)
 
 static bool api_spoolss_startdocprinter(pipes_struct *p)
 {
-       SPOOL_Q_STARTDOCPRINTER q_u;
-       SPOOL_R_STARTDOCPRINTER r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_startdocprinter("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_startdocprinter: unable to unmarshall SPOOL_Q_STARTDOCPRINTER.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_startdocprinter(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_startdocprinter("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_startdocprinter: unable to marshall SPOOL_R_STARTDOCPRINTER.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_STARTDOCPRINTER);
 }
 
 /********************************************************************
@@ -431,27 +246,7 @@ static bool api_spoolss_writeprinter(pipes_struct *p)
 
 static bool api_spoolss_setprinter(pipes_struct *p)
 {
-       SPOOL_Q_SETPRINTER q_u;
-       SPOOL_R_SETPRINTER r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_setprinter("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_setprinter: unable to unmarshall SPOOL_Q_SETPRINTER.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_setprinter(p, &q_u, &r_u);
-       
-       if(!spoolss_io_r_setprinter("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_setprinter: unable to marshall SPOOL_R_SETPRINTER.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_SETPRINTER);
 }
 
 /****************************************************************************
@@ -459,27 +254,7 @@ static bool api_spoolss_setprinter(pipes_struct *p)
 
 static bool api_spoolss_fcpn(pipes_struct *p)
 {
-       SPOOL_Q_FCPN q_u;
-       SPOOL_R_FCPN r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_fcpn("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_fcpn: unable to unmarshall SPOOL_Q_FCPN.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_fcpn(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_fcpn("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_fcpn: unable to marshall SPOOL_R_FCPN.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_FINDCLOSEPRINTERNOTIFY);
 }
 
 /****************************************************************************
@@ -487,27 +262,7 @@ static bool api_spoolss_fcpn(pipes_struct *p)
 
 static bool api_spoolss_addjob(pipes_struct *p)
 {
-       SPOOL_Q_ADDJOB q_u;
-       SPOOL_R_ADDJOB r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_addjob("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_addjob: unable to unmarshall SPOOL_Q_ADDJOB.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_addjob(p, &q_u, &r_u);
-               
-       if(!spoolss_io_r_addjob("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_addjob: unable to marshall SPOOL_R_ADDJOB.\n"));
-               return False;
-       }
-
-       return True;            
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ADDJOB);
 }
 
 /****************************************************************************
@@ -515,27 +270,7 @@ static bool api_spoolss_addjob(pipes_struct *p)
 
 static bool api_spoolss_enumjobs(pipes_struct *p)
 {
-       SPOOL_Q_ENUMJOBS q_u;
-       SPOOL_R_ENUMJOBS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_enumjobs("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumjobs: unable to unmarshall SPOOL_Q_ENUMJOBS.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_enumjobs(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_enumjobs("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_enumjobs: unable to marshall SPOOL_R_ENUMJOBS.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMJOBS);
 }
 
 /****************************************************************************
@@ -543,27 +278,7 @@ static bool api_spoolss_enumjobs(pipes_struct *p)
 
 static bool api_spoolss_schedulejob(pipes_struct *p)
 {
-       SPOOL_Q_SCHEDULEJOB q_u;
-       SPOOL_R_SCHEDULEJOB r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_schedulejob("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_schedulejob: unable to unmarshall SPOOL_Q_SCHEDULEJOB.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_schedulejob(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_schedulejob("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_schedulejob: unable to marshall SPOOL_R_SCHEDULEJOB.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_SCHEDULEJOB);
 }
 
 /****************************************************************************
@@ -571,27 +286,7 @@ static bool api_spoolss_schedulejob(pipes_struct *p)
 
 static bool api_spoolss_setjob(pipes_struct *p)
 {
-       SPOOL_Q_SETJOB q_u;
-       SPOOL_R_SETJOB r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_setjob("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_setjob: unable to unmarshall SPOOL_Q_SETJOB.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_setjob(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_setjob("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_setjob: unable to marshall SPOOL_R_SETJOB.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_SETJOB);
 }
 
 /****************************************************************************
@@ -599,27 +294,7 @@ static bool api_spoolss_setjob(pipes_struct *p)
 
 static bool api_spoolss_enumprinterdrivers(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTERDRIVERS q_u;
-       SPOOL_R_ENUMPRINTERDRIVERS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_enumprinterdrivers("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumprinterdrivers: unable to unmarshall SPOOL_Q_ENUMPRINTERDRIVERS.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_enumprinterdrivers(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_enumprinterdrivers("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_enumprinterdrivers: unable to marshall SPOOL_R_ENUMPRINTERDRIVERS.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPRINTERDRIVERS);
 }
 
 /****************************************************************************
@@ -635,27 +310,7 @@ static bool api_spoolss_getform(pipes_struct *p)
 
 static bool api_spoolss_enumforms(pipes_struct *p)
 {
-       SPOOL_Q_ENUMFORMS q_u;
-       SPOOL_R_ENUMFORMS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if (!spoolss_io_q_enumforms("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumforms: unable to unmarshall SPOOL_Q_ENUMFORMS.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_enumforms(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_enumforms("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_enumforms: unable to marshall SPOOL_R_ENUMFORMS.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMFORMS);
 }
 
 /****************************************************************************
@@ -663,27 +318,7 @@ static bool api_spoolss_enumforms(pipes_struct *p)
 
 static bool api_spoolss_enumports(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPORTS q_u;
-       SPOOL_R_ENUMPORTS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_enumports("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumports: unable to unmarshall SPOOL_Q_ENUMPORTS.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_enumports(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_enumports("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_enumports: unable to marshall SPOOL_R_ENUMPORTS.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPORTS);
 }
 
 /****************************************************************************
@@ -691,27 +326,7 @@ static bool api_spoolss_enumports(pipes_struct *p)
 
 static bool api_spoolss_addprinterex(pipes_struct *p)
 {
-       SPOOL_Q_ADDPRINTEREX q_u;
-       SPOOL_R_ADDPRINTEREX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_addprinterex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_addprinterex: unable to unmarshall SPOOL_Q_ADDPRINTEREX.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_addprinterex(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_addprinterex("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_addprinterex: unable to marshall SPOOL_R_ADDPRINTEREX.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ADDPRINTEREX);
 }
 
 /****************************************************************************
@@ -719,36 +334,7 @@ static bool api_spoolss_addprinterex(pipes_struct *p)
 
 static bool api_spoolss_addprinterdriver(pipes_struct *p)
 {
-       SPOOL_Q_ADDPRINTERDRIVER q_u;
-       SPOOL_R_ADDPRINTERDRIVER r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_addprinterdriver("", &q_u, data, 0)) {
-               if (q_u.level != 3 && q_u.level != 6) {
-                       /* Clever hack from Martin Zielinski <mz@seh.de>
-                        * to allow downgrade from level 8 (Vista).
-                        */
-                       DEBUG(3,("api_spoolss_addprinterdriver: unknown SPOOL_Q_ADDPRINTERDRIVER level %u.\n",
-                               (unsigned int)q_u.level ));
-                       setup_fault_pdu(p, NT_STATUS(DCERPC_FAULT_INVALID_TAG));
-                       return True;
-               }
-               DEBUG(0,("spoolss_io_q_addprinterdriver: unable to unmarshall SPOOL_Q_ADDPRINTERDRIVER.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_addprinterdriver(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_addprinterdriver("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_addprinterdriver: unable to marshall SPOOL_R_ADDPRINTERDRIVER.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ADDPRINTERDRIVER);
 }
 
 /****************************************************************************
@@ -756,27 +342,7 @@ static bool api_spoolss_addprinterdriver(pipes_struct *p)
 
 static bool api_spoolss_getprinterdriverdirectory(pipes_struct *p)
 {
-       SPOOL_Q_GETPRINTERDRIVERDIR q_u;
-       SPOOL_R_GETPRINTERDRIVERDIR r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_getprinterdriverdir("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getprinterdriverdir: unable to unmarshall SPOOL_Q_GETPRINTERDRIVERDIR.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_getprinterdriverdirectory(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_getprinterdriverdir("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_getprinterdriverdir: unable to marshall SPOOL_R_GETPRINTERDRIVERDIR.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETPRINTERDRIVERDIRECTORY);
 }
 
 /****************************************************************************
@@ -784,27 +350,7 @@ static bool api_spoolss_getprinterdriverdirectory(pipes_struct *p)
 
 static bool api_spoolss_enumprinterdata(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTERDATA q_u;
-       SPOOL_R_ENUMPRINTERDATA r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_enumprinterdata("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumprinterdata: unable to unmarshall SPOOL_Q_ENUMPRINTERDATA.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_enumprinterdata(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_enumprinterdata("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_enumprinterdata: unable to marshall SPOOL_R_ENUMPRINTERDATA.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPRINTERDATA);
 }
 
 /****************************************************************************
@@ -812,54 +358,14 @@ static bool api_spoolss_enumprinterdata(pipes_struct *p)
 
 static bool api_spoolss_setprinterdata(pipes_struct *p)
 {
-       SPOOL_Q_SETPRINTERDATA q_u;
-       SPOOL_R_SETPRINTERDATA r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_setprinterdata("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_setprinterdata: unable to unmarshall SPOOL_Q_SETPRINTERDATA.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_setprinterdata(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_setprinterdata("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_setprinterdata: unable to marshall SPOOL_R_SETPRINTERDATA.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_SETPRINTERDATA);
 }
 
 /****************************************************************************
 ****************************************************************************/
 static bool api_spoolss_reset_printer(pipes_struct *p)
 {
-       SPOOL_Q_RESETPRINTER q_u;
-       SPOOL_R_RESETPRINTER r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       if(!spoolss_io_q_resetprinter("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_setprinterdata: unable to unmarshall SPOOL_Q_SETPRINTERDATA.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_resetprinter(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_resetprinter("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_setprinterdata: unable to marshall SPOOL_R_RESETPRINTER.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_RESETPRINTER);
 }
 
 /****************************************************************************
@@ -890,27 +396,7 @@ static bool api_spoolss_setform(pipes_struct *p)
 
 static bool api_spoolss_enumprintprocessors(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTPROCESSORS q_u;
-       SPOOL_R_ENUMPRINTPROCESSORS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_enumprintprocessors("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumprintprocessors: unable to unmarshall SPOOL_Q_ENUMPRINTPROCESSORS.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_enumprintprocessors(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_enumprintprocessors("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_enumprintprocessors: unable to marshall SPOOL_R_ENUMPRINTPROCESSORS.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPRINTPROCESSORS);
 }
 
 /****************************************************************************
@@ -918,31 +404,7 @@ static bool api_spoolss_enumprintprocessors(pipes_struct *p)
 
 static bool api_spoolss_addprintprocessor(pipes_struct *p)
 {
-       SPOOL_Q_ADDPRINTPROCESSOR q_u;
-       SPOOL_R_ADDPRINTPROCESSOR r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_addprintprocessor("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_addprintprocessor: unable to unmarshall SPOOL_Q_ADDPRINTPROCESSOR.\n"));
-               return False;
-       }
-       
-       /* for now, just indicate success and ignore the add.  We'll
-          automatically set the winprint processor for printer
-          entries later.  Used to debug the LexMark Optra S 1855 PCL
-          driver --jerry */
-       r_u.status = WERR_OK;
-
-       if(!spoolss_io_r_addprintprocessor("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_addprintprocessor: unable to marshall SPOOL_R_ADDPRINTPROCESSOR.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ADDPRINTPROCESSOR);
 }
 
 /****************************************************************************
@@ -950,27 +412,7 @@ static bool api_spoolss_addprintprocessor(pipes_struct *p)
 
 static bool api_spoolss_enumprintprocdatatypes(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTPROCDATATYPES q_u;
-       SPOOL_R_ENUMPRINTPROCDATATYPES r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_enumprintprocdatatypes("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumprintprocdatatypes: unable to unmarshall SPOOL_Q_ENUMPRINTPROCDATATYPES.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_enumprintprocdatatypes(p, &q_u, &r_u);
-
-       if(!spoolss_io_r_enumprintprocdatatypes("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_enumprintprocdatatypes: unable to marshall SPOOL_R_ENUMPRINTPROCDATATYPES.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPRINTPROCDATATYPES);
 }
 
 /****************************************************************************
@@ -978,27 +420,7 @@ static bool api_spoolss_enumprintprocdatatypes(pipes_struct *p)
 
 static bool api_spoolss_enumprintmonitors(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTMONITORS q_u;
-       SPOOL_R_ENUMPRINTMONITORS r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if (!spoolss_io_q_enumprintmonitors("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_enumprintmonitors: unable to unmarshall SPOOL_Q_ENUMPRINTMONITORS.\n"));
-               return False;
-       }
-               
-       r_u.status = _spoolss_enumprintmonitors(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_enumprintmonitors("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_enumprintmonitors: unable to marshall SPOOL_R_ENUMPRINTMONITORS.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMMONITORS);
 }
 
 /****************************************************************************
@@ -1006,27 +428,7 @@ static bool api_spoolss_enumprintmonitors(pipes_struct *p)
 
 static bool api_spoolss_getjob(pipes_struct *p)
 {
-       SPOOL_Q_GETJOB q_u;
-       SPOOL_R_GETJOB r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_getjob("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getjob: unable to unmarshall SPOOL_Q_GETJOB.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_getjob(p, &q_u, &r_u);
-       
-       if(!spoolss_io_r_getjob("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_getjob: unable to marshall SPOOL_R_GETJOB.\n"));
-               return False;
-       }
-               
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETJOB);
 }
 
 /********************************************************************
@@ -1037,28 +439,7 @@ static bool api_spoolss_getjob(pipes_struct *p)
 
 static bool api_spoolss_getprinterdataex(pipes_struct *p)
 {
-       SPOOL_Q_GETPRINTERDATAEX q_u;
-       SPOOL_R_GETPRINTERDATAEX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-
-       /* read the stream and fill the struct */
-       if (!spoolss_io_q_getprinterdataex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getprinterdataex: unable to unmarshall SPOOL_Q_GETPRINTERDATAEX.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_getprinterdataex( p, &q_u, &r_u);
-
-       if (!spoolss_io_r_getprinterdataex("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_getprinterdataex: unable to marshall SPOOL_R_GETPRINTERDATAEX.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETPRINTERDATAEX);
 }
 
 /****************************************************************************
@@ -1066,27 +447,7 @@ static bool api_spoolss_getprinterdataex(pipes_struct *p)
 
 static bool api_spoolss_setprinterdataex(pipes_struct *p)
 {
-       SPOOL_Q_SETPRINTERDATAEX q_u;
-       SPOOL_R_SETPRINTERDATAEX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_setprinterdataex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_setprinterdataex: unable to unmarshall SPOOL_Q_SETPRINTERDATAEX.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_setprinterdataex(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_setprinterdataex("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_setprinterdataex: unable to marshall SPOOL_R_SETPRINTERDATAEX.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_SETPRINTERDATAEX);
 }
 
 
@@ -1095,27 +456,7 @@ static bool api_spoolss_setprinterdataex(pipes_struct *p)
 
 static bool api_spoolss_enumprinterkey(pipes_struct *p)
 {
-       SPOOL_Q_ENUMPRINTERKEY q_u;
-       SPOOL_R_ENUMPRINTERKEY r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_enumprinterkey("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_setprinterkey: unable to unmarshall SPOOL_Q_ENUMPRINTERKEY.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_enumprinterkey(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_enumprinterkey("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_enumprinterkey: unable to marshall SPOOL_R_ENUMPRINTERKEY.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ENUMPRINTERKEY);
 }
 
 /****************************************************************************
@@ -1151,27 +492,7 @@ static bool api_spoolss_enumprinterdataex(pipes_struct *p)
 
 static bool api_spoolss_getprintprocessordirectory(pipes_struct *p)
 {
-       SPOOL_Q_GETPRINTPROCESSORDIRECTORY q_u;
-       SPOOL_R_GETPRINTPROCESSORDIRECTORY r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_getprintprocessordirectory("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_getprintprocessordirectory: unable to unmarshall SPOOL_Q_GETPRINTPROCESSORDIRECTORY.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_getprintprocessordirectory(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_getprintprocessordirectory("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_getprintprocessordirectory: unable to marshall SPOOL_R_GETPRINTPROCESSORDIRECTORY.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_GETPRINTPROCESSORDIRECTORY);
 }
 
 /****************************************************************************
@@ -1195,36 +516,7 @@ static bool api_spoolss_deleteprinterkey(pipes_struct *p)
 
 static bool api_spoolss_addprinterdriverex(pipes_struct *p)
 {
-       SPOOL_Q_ADDPRINTERDRIVEREX q_u;
-       SPOOL_R_ADDPRINTERDRIVEREX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_addprinterdriverex("", &q_u, data, 0)) {
-               if (q_u.level != 3 && q_u.level != 6) {
-                       /* Clever hack from Martin Zielinski <mz@seh.de>
-                        * to allow downgrade from level 8 (Vista).
-                        */
-                       DEBUG(3,("api_spoolss_addprinterdriverex: unknown SPOOL_Q_ADDPRINTERDRIVEREX level %u.\n",
-                               (unsigned int)q_u.level ));
-                       setup_fault_pdu(p, NT_STATUS(DCERPC_FAULT_INVALID_TAG));
-                       return True;
-               }
-               DEBUG(0,("spoolss_io_q_addprinterdriverex: unable to unmarshall SPOOL_Q_ADDPRINTERDRIVEREX.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_addprinterdriverex(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_addprinterdriverex("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_addprinterdriverex: unable to marshall SPOOL_R_ADDPRINTERDRIVEREX.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_ADDPRINTERDRIVEREX);
 }
 
 /****************************************************************************
@@ -1232,27 +524,7 @@ static bool api_spoolss_addprinterdriverex(pipes_struct *p)
 
 static bool api_spoolss_deleteprinterdriverex(pipes_struct *p)
 {
-       SPOOL_Q_DELETEPRINTERDRIVEREX q_u;
-       SPOOL_R_DELETEPRINTERDRIVEREX r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_deleteprinterdriverex("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_deleteprinterdriverex: unable to unmarshall SPOOL_Q_DELETEPRINTERDRIVEREX.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_deleteprinterdriverex(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_deleteprinterdriverex("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_deleteprinterdriverex: unable to marshall SPOOL_R_DELETEPRINTERDRIVEREX.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_DELETEPRINTERDRIVEREX);
 }
 
 /****************************************************************************
@@ -1260,27 +532,7 @@ static bool api_spoolss_deleteprinterdriverex(pipes_struct *p)
 
 static bool api_spoolss_xcvdataport(pipes_struct *p)
 {
-       SPOOL_Q_XCVDATAPORT q_u;
-       SPOOL_R_XCVDATAPORT r_u;
-       prs_struct *data = &p->in_data.data;
-       prs_struct *rdata = &p->out_data.rdata;
-       
-       ZERO_STRUCT(q_u);
-       ZERO_STRUCT(r_u);
-       
-       if(!spoolss_io_q_xcvdataport("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_replyopenprinter: unable to unmarshall SPOOL_Q_XCVDATAPORT.\n"));
-               return False;
-       }
-       
-       r_u.status = _spoolss_xcvdataport(p, &q_u, &r_u);
-                               
-       if(!spoolss_io_r_xcvdataport("", &r_u, rdata, 0)) {
-               DEBUG(0,("spoolss_io_r_replyopenprinter: unable to marshall SPOOL_R_XCVDATAPORT.\n"));
-               return False;
-       }
-       
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_XCVDATA);
 }
 
 /*******************************************************************