The branch, master has been updated
       via  99518bc... s4-smbtorture: add 
smbcli_rap_netprintjob{pause,continue,delete}.
       via  d266af7... rap: add IDL for NetPrintJob{Pause,Continue,Delete}.
      from  9a313bb... s3-lanman: fix api_DosPrintQGetInfo().

http://gitweb.samba.org/?p=samba.git;a=shortlog;h=master


- Log -----------------------------------------------------------------
commit 99518bc1ea330474ba27dcce0dde141026ebaae2
Author: Günther Deschner <[email protected]>
Date:   Thu Apr 29 14:22:55 2010 +0200

    s4-smbtorture: add smbcli_rap_netprintjob{pause,continue,delete}.
    
    Guenther

commit d266af79b3e96e534c8d0b41e22fa758387c8727
Author: Günther Deschner <[email protected]>
Date:   Thu Apr 29 14:12:14 2010 +0200

    rap: add IDL for NetPrintJob{Pause,Continue,Delete}.
    
    Guenther

-----------------------------------------------------------------------

Summary of changes:
 librpc/gen_ndr/ndr_rap.c  |  147 +++++++++++++++++++++++++++++++++++++++++++++
 librpc/gen_ndr/ndr_rap.h  |   17 +++++-
 librpc/gen_ndr/rap.h      |   39 ++++++++++++
 librpc/idl/rap.idl        |   18 ++++++
 source4/torture/rap/rap.c |  110 +++++++++++++++++++++++++++++++++
 5 files changed, 330 insertions(+), 1 deletions(-)


Changeset truncated at 500 lines:

diff --git a/librpc/gen_ndr/ndr_rap.c b/librpc/gen_ndr/ndr_rap.c
index 97a530d..1488b34 100644
--- a/librpc/gen_ndr/ndr_rap.c
+++ b/librpc/gen_ndr/ndr_rap.c
@@ -2096,3 +2096,150 @@ _PUBLIC_ void ndr_print_rap_NetPrintQGetInfo(struct 
ndr_print *ndr, const char *
        }
        ndr->depth--;
 }
+
+_PUBLIC_ enum ndr_err_code ndr_push_rap_NetPrintJobPause(struct ndr_push *ndr, 
int flags, const struct rap_NetPrintJobPause *r)
+{
+       if (flags & NDR_IN) {
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->in.JobID));
+       }
+       if (flags & NDR_OUT) {
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.status));
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.convert));
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ enum ndr_err_code ndr_pull_rap_NetPrintJobPause(struct ndr_pull *ndr, 
int flags, struct rap_NetPrintJobPause *r)
+{
+       if (flags & NDR_IN) {
+               ZERO_STRUCT(r->out);
+
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->in.JobID));
+       }
+       if (flags & NDR_OUT) {
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->out.status));
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->out.convert));
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ void ndr_print_rap_NetPrintJobPause(struct ndr_print *ndr, const char 
*name, int flags, const struct rap_NetPrintJobPause *r)
+{
+       ndr_print_struct(ndr, name, "rap_NetPrintJobPause");
+       ndr->depth++;
+       if (flags & NDR_SET_VALUES) {
+               ndr->flags |= LIBNDR_PRINT_SET_VALUES;
+       }
+       if (flags & NDR_IN) {
+               ndr_print_struct(ndr, "in", "rap_NetPrintJobPause");
+               ndr->depth++;
+               ndr_print_uint16(ndr, "JobID", r->in.JobID);
+               ndr->depth--;
+       }
+       if (flags & NDR_OUT) {
+               ndr_print_struct(ndr, "out", "rap_NetPrintJobPause");
+               ndr->depth++;
+               ndr_print_uint16(ndr, "status", r->out.status);
+               ndr_print_uint16(ndr, "convert", r->out.convert);
+               ndr->depth--;
+       }
+       ndr->depth--;
+}
+
+_PUBLIC_ enum ndr_err_code ndr_push_rap_NetPrintJobContinue(struct ndr_push 
*ndr, int flags, const struct rap_NetPrintJobContinue *r)
+{
+       if (flags & NDR_IN) {
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->in.JobID));
+       }
+       if (flags & NDR_OUT) {
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.status));
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.convert));
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ enum ndr_err_code ndr_pull_rap_NetPrintJobContinue(struct ndr_pull 
*ndr, int flags, struct rap_NetPrintJobContinue *r)
+{
+       if (flags & NDR_IN) {
+               ZERO_STRUCT(r->out);
+
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->in.JobID));
+       }
+       if (flags & NDR_OUT) {
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->out.status));
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->out.convert));
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ void ndr_print_rap_NetPrintJobContinue(struct ndr_print *ndr, const 
char *name, int flags, const struct rap_NetPrintJobContinue *r)
+{
+       ndr_print_struct(ndr, name, "rap_NetPrintJobContinue");
+       ndr->depth++;
+       if (flags & NDR_SET_VALUES) {
+               ndr->flags |= LIBNDR_PRINT_SET_VALUES;
+       }
+       if (flags & NDR_IN) {
+               ndr_print_struct(ndr, "in", "rap_NetPrintJobContinue");
+               ndr->depth++;
+               ndr_print_uint16(ndr, "JobID", r->in.JobID);
+               ndr->depth--;
+       }
+       if (flags & NDR_OUT) {
+               ndr_print_struct(ndr, "out", "rap_NetPrintJobContinue");
+               ndr->depth++;
+               ndr_print_uint16(ndr, "status", r->out.status);
+               ndr_print_uint16(ndr, "convert", r->out.convert);
+               ndr->depth--;
+       }
+       ndr->depth--;
+}
+
+_PUBLIC_ enum ndr_err_code ndr_push_rap_NetPrintJobDelete(struct ndr_push 
*ndr, int flags, const struct rap_NetPrintJobDelete *r)
+{
+       if (flags & NDR_IN) {
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->in.JobID));
+       }
+       if (flags & NDR_OUT) {
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.status));
+               NDR_CHECK(ndr_push_uint16(ndr, NDR_SCALARS, r->out.convert));
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ enum ndr_err_code ndr_pull_rap_NetPrintJobDelete(struct ndr_pull 
*ndr, int flags, struct rap_NetPrintJobDelete *r)
+{
+       if (flags & NDR_IN) {
+               ZERO_STRUCT(r->out);
+
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->in.JobID));
+       }
+       if (flags & NDR_OUT) {
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->out.status));
+               NDR_CHECK(ndr_pull_uint16(ndr, NDR_SCALARS, &r->out.convert));
+       }
+       return NDR_ERR_SUCCESS;
+}
+
+_PUBLIC_ void ndr_print_rap_NetPrintJobDelete(struct ndr_print *ndr, const 
char *name, int flags, const struct rap_NetPrintJobDelete *r)
+{
+       ndr_print_struct(ndr, name, "rap_NetPrintJobDelete");
+       ndr->depth++;
+       if (flags & NDR_SET_VALUES) {
+               ndr->flags |= LIBNDR_PRINT_SET_VALUES;
+       }
+       if (flags & NDR_IN) {
+               ndr_print_struct(ndr, "in", "rap_NetPrintJobDelete");
+               ndr->depth++;
+               ndr_print_uint16(ndr, "JobID", r->in.JobID);
+               ndr->depth--;
+       }
+       if (flags & NDR_OUT) {
+               ndr_print_struct(ndr, "out", "rap_NetPrintJobDelete");
+               ndr->depth++;
+               ndr_print_uint16(ndr, "status", r->out.status);
+               ndr_print_uint16(ndr, "convert", r->out.convert);
+               ndr->depth--;
+       }
+       ndr->depth--;
+}
diff --git a/librpc/gen_ndr/ndr_rap.h b/librpc/gen_ndr/ndr_rap.h
index b4bce71..cb46248 100644
--- a/librpc/gen_ndr/ndr_rap.h
+++ b/librpc/gen_ndr/ndr_rap.h
@@ -17,7 +17,13 @@
 
 #define NDR_RAP_NETPRINTQGETINFO (0x04)
 
-#define NDR_RAP_CALL_COUNT (5)
+#define NDR_RAP_NETPRINTJOBPAUSE (0x05)
+
+#define NDR_RAP_NETPRINTJOBCONTINUE (0x06)
+
+#define NDR_RAP_NETPRINTJOBDELETE (0x07)
+
+#define NDR_RAP_CALL_COUNT (8)
 void ndr_print_rap_share_info_0(struct ndr_print *ndr, const char *name, const 
struct rap_share_info_0 *r);
 void ndr_print_rap_share_info_1(struct ndr_print *ndr, const char *name, const 
struct rap_share_info_1 *r);
 void ndr_print_rap_share_info_2(struct ndr_print *ndr, const char *name, const 
struct rap_share_info_2 *r);
@@ -54,4 +60,13 @@ void ndr_print_rap_NetPrintQEnum(struct ndr_print *ndr, 
const char *name, int fl
 enum ndr_err_code ndr_push_rap_NetPrintQGetInfo(struct ndr_push *ndr, int 
flags, const struct rap_NetPrintQGetInfo *r);
 enum ndr_err_code ndr_pull_rap_NetPrintQGetInfo(struct ndr_pull *ndr, int 
flags, struct rap_NetPrintQGetInfo *r);
 void ndr_print_rap_NetPrintQGetInfo(struct ndr_print *ndr, const char *name, 
int flags, const struct rap_NetPrintQGetInfo *r);
+enum ndr_err_code ndr_push_rap_NetPrintJobPause(struct ndr_push *ndr, int 
flags, const struct rap_NetPrintJobPause *r);
+enum ndr_err_code ndr_pull_rap_NetPrintJobPause(struct ndr_pull *ndr, int 
flags, struct rap_NetPrintJobPause *r);
+void ndr_print_rap_NetPrintJobPause(struct ndr_print *ndr, const char *name, 
int flags, const struct rap_NetPrintJobPause *r);
+enum ndr_err_code ndr_push_rap_NetPrintJobContinue(struct ndr_push *ndr, int 
flags, const struct rap_NetPrintJobContinue *r);
+enum ndr_err_code ndr_pull_rap_NetPrintJobContinue(struct ndr_pull *ndr, int 
flags, struct rap_NetPrintJobContinue *r);
+void ndr_print_rap_NetPrintJobContinue(struct ndr_print *ndr, const char 
*name, int flags, const struct rap_NetPrintJobContinue *r);
+enum ndr_err_code ndr_push_rap_NetPrintJobDelete(struct ndr_push *ndr, int 
flags, const struct rap_NetPrintJobDelete *r);
+enum ndr_err_code ndr_pull_rap_NetPrintJobDelete(struct ndr_pull *ndr, int 
flags, struct rap_NetPrintJobDelete *r);
+void ndr_print_rap_NetPrintJobDelete(struct ndr_print *ndr, const char *name, 
int flags, const struct rap_NetPrintJobDelete *r);
 #endif /* _HEADER_NDR_rap */
diff --git a/librpc/gen_ndr/rap.h b/librpc/gen_ndr/rap.h
index 78cae37..b209fd4 100644
--- a/librpc/gen_ndr/rap.h
+++ b/librpc/gen_ndr/rap.h
@@ -677,4 +677,43 @@ struct rap_NetPrintQGetInfo {
 
 };
 
+
+struct rap_NetPrintJobPause {
+       struct {
+               uint16_t JobID;
+       } in;
+
+       struct {
+               uint16_t status;
+               uint16_t convert;
+       } out;
+
+};
+
+
+struct rap_NetPrintJobContinue {
+       struct {
+               uint16_t JobID;
+       } in;
+
+       struct {
+               uint16_t status;
+               uint16_t convert;
+       } out;
+
+};
+
+
+struct rap_NetPrintJobDelete {
+       struct {
+               uint16_t JobID;
+       } in;
+
+       struct {
+               uint16_t status;
+               uint16_t convert;
+       } out;
+
+};
+
 #endif /* _HEADER_rap */
diff --git a/librpc/idl/rap.idl b/librpc/idl/rap.idl
index db65308..52a9c60 100644
--- a/librpc/idl/rap.idl
+++ b/librpc/idl/rap.idl
@@ -564,6 +564,24 @@ interface rap
                [out,switch_is(level)] rap_printq_info info
        );
 
+       [public] void rap_NetPrintJobPause(
+               [in] uint16 JobID,
+               [out] uint16 status,
+               [out] uint16 convert
+       );
+
+       [public] void rap_NetPrintJobContinue(
+               [in] uint16 JobID,
+               [out] uint16 status,
+               [out] uint16 convert
+       );
+
+       [public] void rap_NetPrintJobDelete(
+               [in] uint16 JobID,
+               [out] uint16 status,
+               [out] uint16 convert
+       );
+
        /* Parameter description strings for RAP calls   */
        /* Names are defined name for RAP call with _REQ */
        /* appended to end.                              */
diff --git a/source4/torture/rap/rap.c b/source4/torture/rap/rap.c
index e1191bb..9e2307c 100644
--- a/source4/torture/rap/rap.c
+++ b/source4/torture/rap/rap.c
@@ -765,6 +765,116 @@ NTSTATUS smbcli_rap_netprintqgetinfo(struct smbcli_tree 
*tree,
        return result;
 }
 
+NTSTATUS smbcli_rap_netprintjobpause(struct smbcli_tree *tree,
+                                    struct smb_iconv_convenience 
*iconv_convenience,
+                                    TALLOC_CTX *mem_ctx,
+                                    struct rap_NetPrintJobPause *r)
+{
+       struct rap_call *call;
+       NTSTATUS result = NT_STATUS_UNSUCCESSFUL;
+
+       if (!(call = new_rap_cli_call(mem_ctx, iconv_convenience, 
RAP_WPrintJobPause))) {
+               return NT_STATUS_NO_MEMORY;
+       }
+
+       rap_cli_push_word(call, r->in.JobID);
+
+       rap_cli_expect_format(call, "W");
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(rap_NetPrintJobPause, r);
+       }
+
+       result = rap_cli_do_call(tree, iconv_convenience, call);
+
+       if (!NT_STATUS_IS_OK(result))
+               goto done;
+
+       NDR_GOTO(ndr_pull_uint16(call->ndr_pull_param, NDR_SCALARS, 
&r->out.status));
+       NDR_GOTO(ndr_pull_uint16(call->ndr_pull_param, NDR_SCALARS, 
&r->out.convert));
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(rap_NetPrintJobPause, r);
+       }
+
+ done:
+       talloc_free(call);
+       return result;
+}
+
+NTSTATUS smbcli_rap_netprintjobcontinue(struct smbcli_tree *tree,
+                                       struct smb_iconv_convenience 
*iconv_convenience,
+                                       TALLOC_CTX *mem_ctx,
+                                       struct rap_NetPrintJobContinue *r)
+{
+       struct rap_call *call;
+       NTSTATUS result = NT_STATUS_UNSUCCESSFUL;
+
+       if (!(call = new_rap_cli_call(mem_ctx, iconv_convenience, 
RAP_WPrintJobContinue))) {
+               return NT_STATUS_NO_MEMORY;
+       }
+
+       rap_cli_push_word(call, r->in.JobID);
+
+       rap_cli_expect_format(call, "W");
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(rap_NetPrintJobContinue, r);
+       }
+
+       result = rap_cli_do_call(tree, iconv_convenience, call);
+
+       if (!NT_STATUS_IS_OK(result))
+               goto done;
+
+       NDR_GOTO(ndr_pull_uint16(call->ndr_pull_param, NDR_SCALARS, 
&r->out.status));
+       NDR_GOTO(ndr_pull_uint16(call->ndr_pull_param, NDR_SCALARS, 
&r->out.convert));
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(rap_NetPrintJobContinue, r);
+       }
+
+ done:
+       talloc_free(call);
+       return result;
+}
+
+NTSTATUS smbcli_rap_netprintjobdelete(struct smbcli_tree *tree,
+                                     struct smb_iconv_convenience 
*iconv_convenience,
+                                     TALLOC_CTX *mem_ctx,
+                                     struct rap_NetPrintJobDelete *r)
+{
+       struct rap_call *call;
+       NTSTATUS result = NT_STATUS_UNSUCCESSFUL;
+
+       if (!(call = new_rap_cli_call(mem_ctx, iconv_convenience, 
RAP_WPrintJobDel))) {
+               return NT_STATUS_NO_MEMORY;
+       }
+
+       rap_cli_push_word(call, r->in.JobID);
+
+       rap_cli_expect_format(call, "W");
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_IN_DEBUG(rap_NetPrintJobDelete, r);
+       }
+
+       result = rap_cli_do_call(tree, iconv_convenience, call);
+
+       if (!NT_STATUS_IS_OK(result))
+               goto done;
+
+       NDR_GOTO(ndr_pull_uint16(call->ndr_pull_param, NDR_SCALARS, 
&r->out.status));
+       NDR_GOTO(ndr_pull_uint16(call->ndr_pull_param, NDR_SCALARS, 
&r->out.convert));
+
+       if (DEBUGLEVEL >= 10) {
+               NDR_PRINT_OUT_DEBUG(rap_NetPrintJobDelete, r);
+       }
+
+ done:
+       talloc_free(call);
+       return result;
+}
 
 static bool test_netservergetinfo(struct torture_context *tctx, 
                                  struct smbcli_state *cli)


-- 
Samba Shared Repository

Reply via email to