summaryrefslogtreecommitdiff
path: root/source3/rpc_client
diff options
context:
space:
mode:
authorMatthew Chapman <matty@samba.org>1999-04-23 14:47:45 +0000
committerMatthew Chapman <matty@samba.org>1999-04-23 14:47:45 +0000
commit7fe5ba774b27b01b91f0d7cc25abf8383b9afca6 (patch)
treeab1fecb49271ba15d5f6f037a2a0b318734ba6f2 /source3/rpc_client
parent9837c863c21bceea2a5e603042624001a5df09dd (diff)
downloadsamba-7fe5ba774b27b01b91f0d7cc25abf8383b9afca6.tar.gz
samba-7fe5ba774b27b01b91f0d7cc25abf8383b9afca6.tar.bz2
samba-7fe5ba774b27b01b91f0d7cc25abf8383b9afca6.zip
Adding scheduler control pipe (\atsvc), client-side routines, and rpcclient
command "at" (compatible with NT's "at" command - see rpcclient commit) - useful for remote NT administration. (This used to be commit cf30a472f702d7b50c3a85e2cf2f55b46a2bd452)
Diffstat (limited to 'source3/rpc_client')
-rw-r--r--source3/rpc_client/cli_atsvc.c238
1 files changed, 238 insertions, 0 deletions
diff --git a/source3/rpc_client/cli_atsvc.c b/source3/rpc_client/cli_atsvc.c
new file mode 100644
index 0000000000..bebc4d0bc7
--- /dev/null
+++ b/source3/rpc_client/cli_atsvc.c
@@ -0,0 +1,238 @@
+/*
+ * Unix SMB/Netbios implementation.
+ * Version 2.1.
+ * RPC client routines: scheduler service
+ * Copyright (C) Matthew Chapman 1999,
+ * Copyright (C) Luke Kenneth Casson Leighton 1996-1999,
+ * Copyright (C) Andrew Tridgell 1992-1999.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include "includes.h"
+
+extern int DEBUGLEVEL;
+
+/****************************************************************************
+add a job to the scheduler
+****************************************************************************/
+BOOL at_add_job(struct cli_state *cli, uint16 fnum,
+ char *server_name, AT_JOB_INFO *info, char *command,
+ uint32 *jobid)
+{
+ prs_struct rbuf;
+ prs_struct buf;
+ AT_Q_ADD_JOB q_a;
+ BOOL p = False;
+
+ prs_init(&buf , 1024, 4, SAFETY_MARGIN, False);
+ prs_init(&rbuf, 0 , 4, SAFETY_MARGIN, True );
+
+ /* create and send a MSRPC command with api AT_ADD_JOB */
+
+ DEBUG(4,("Scheduler Add Job\n"));
+
+ /* store the parameters */
+ make_at_q_add_job(&q_a, server_name, info, command);
+
+ /* turn parameters into data stream */
+ at_io_q_add_job("", &q_a, &buf, 0);
+
+ /* send the data on \PIPE\ */
+ if (rpc_api_pipe_req(cli, fnum, AT_ADD_JOB, &buf, &rbuf))
+ {
+ AT_R_ADD_JOB r_a;
+
+ at_io_r_add_job("", &r_a, &rbuf, 0);
+ p = rbuf.offset != 0;
+
+ if (p && r_a.status != 0)
+ {
+ /* report error code */
+ DEBUG(0,("AT_R_ADD_JOB: %s\n", get_nt_error_msg(r_a.status)));
+ p = False;
+ }
+
+ if (p)
+ {
+ *jobid = r_a.jobid;
+ }
+ }
+
+ prs_mem_free(&rbuf);
+ prs_mem_free(&buf );
+
+ return p;
+}
+
+/****************************************************************************
+dequeue a job
+****************************************************************************/
+BOOL at_del_job(struct cli_state *cli, uint16 fnum,
+ char *server_name, uint32 min_jobid, uint32 max_jobid)
+{
+ prs_struct rbuf;
+ prs_struct buf;
+ AT_Q_DEL_JOB q_d;
+ BOOL p = False;
+
+ prs_init(&buf , 1024, 4, SAFETY_MARGIN, False);
+ prs_init(&rbuf, 0 , 4, SAFETY_MARGIN, True );
+
+ /* create and send a MSRPC command with api AT_DEL_JOB */
+
+ DEBUG(4,("Scheduler Delete Job\n"));
+
+ /* store the parameters */
+ make_at_q_del_job(&q_d, server_name, min_jobid, max_jobid);
+
+ /* turn parameters into data stream */
+ at_io_q_del_job("", &q_d, &buf, 0);
+
+ /* send the data on \PIPE\ */
+ if (rpc_api_pipe_req(cli, fnum, AT_DEL_JOB, &buf, &rbuf))
+ {
+ AT_R_DEL_JOB r_d;
+
+ at_io_r_del_job("", &r_d, &rbuf, 0);
+ p = rbuf.offset != 0;
+
+ if (p && r_d.status != 0)
+ {
+ /* report error code */
+ DEBUG(0,("AT_R_DEL_JOB: %s\n", get_nt_error_msg(r_d.status)));
+ p = False;
+ }
+ }
+
+ prs_mem_free(&rbuf);
+ prs_mem_free(&buf );
+
+ return p;
+}
+
+/****************************************************************************
+enumerate scheduled jobs
+****************************************************************************/
+BOOL at_enum_jobs(struct cli_state *cli, uint16 fnum,
+ char *server_name, uint32 *num_jobs,
+ AT_ENUM_INFO *jobs, fstring *commands)
+{
+ prs_struct rbuf;
+ prs_struct buf;
+ AT_Q_ENUM_JOBS q_e;
+ BOOL p = False;
+
+ prs_init(&buf , 1024, 4, SAFETY_MARGIN, False);
+ prs_init(&rbuf, 0 , 4, SAFETY_MARGIN, True );
+
+ /* create and send a MSRPC command with api AT_DEL_JOB */
+
+ DEBUG(4,("Scheduler Enumerate Jobs\n"));
+
+ /* store the parameters */
+ make_at_q_enum_jobs(&q_e, server_name);
+
+ /* turn parameters into data stream */
+ at_io_q_enum_jobs("", &q_e, &buf, 0);
+
+ /* send the data on \PIPE\ */
+ if (rpc_api_pipe_req(cli, fnum, AT_ENUM_JOBS, &buf, &rbuf))
+ {
+ AT_R_ENUM_JOBS r_e;
+
+ at_io_r_enum_jobs("", &r_e, &rbuf, 0);
+ p = rbuf.offset != 0;
+
+ if (p && r_e.status != 0)
+ {
+ /* report error code */
+ DEBUG(0,("AT_R_ENUM_JOBS: %s\n", get_nt_error_msg(r_e.status)));
+ p = False;
+ }
+
+ if (p)
+ {
+ int i;
+
+ *num_jobs = r_e.num_entries;
+ memcpy(jobs, &r_e.info, r_e.num_entries * sizeof(AT_ENUM_INFO));
+
+ for (i = 0; i < r_e.num_entries; i++)
+ {
+ unistr2_to_ascii(commands[i], &r_e.command[i],
+ sizeof(commands[i]));
+ }
+ }
+ }
+
+ prs_mem_free(&rbuf);
+ prs_mem_free(&buf );
+
+ return p;
+}
+
+/****************************************************************************
+query job information
+****************************************************************************/
+BOOL at_query_job(struct cli_state *cli, uint16 fnum, char *server_name,
+ uint32 jobid, AT_JOB_INFO *job, fstring command)
+{
+ prs_struct rbuf;
+ prs_struct buf;
+ AT_Q_QUERY_JOB q_q;
+ BOOL p = False;
+
+ prs_init(&buf , 1024, 4, SAFETY_MARGIN, False);
+ prs_init(&rbuf, 0 , 4, SAFETY_MARGIN, True );
+
+ /* create and send a MSRPC command with api AT_QUERY_JOB */
+
+ DEBUG(4,("Scheduler Query Job\n"));
+
+ /* store the parameters */
+ make_at_q_query_job(&q_q, server_name, jobid);
+
+ /* turn parameters into data stream */
+ at_io_q_query_job("", &q_q, &buf, 0);
+
+ /* send the data on \PIPE\ */
+ if (rpc_api_pipe_req(cli, fnum, AT_QUERY_JOB, &buf, &rbuf))
+ {
+ AT_R_QUERY_JOB r_q;
+
+ at_io_r_query_job("", &r_q, &rbuf, 0);
+ p = rbuf.offset != 0;
+
+ if (p && r_q.status != 0)
+ {
+ /* report error code */
+ DEBUG(0,("AT_R_QUERY_JOB: %s\n", get_nt_error_msg(r_q.status)));
+ p = False;
+ }
+
+ if (p)
+ {
+ memcpy(job, &r_q.info, sizeof(AT_JOB_INFO));
+ unistr2_to_ascii(command, &r_q.command,
+ sizeof(fstring)-1);
+ }
+ }
+
+ prs_mem_free(&rbuf);
+ prs_mem_free(&buf );
+
+ return p;
+}