s3-spoolss: use pidl for _spoolss_DeletePrinter.
authorGünther Deschner <gd@samba.org>
Fri, 14 Nov 2008 22:43:30 +0000 (23:43 +0100)
committerGünther Deschner <gd@samba.org>
Fri, 6 Feb 2009 20:30:39 +0000 (21:30 +0100)
Guenther

source3/rpc_server/srv_spoolss.c
source3/rpc_server/srv_spoolss_nt.c

index 24d4049ef85ca220f1114bde3031415a3bc7ec18..c5fed8cb39b1889f985e26c96e4e41bbb988c684 100644 (file)
@@ -221,30 +221,9 @@ static bool api_spoolss_abortprinter(pipes_struct *p)
 
 static bool api_spoolss_deleteprinter(pipes_struct *p)
 {
-       SPOOL_Q_DELETEPRINTER q_u;
-       SPOOL_R_DELETEPRINTER 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_deleteprinter("", &q_u, data, 0)) {
-               DEBUG(0,("spoolss_io_q_deleteprinter: unable to unmarshall SPOOL_Q_DELETEPRINTER.\n"));
-               return False;
-       }
-
-       r_u.status = _spoolss_deleteprinter(p, &q_u, &r_u);
-
-       if (!spoolss_io_r_deleteprinter("",&r_u,rdata,0)) {
-               DEBUG(0,("spoolss_io_r_deleteprinter: unable to marshall SPOOL_R_DELETEPRINTER.\n"));
-               return False;
-       }
-
-       return True;
+       return proxy_spoolss_call(p, NDR_SPOOLSS_DELETEPRINTER);
 }
 
-
 /********************************************************************
  * api_spoolss_deleteprinterdriver
  *
index e5e41065c29c56445498460871e06010da85f299..85f5d4076f30f586c75a9c7a33556e92b094d80e 100644 (file)
@@ -1940,22 +1940,20 @@ WERROR _spoolss_ClosePrinter(pipes_struct *p,
        return WERR_OK;
 }
 
-/********************************************************************
- * api_spoolss_deleteprinter
-
- ********************************************************************/
+/****************************************************************
+ _spoolss_DeletePrinter
+****************************************************************/
 
-WERROR _spoolss_deleteprinter(pipes_struct *p, SPOOL_Q_DELETEPRINTER *q_u, SPOOL_R_DELETEPRINTER *r_u)
+WERROR _spoolss_DeletePrinter(pipes_struct *p,
+                             struct spoolss_DeletePrinter *r)
 {
-       POLICY_HND *handle = &q_u->handle;
+       POLICY_HND *handle = r->in.handle;
        Printer_entry *Printer=find_printer_index_by_hnd(p, handle);
        WERROR result;
 
        if (Printer && Printer->document_started)
                _spoolss_enddocprinter_internal(p, handle);  /* print job was not closed */
 
-       memcpy(&r_u->handle, &q_u->handle, sizeof(r_u->handle));
-
        result = delete_printer_handle(p, handle);
 
        update_c_setprinter(False);
@@ -10008,17 +10006,6 @@ WERROR _spoolss_AddPrinter(pipes_struct *p,
        return WERR_NOT_SUPPORTED;
 }
 
-/****************************************************************
- _spoolss_DeletePrinter
-****************************************************************/
-
-WERROR _spoolss_DeletePrinter(pipes_struct *p,
-                             struct spoolss_DeletePrinter *r)
-{
-       p->rng_fault_state = true;
-       return WERR_NOT_SUPPORTED;
-}
-
 /****************************************************************
  _spoolss_SetPrinter
 ****************************************************************/