Add cmd_wkssvc_messagebuffersend().
authorGünther Deschner <gd@samba.org>
Thu, 6 Dec 2007 18:06:30 +0000 (19:06 +0100)
committerGünther Deschner <gd@samba.org>
Fri, 7 Dec 2007 10:43:00 +0000 (11:43 +0100)
Guenther
(This used to be commit 71e512efabe833a850cce3ed827415b5d1c032d5)

source3/rpcclient/cmd_wkssvc.c

index b0c548f92501d3e570ee9578f12da77021ad615e..d32a4c591f7d8cd7787e1fe03fd024cc9317a5b3 100644 (file)
@@ -80,10 +80,45 @@ static WERROR cmd_wkssvc_getjoininformation(struct rpc_pipe_client *cli,
        return WERR_OK;
 }
 
+static WERROR cmd_wkssvc_messagebuffersend(struct rpc_pipe_client *cli,
+                                          TALLOC_CTX *mem_ctx,
+                                          int argc,
+                                          const char **argv)
+{
+       const char *server_name = cli->cli->desthost;
+       const char *message_name = cli->cli->desthost;
+       const char *message_sender_name = cli->cli->desthost;
+       smb_ucs2_t *message_buffer = NULL;
+       size_t message_size = 0;
+       NTSTATUS status;
+       WERROR werr;
+
+       message_size = push_ucs2_talloc(mem_ctx,
+                                       &message_buffer,
+                                       "my message");
+       if (message_size == -1) {
+               return WERR_NOMEM;
+       }
+
+       status = rpccli_wkssvc_NetrMessageBufferSend(cli, mem_ctx,
+                                                    server_name,
+                                                    message_name,
+                                                    message_sender_name,
+                                                    (uint8_t *)message_buffer,
+                                                    message_size,
+                                                    &werr);
+       if (!NT_STATUS_IS_OK(status)) {
+               return ntstatus_to_werror(status);
+       }
+
+       return werr;
+}
+
 struct cmd_set wkssvc_commands[] = {
 
        { "WKSSVC" },
-       { "wkstagetinfo", RPC_RTYPE_WERROR, NULL, cmd_wkssvc_wkstagetinfo, PI_WKSSVC, NULL, "Query WKSSVC Workstation Information", "" },
-       { "getjoininformation", RPC_RTYPE_WERROR, NULL, cmd_wkssvc_getjoininformation, PI_WKSSVC, NULL, "Query WKSSVC Join Information", "" },
+       { "wkssvc_wkstagetinfo", RPC_RTYPE_WERROR, NULL, cmd_wkssvc_wkstagetinfo, PI_WKSSVC, NULL, "Query WKSSVC Workstation Information", "" },
+       { "wkssvc_getjoininformation", RPC_RTYPE_WERROR, NULL, cmd_wkssvc_getjoininformation, PI_WKSSVC, NULL, "Query WKSSVC Join Information", "" },
+       { "wkssvc_messagebuffersend", RPC_RTYPE_WERROR, NULL, cmd_wkssvc_messagebuffersend, PI_WKSSVC, NULL, "Send WKSSVC message", "" },
        { NULL }
 };