summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source3/lib/cmd_interp.c1375
1 files changed, 0 insertions, 1375 deletions
diff --git a/source3/lib/cmd_interp.c b/source3/lib/cmd_interp.c
deleted file mode 100644
index 54d023e9f7..0000000000
--- a/source3/lib/cmd_interp.c
+++ /dev/null
@@ -1,1375 +0,0 @@
-/*
- Unix SMB/Netbios implementation.
- Version 1.9.
- SMB client
- Copyright (C) Andrew Tridgell 1994-1998
- Copyright (C) Luke Kenneth Casson Leighton 1998-2000
- Copyright (C) Gerald Carter 2000
-
- 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.
-*/
-
-#ifdef SYSLOG
-#undef SYSLOG
-#endif
-
-#include "includes.h"
-#include "rpc_parse.h"
-
-#ifndef REGISTER
-#define REGISTER 0
-#endif
-
-extern pstring debugf;
-extern pstring global_myname;
-
-extern pstring user_socket_options;
-
-/* found in rpc_client/cli_connect.c */
-extern struct user_creds *usr_creds;
-
-
-#define CNV_LANG(s) dos2unix_format(s,False)
-#define CNV_INPUT(s) unix2dos_format(s,True)
-
-static int process_tok(fstring tok);
-static uint32 cmd_help(struct client_info *info, int argc, char *argv[]);
-static uint32 cmd_quit(struct client_info *info, int argc, char *argv[]);
-static uint32 cmd_set(struct client_info *info, int argc, char *argv[]);
-static uint32 cmd_use(struct client_info *info, int argc, char *argv[]);
-
-static struct user_creds usr;
-
-struct client_info cli_info;
-
-char **cmd_argv = NULL;
-uint32 cmd_argc = 0;
-
-FILE *out_hnd;
-
-
-static void cmd_set_free(struct command_set *item)
-{
- if (item != NULL)
- SAFE_FREE(item->name);
-
- SAFE_FREE(item);
-}
-
-static struct command_set *cmd_set_dup(const struct command_set *from)
-{
- if (from != NULL)
- {
- struct command_set *copy;
-
- copy = (struct command_set*)malloc(sizeof(struct command_set));
- if (copy != NULL)
- {
- memcpy(copy, from, sizeof(struct command_set));
- if (from->name != NULL)
- copy->name = strdup(from->name);
- }
- return copy;
- }
- return NULL;
-}
-
-void free_cmd_set_array(uint32 num_entries, struct command_set **entries)
-{
- void (*fn) (void *) = (void (*)(void *))&cmd_set_free;
- free_void_array(num_entries, (void **)entries, *fn);
-}
-
-struct command_set *add_cmd_set_to_array(uint32 *len, struct command_set ***array,
- const struct command_set *cmd)
-{
- void *(*fn) (const void *) = (void *(*)(const void *))&cmd_set_dup;
- return (struct command_set *)add_copy_to_array(len, (void ***)array,
- (const void *)cmd, *fn,
- False);
-
-}
-
-static struct command_set **commands = NULL;
-static uint32 num_commands = 0;
-
-/****************************************************************************
- add in individual command-sets.
- ****************************************************************************/
-void add_command_set(const struct command_set *cmds)
-{
- while (! ((cmds->fn==NULL) && (strlen(cmds->name)==0)))
- {
- add_cmd_set_to_array(&num_commands, &commands, cmds);
- cmds++;
- }
-}
-
-/****************************************************************************
- This defines the commands supported by this client
- ****************************************************************************/
-static struct command_set general_commands[] = {
- /*
- * maintenance
- */
-
- {"General", NULL, NULL, {NULL, NULL}},
-
- { "set", cmd_set,
- "run rpcclient inside rpcclient (change options etc.)",
- {NULL, NULL}
- },
-
- { "use", cmd_use,
- "net use and net view",
- {NULL, NULL}
- },
-
- /*
- * bye bye
- */
-
- { "quit", cmd_quit,
- "logoff the server",
- {NULL, NULL}
- },
- { "q", cmd_quit,
- "logoff the server",
- {NULL, NULL}
- },
- { "exit", cmd_quit,
- "logoff the server",
- {NULL, NULL}
- },
- { "bye", cmd_quit,
- "logoff the server",
- {NULL, NULL}
- },
-
- /*
- * eek!
- */
-
- { "help", cmd_help,
- "[command] give help on a command",
- {NULL, NULL}
- },
- { "?", cmd_help,
- "[command] give help on a command",
- {NULL, NULL}
- },
-
- /*
- * shell
- */
-
- { "!", NULL,
- "run a shell command on the local system",
- {NULL, NULL}
- },
-
- /*
- * oop!
- */
-
- { "", NULL, NULL,
- {NULL, NULL}
- }
-};
-
-
-/****************************************************************************
-do a (presumably graceful) quit...
-****************************************************************************/
-static uint32 cmd_quit(struct client_info *info, int argc, char *argv[])
-{
- free_connections();
- exit(0);
-
- /* NOTREACHED */
- return 0;
-}
-
-/****************************************************************************
-help
-****************************************************************************/
-static uint32 cmd_help(struct client_info *info, int argc, char *argv[])
-{
- int i = 0;
-
- /* get help on a specific command */
- if (argc > 1)
- {
- if ((i = process_tok(argv[0])) >= 0)
- {
- fprintf(out_hnd, "HELP %s:\n\t%s\n\n", commands[i]->name,
- commands[i]->description);
- }
-
- return 0;
- }
-
- /* Print out the list of available commands */
- for (i = 0; i < num_commands; i++)
- {
- if (commands[i]->fn == NULL)
- fprintf (out_hnd, "\n");
- else
- fprintf (out_hnd, "\t");
-
- fprintf(out_hnd, "%s\n", commands[i]->name);
- }
-
- return 0;
-}
-
-/*******************************************************************
- lookup a command string in the list of commands, including
- abbreviations
- ******************************************************************/
-static int process_tok(char *tok)
-{
- int i = 0, matches = 0;
- int cmd = 0;
- int tok_len = strlen(tok);
-
- for (i = 0; i < num_commands; i++)
- {
- if (strequal(commands[i]->name, tok))
- {
- matches = 1;
- cmd = i;
- break;
- }
- else if (strnequal(commands[i]->name, tok, tok_len))
- {
- matches++;
- cmd = i;
- }
- }
-
- if (matches == 0)
- return (-1);
- else if (matches == 1)
- return (cmd);
- else
- return (-2);
-}
-
-/****************************************************************************
- turn command line into command argument array
-****************************************************************************/
-static BOOL get_cmd_args(char *line)
-{
- char *ptr = line;
- pstring tok;
- cmd_argc = 0;
- cmd_argv = NULL;
-
- /* get the first part of the command */
- if (!next_token_nr(&ptr, tok, NULL, sizeof(tok)))
- return False;
-
- do
- {
- add_chars_to_array(&cmd_argc, &cmd_argv, tok);
- }
- while (next_token_nr(NULL, tok, NULL, sizeof(tok)));
-
- add_chars_to_array(&cmd_argc, &cmd_argv, NULL);
-
- return True;
-}
-
-/* command options mask */
-static uint32 cmd_set_options = 0xffffffff;
-
-/****************************************************************************
- process commands from the client
-****************************************************************************/
-static uint32 do_command(struct client_info *info, char *line)
-{
- NTSTATUS status = 0x0;
- int i;
-
- if (!get_cmd_args(line))
- return False;
-
- if (cmd_argc == 0)
- return False;
-
- i = process_tok(cmd_argv[0]);
- if (i >= 0)
- {
- int argc = ((int)cmd_argc);
- char **argv = cmd_argv;
- optind = 0;
-
- status = commands[i]->fn(info, argc, argv);
- }
- else if (i == -2)
- {
- fprintf(out_hnd, "%s: command abbreviation ambiguous\n",
- CNV_LANG(cmd_argv[0]));
- }
- else
- {
- fprintf(out_hnd, "%s: command not found\n",
- CNV_LANG(cmd_argv[0]));
- }
-
- free_char_array(cmd_argc, cmd_argv);
- parse_talloc_free(); /* Free up init_XXX memory. */
-
- return status;
-}
-
-
-/****************************************************************************
- process commands from the client
-****************************************************************************/
-static uint32 process(struct client_info *info, char *cmd_str)
-{
- NTSTATUS status = 0;
- pstring line;
- char *cmd = cmd_str;
-
- if (cmd != NULL)
- {
- while (cmd[0] != '\0')
- {
- char *p;
-
- if ((p = strchr_m(cmd, ';')) == 0)
- {
- strncpy(line, cmd, 999);
- line[1000] = '\0';
- cmd += strlen(cmd);
- }
- else
- {
- if (p - cmd > 999)
- p = cmd + 999;
- strncpy(line, cmd, p - cmd);
- line[p - cmd] = '\0';
- cmd = p + 1;
- }
-
- /* input language code to internal one */
- CNV_INPUT(line);
-
- status = do_command(info, line);
- if (status == 0x0)
- {
- continue;
- }
- }
- }
- else
- {
- while (!feof(stdin))
- {
-#ifdef HAVE_LIBREADLINE
- char *ret_line;
-#endif
- pstring pline;
- BOOL at_sym = False;
-
- pline[0] = 0;
- if (info->show_prompt)
- {
- safe_strcat(pline, "[", sizeof(pline) - 1);
- if (usr.ntc.domain[0] != 0)
- {
- safe_strcat(pline, usr.ntc.domain,
- sizeof(pline) - 1);
- safe_strcat(pline, "\\", sizeof(pline) - 1);
- at_sym = True;
- }
- if (usr.ntc.user_name[0] != 0)
- {
- safe_strcat(pline, usr.ntc.user_name,
- sizeof(pline) - 1);
- at_sym = True;
- }
- if (at_sym)
- safe_strcat(pline, "@", sizeof(pline) - 1);
-
- safe_strcat(pline, cli_info.dest_host,
- sizeof(pline) - 1);
- safe_strcat(pline, "]$ ", sizeof(pline) - 1);
- }
-#ifndef HAVE_LIBREADLINE
-
- /* display a prompt */
- fprintf(out_hnd, "%s", CNV_LANG(pline));
- fflush(out_hnd);
-
- cli_use_wait_keyboard();
-
- /* and get a response */
- if (!fgets(line, 1000, stdin))
- {
- break;
- }
-
-#else /* HAVE_LIBREADLINE */
-
- if (!(ret_line = readline(pline)))
- break;
- SAFE_FREE(ret_line);
-
- /* Copy read line to samba buffer */
-
- pstrcpy(line, rl_line_buffer);
-
- /* Add to history */
-
- if (strlen(line) > 0)
- add_history(line);
-#endif
- /* input language code to internal one */
- CNV_INPUT(line);
-
- /* special case - first char is ! */
- if (*line == '!')
- {
- system(line + 1);
- continue;
- }
-
- fprintf(out_hnd, "%s\n", line);
-
- status = do_command(info, line);
- if (status == 0x0)
- {
- continue;
- }
- }
- }
- return status;
-}
-
-/****************************************************************************
-usage on the program
-****************************************************************************/
-static void usage(char *pname)
-{
- fprintf(out_hnd,
- "Usage: %s [\\server] [password] [-U user] -[W domain] [-l log] ",
- pname);
-
- fprintf(out_hnd, "\nVersion %s\n", VERSION);
- fprintf(out_hnd, "\t-d debuglevel set the debuglevel\n");
- fprintf(out_hnd,
- "\t-S <\\>server Server to connect to\n");
- fprintf(out_hnd,
- "\t-l log basename. Basename for log/debug files\n");
- fprintf(out_hnd,
- "\t-n netbios name. Use this name as my netbios name\n");
- fprintf(out_hnd,
- "\t-N don't ask for a password\n");
- fprintf(out_hnd,
- "\t-m max protocol set the max protocol level\n");
- fprintf(out_hnd,
- "\t-I dest IP use this IP to connect to\n");
- fprintf(out_hnd,
- "\t-E write messages to stderr instead of stdout\n");
- fprintf(out_hnd,
- "\t-A filename file from which to read the authentication credentials\n");
- fprintf(out_hnd,
- "\t-P hide prompt (used for shell scripts)\n");
- fprintf(out_hnd,
- "\t-U username set the network username\n");
- fprintf(out_hnd,
- "\t-U username%%pass set the network username and password\n");
- fprintf(out_hnd, "\t-W domain set the domain name\n");
- fprintf(out_hnd,
- "\t-c 'command string' execute semicolon separated commands\n");
- fprintf(out_hnd,
- "\t-t terminal code terminal i/o code {sjis|euc|jis7|jis8|junet|hex}\n");
- fprintf(out_hnd, "\n");
-}
-
-#ifdef HAVE_LIBREADLINE
-
-/****************************************************************************
-GNU readline completion functions
-****************************************************************************/
-
-/* Complete an rpcclient command */
-
-static char *complete_cmd(char *text, int state)
-{
- static int cmd_index;
- char *name;
-
- /* Initialise */
-
- if (state == 0)
- cmd_index = 0;
-
- /* Return the next name which partially matches the list of commands */
-
- while ((cmd_index < num_commands)
- && (strlen(name = commands[cmd_index++]->name) > 0))
- {
- if (strncmp(name, text, strlen(text)) == 0)
- return strdup(name);
- }
-
- return NULL;
-}
-
-/* Main completion function */
-
-static char **completion_fn(char *text, int start, int end)
-{
- pstring cmd_partial;
- int cmd_index;
- int num_words;
-
- int i;
- char lastch = ' ';
-
- (void)get_cmd_args(rl_line_buffer);
-
- safe_strcpy(cmd_partial, rl_line_buffer,
- MAX(sizeof(cmd_partial), end) - 1);
-
- /* Complete rpcclient command */
-
- if (start == 0)
- return completion_matches(text, complete_cmd);
-
- /* Count # of words in command */
-
- num_words = 0;
- for (i = 0; i <= end; i++)
- {
- if ((rl_line_buffer[i] != ' ') && (lastch == ' '))
- num_words++;
- lastch = rl_line_buffer[i];
- }
-
- if (rl_line_buffer[end] == ' ')
- num_words++;
-
- /* Work out which command we are completing for */
-
- for (cmd_index = 0; cmd_index < num_commands; cmd_index++)
- {
-
- /* Check each command in array */
-
- if (strncmp(rl_line_buffer, commands[cmd_index]->name,
- strlen(commands[cmd_index]->name)) == 0)
- {
- /* Call appropriate completion function */
-
- if (num_words == 2 || num_words == 3)
- {
- char *(*fn) (char *, int);
- fn = commands[cmd_index]->compl_args[num_words - 2];
- if (fn != NULL)
- return completion_matches(text, fn);
- }
- }
- }
-
- /* Eeek! */
- return NULL;
-}
-
-/* To avoid filename completion being activated when no valid
- completions are found, we assign this stub completion function
- to the rl_completion_entry_function variable. */
-
-static char *complete_cmd_null(char *text, int state)
-{
- return NULL;
-}
-
-#endif /* HAVE_LIBREADLINE */
-
-static void set_user_password(struct ntuser_creds *u,
- BOOL got_pass, char *password)
-{
- /* set the password cache info */
- if (got_pass)
- {
- if (password == NULL)
- {
- DEBUG(10, ("set_user_password: NULL pwd\n"));
- pwd_set_nullpwd(&u->pwd);
- }
- else
- {
- /* generate 16 byte hashes */
- DEBUG(10, ("set_user_password: generate\n"));
- if (lp_encrypted_passwords())
- pwd_make_lm_nt_16(&u->pwd, password);
- else
- pwd_set_cleartext(&u->pwd, password);
- }
- }
- else
- {
- DEBUG(10, ("set_user_password: read\n"));
- pwd_read(&u->pwd, "Enter Password:", True);
- }
-}
-
-static uint32 cmd_use(struct client_info *info, int argc, char *argv[])
-{
- int opt;
- BOOL net_use = False;
- BOOL net_use_add = True;
- BOOL force_close = False;
- fstring dest_host;
- fstring srv_name;
- BOOL null_pwd = False;
- BOOL got_pwd = False;
- pstring password;
-
-
- if (usr_creds != NULL)
- copy_nt_creds(&usr.ntc, &usr_creds->ntc);
- else
- copy_nt_creds(&usr.ntc, NULL);
-
- pstrcpy(dest_host, cli_info.dest_host);
- pstrcpy(usr.ntc.user_name, optarg);
- info->reuse = False;
-
- if (argc <= 1)
- {
- report(out_hnd,
- "net [\\\\Server] [-U user%%pass] [-W domain] [-d] [-f]\n");
- report(out_hnd, " -d Deletes a connection\n");
- report(out_hnd, " -f Forcibly deletes a connection\n");
- report(out_hnd, "net -u Shows all connections\n");
- return 0;
- }
-
- if (argc > 1 && (*argv[1] != '-'))
- {
- if (strnequal("\\\\", argv[1], 2) ||
- strnequal("//", argv[1], 2))
- {
- pstrcpy(dest_host, argv[1] + 2);
- }
- argc--;
- argv++;
- }
-
- while ((opt = getopt(argc, argv, "udU:W:")) != EOF)
- {
- switch (opt)
- {
- case 'u':
- {
- net_use = True;
- break;
- }
-
- case 'U':
- {
- char *lp;
- pstrcpy(usr.ntc.user_name, optarg);
- if ((lp = strchr_m(usr.ntc.user_name, '%')))
- {
- *lp = 0;
- pstrcpy(password, lp + 1);
- memset(strchr_m(optarg, '%') + 1, 'X',
- strlen(password));
- got_pwd = True;
- }
- if (usr.ntc.user_name[0] == 0
- && password[0] == 0)
- {
- null_pwd = True;
- }
- break;
- }
-
- case 'N':
- {
- null_pwd = True;
- }
- case 'W':
- {
- pstrcpy(usr.ntc.domain, optarg);
- break;
- }
-
- case 'd':
- {
- net_use_add = False;
- break;
- }
-
- case 'f':
- {
- force_close = True;
- break;
- }
-
- default:
- {
- report(out_hnd,
- "net -S \\server [-U user%%pass] [-W domain] [-d] [-f]\n");
- report(out_hnd, "net -u\n");
- break;
- }
- }
- }
-
- if (strnequal("\\\\", dest_host, 2))
- {
- fstrcpy(srv_name, dest_host);
- }
- else
- {
- fstrcpy(srv_name, "\\\\");
- fstrcat(srv_name, dest_host);
- }
- strupper(srv_name);
-
- if (net_use)
- {
- int i;
- uint32 num_uses;
- struct use_info **use;
- cli_net_use_enum(&num_uses, &use);
-
- if (num_uses == 0)
- {
- report(out_hnd, "No connections\n");
- }
- else
- {
- report(out_hnd, "Connections:\n");
-
- for (i = 0; i < num_uses; i++)
- {
- if (use[i] != NULL && use[i]->connected)
- {
- report(out_hnd, "Server:\t%s\t",use[i]->srv_name);
- report(out_hnd, "Key:\t[%d,%x]\t",use[i]->key.pid, use[i]->key.vuid);
- report(out_hnd, "User:\t%s\t", use[i]->user_name);
- report(out_hnd, "Domain:\t%s\n", use[i]->domain);
- }
- }
- }
- }
- else if (net_use_add)
- {
- BOOL isnew;
- if (null_pwd)
- set_user_password(&usr.ntc, True, NULL);
- else
- set_user_password(&usr.ntc, got_pwd, password);
-
- /* paranoia: destroy the local copy of the password */
- ZERO_STRUCT(password);
-
- report(out_hnd, "Server:\t%s:\tUser:\t%s\tDomain:\t%s\n",
- srv_name, usr.ntc.user_name, usr.ntc.domain);
- report(out_hnd, "Connection:\t");
-
- if (cli_net_use_add(srv_name, &usr.ntc, info->reuse, &isnew) != NULL)
- report(out_hnd, "OK\n");
- else
- report(out_hnd, "FAILED\n");
- }
- else
- {
- BOOL closed;
- report(out_hnd, "Server:\t%s:\tUser:\t%s\tDomain:\t%s\n",
- srv_name, usr.ntc.user_name, usr.ntc.domain);
- report(out_hnd, "Connection:\t");
-
- if (!cli_net_use_del(srv_name, &usr.ntc, force_close, &closed))
- report(out_hnd, ": Does not exist\n");
- else if (force_close && closed)
- report(out_hnd, ": Forcibly terminated\n");
- else if (closed)
- report(out_hnd, ": Terminated\n");
- else
- report(out_hnd, ": Unlinked\n");
- }
-
- /* paranoia: destroy the local copy of the password */
- ZERO_STRUCT(password);
-
- return 0;
-}
-
-/******************************************************************
- allow or disallow automatic connections. rpctorture, because it
- does not reestablish connections after sys_fork(), fails unless the
- connection is established AFTER the sys_fork()
- ******************************************************************/
-static BOOL auto_connect = True;
-void cmd_set_no_autoconnect(void)
-{
- auto_connect = False;
-}
-
-#define CMD_STR 0x1
-#define CMD_DBF 0x2
-#define CMD_SVC 0x4
-#define CMD_TERM 0x8
-#define CMD_PASS 0x10
-#define CMD_USER 0x20
-#define CMD_NOPW 0x40
-#define CMD_DBLV 0x80
-#define CMD_HELP 0x100
-#define CMD_SOCK 0x200
-#define CMD_IFACE 0x400
-#define CMD_DOM 0x800
-#define CMD_IP 0x1000
-#define CMD_HOST 0x2000
-#define CMD_NAME 0x4000
-#define CMD_DBG 0x8000
-#define CMD_SCOPE 0x10000
-#define CMD_INTER 0x20000
-
-static void read_authfile (char *filename, char* username, char* password)
-{
- FILE *auth;
- fstring buf;
- uint16 len = 0;
- char *ptr, *val, *param;
-
- if ((auth=sys_fopen(filename, "r")) == NULL)
- {
- /* fail if we can't open the credentials file */
- DEBUG(0,("ERROR: Unable to open credentials file!\n"));
- return;
- }
-
- while (!feof(auth))
- {
- /* get a line from the file */
- if (!fgets (buf, sizeof(buf), auth))
- continue;
-
- len = strlen(buf);
-
- /* skip empty lines */
- if ((len) && (buf[len-1]=='\n'))
- {
- buf[len-1] = '\0';
- len--;
- }
- if (len == 0)
- continue;
-
- /* break up the line into parameter & value.
- will need to eat a little whitespace possibly */
- param = buf;
- if (!(ptr = strchr_m(buf, '=')))
- continue;
- val = ptr+1;
- *ptr = '\0';
-
- /* eat leading white space */
- while ((*val!='\0') && ((*val==' ') || (*val=='\t')))
- val++;
-
- if (strwicmp("password", param) == 0)
- {
- pstrcpy(password, val);
- cmd_set_options |= CMD_PASS;
- }
- else if (strwicmp("username", param) == 0)
- {
- pstrcpy(username, val);
- cmd_set_options |= CMD_USER;
- }
-
- memset(buf, 0, sizeof(buf));
- }
- fclose(auth);
-
- return;
-}
-
-static uint32 cmd_set(CLIENT_INFO *info, int argc, char *argv[])
-{
- BOOL interactive = True;
- char *cmd_str = NULL;
- int opt;
- extern char *optarg;
- static pstring servicesf = CONFIGFILE;
- pstring term_code;
- pstring password; /* local copy only, if one is entered */
- fstring srv_name;
- int new_debuglevel = -1;
-
- password[0] = 0;
- usr_creds = &usr;
- info->reuse = False;
-#ifdef KANJI
- pstrcpy(term_code, KANJI);
-#else /* KANJI */
- *term_code = 0;
-#endif /* KANJI */
-
- if (argc > 1 && (*argv[1] != '-'))
- {
- if (strnequal("\\\\", argv[1], 2) ||
- strnequal("//", argv[1], 2))
- {
- cmd_set_options |= CMD_HOST;
- pstrcpy(cli_info.dest_host, argv[1] + 2);
- strupper(cli_info.dest_host);
- }
- argc--;
- argv++;
- }
-
- if (argc > 1 && (*argv[1] != '-'))
- {
- cmd_set_options |= CMD_PASS;
- pstrcpy(password, argv[1]);
- memset(argv[1], 'X', strlen(argv[1]));
- argc--;
- argv++;
- }
-
- while ((opt = getopt(argc, argv,"PRs:O:M:S:i:Nn:d:l:hI:EB:U:L:t:m:W:T:D:c:A:")) != EOF)
- {
- switch (opt)
- {
- /* reuse connections in the case of a previous authentication */
- case 'R':
- {
- info->reuse = True;
- break;
- }
-
- /* max protocol */
- case 'm':
- {
- /* FIXME ... max_protocol seems to be funny here */
-
- int max_protocol = 0;
- max_protocol = interpret_protocol(optarg, max_protocol);
- fprintf(stderr, "max protocol not currently supported\n");
- break;
- }
-
- /* socket options */
- case 'O':
- {
- cmd_set_options |= CMD_SOCK;
- pstrcpy(user_socket_options, optarg);
- break;
- }
-
- /* define the server to connect to */
- case 'S':
- {
- cmd_set_options |= CMD_HOST;
- pstrcpy(cli_info.dest_host, optarg);
- strupper(cli_info.dest_host);
- break;
- }
-
- /* username for the connection -- support the
- username%password format as well */
- case 'U':
- {
- char *lp;
- cmd_set_options |= CMD_USER;
- pstrcpy(usr.ntc.user_name, optarg);
- if ((lp = strchr_m(usr.ntc.user_name, '%')))
- {
- *lp = 0;
- pstrcpy(password, lp + 1);
- cmd_set_options |= CMD_PASS;
- memset(lp+1, 'X', strlen(password));
- }
- break;
- }
-
- /* authfile -- only get the username and password from the file */
- case 'A':
- {
- read_authfile (optarg, usr.ntc.user_name, password);
- break;
- }
-
- /* define the workgroup/domain name */
- case 'W':
- {
- cmd_set_options |= CMD_DOM;
- pstrcpy(usr.ntc.domain, optarg);
- break;
- }
-
- /* should we display a command prompt at all */
- case 'P':
- { /* optarg == prompt string ? */
- info->show_prompt = False;
- break;
- }
-
- /* send to stderr instaed of stdout */
- case 'E':
- {
- cmd_set_options |= CMD_DBG;
- dbf = x_stderr;
- break;
- }
-
- /* IP address of destination host */
- case 'I':
- {
- cmd_set_options |= CMD_IP;
- cli_info.dest_ip = *interpret_addr2(optarg);
- if (zero_ip(cli_info.dest_ip))
- {
- free_connections();
- exit(1);
- }
- break;
- }
-
- /* define netbios name of client machine we are on */
- case 'n':
- {
- cmd_set_options |= CMD_NAME;
- fstrcpy(global_myname, optarg);
- break;
- }
-
- /* do not prompt for a password. Implies anonymous connection
- unless the password was passed in username%password form */
- case 'N':
- {
- cmd_set_options |= CMD_NOPW | CMD_PASS;
- break;
- }
-
- /* debug level */
- case 'd':
- {
- cmd_set_options |= CMD_DBLV;
- if (*optarg == 'A')
- new_debuglevel = 10000;
- else
- new_debuglevel = atoi(optarg);
- break;
- }
-
- /* log file name */
- case 'l':
- {
- cmd_set_options |= CMD_INTER;
- slprintf(debugf, sizeof(debugf) - 1, "%s.client", optarg);
- interactive = False;
- break;
- }
-
- /* command string to be executed */
- case 'c':
- {
- cmd_set_options |= CMD_STR;
- cmd_str = optarg;
- break;
- }
-
- /* program usage/help screen */
- case 'h':
- {
- cmd_set_options |= CMD_HELP;
- usage(argv[0]);
- break;
- }
-
- /* config file to use */
- case 's':
- {
- cmd_set_options |= CMD_SVC;
- pstrcpy(servicesf, optarg);
- break;
- }
-
- /* terminal code */
- case 't':
- {
- cmd_set_options |= CMD_TERM;
- pstrcpy(term_code, optarg);
- break;
- }
-
- default:
- {
- cmd_set_options |= CMD_HELP;
- usage(argv[0]);
- break;
- }
- }
- }
-
-
- if (cmd_set_options & CMD_INTER)
- {
- setup_logging(debugf, interactive);
- if (!interactive)
- reopen_logs();
- }
-
- strupper(global_myname);
- fstrcpy(cli_info.myhostname, global_myname);
-
- if (cmd_set_options & CMD_SVC)
- {
- if (!lp_load(servicesf, True, False, False))
- {
- fprintf(stderr, "Can't load %s - run testparm to debug it\n",
- servicesf);
- }
-
- }
-
- if (new_debuglevel != -1) {
- DEBUGLEVEL = new_debuglevel;
- }
-
- if (cmd_set_options & CMD_INTER)
- {
- load_interfaces();
- }
-
- DEBUG(10, ("cmd_set: options: %x\n", cmd_set_options));
-
- if (cmd_set_options & CMD_HELP) {
- return 0;
- }
-
- /* NULL password if specified or is username is empty */
- if ((cmd_set_options & CMD_NOPW) || (strlen(usr.ntc.user_name) == 0))
- set_user_password(&usr.ntc, True, NULL);
- else
- set_user_password(&usr.ntc, ((cmd_set_options & CMD_PASS) != 0), password);
-
- /* paranoia: destroy the local copy of the password */
- ZERO_STRUCT(password);
-
- if (strcmp(cli_info.dest_host, "*") == 0)
- {
- /* special case - we want the PDC */
- struct in_addr ip;
- if (!resolve_srv_name(cli_info.dest_host, cli_info.dest_host, &ip)) {
- report(out_hnd, "ERROR: Failed to find the PDC\n");
- return 1;
- }
- }
-
- fstrcpy(srv_name, "\\\\");
- fstrcat(srv_name, cli_info.dest_host);
- strupper(srv_name);
-
-
- if (auto_connect)
- {
- BOOL isnew;
- report(out_hnd, "Server:\t%s:\tUser:\t%s\tDomain:\t%s\n",
- srv_name, usr.ntc.user_name, usr.ntc.domain);
- report(out_hnd, "Connection:\t");
-
- if (cli_net_use_add(srv_name, &usr.ntc, info->reuse, &isnew) != NULL)
- {
- report(out_hnd, "OK\n");
- }
- else
- {
- report(out_hnd, "FAILED\n");
- }
- /* ???? --jerry
- usr_creds = NULL; */
- }
-
- if (cmd_str != NULL)
- return process(&cli_info, cmd_str);
-
- return 0;
-}
-
-static void read_user_env(struct ntuser_creds *u)
-{
- pstring password;
-
- password[0] = 0;
-
- if (getenv("USER"))
- {
- char *p;
- pstrcpy(u->user_name, getenv("USER"));
-
- /* modification to support userid%passwd syntax in the USER var
- 25.Aug.97, jdblair@uab.edu */
-
- if ((p = strchr_m(u->user_name, '%')))
- {
- *p = 0;
- pstrcpy(password, p + 1);
- memset(strchr_m(getenv("USER"), '%') + 1, 'X',
- strlen(password));
- }
- }
-
- /* modification to support PASSWD environmental var
- 25.Aug.97, jdblair@uab.edu */
- if (getenv("PASSWD"))
- pstrcpy(password, getenv("PASSWD"));
-
- if (*u->user_name == 0 && getenv("LOGNAME"))
- pstrcpy(u->user_name, getenv("LOGNAME"));
-
- set_user_password(u, True, password);
-
- /* paranoia: destroy the local copy of the password */
- ZERO_STRUCT(password);
-}
-
-static void readline_init(void)
-{
-#ifdef HAVE_LIBREADLINE
- /* Initialise GNU Readline */ rl_readline_name = "rpcclient";
- rl_attempted_completion_function = completion_fn;
- rl_completion_entry_function = (Function *) complete_cmd_null;
-
- /* Initialise history list */
-
- using_history();
-
-#else
- int x;
- x = 0; /* stop compiler warnings */
-#endif /* HAVE_LIBREADLINE */
-}
-
-/****************************************************************************
- main program
-****************************************************************************/
-int command_main(int argc, char *argv[])
-{
- NTSTATUS status;
- mode_t myumask = 0755;
- char progname[255], path[255], *s;
- pstring msg;
-
- DEBUGLEVEL = 2;
-
- /* add in the internal command set and the various
- client RPC groups--spoolss, lsa, etc... */
- add_command_set(general_commands);
-
- /* usr_creds is a global most recently used set of user credentials
- retrieved from the connection list. */
- copy_user_creds(&usr, NULL);
- usr_creds = &usr;
- usr.ptr_ntc = 1;
-
- out_hnd = stdout;
-
- /* retrieve the binary name used when invoking the program
- for instances like samedit, etc... */
- strncpy(path, argv[0], 255);
- for (s = strtok(path, "/"); s; s = strtok(NULL, "/"))
- fstrcpy(progname, s);
-
- slprintf(debugf, sizeof(debugf) - 1,
- "%s/log.%s", LOGFILEBASE, progname);
-
- /* initialize usr */
- pstrcpy(usr.ntc.domain, "");
- pstrcpy(usr.ntc.user_name, "");
- pstrcpy(cli_info.myhostname, "");
- pstrcpy(cli_info.dest_host, "");
-
- /* init client_info struct */
- cli_info.dest_ip.s_addr = 0;
- cli_info.show_prompt = True;
- ZERO_STRUCT(cli_info.dom.level3_sid);
- ZERO_STRUCT(cli_info.dom.level5_sid);
- fstrcpy(cli_info.dom.level3_dom, "");
- fstrcpy(cli_info.dom.level5_dom, "");
-
- readline_init();
- TimeInit();
- init_connections();
-
- myumask = umask(0);
- umask(myumask);
-
- if (!get_myname(global_myname))
- {
- fprintf(stderr, "Failed to get my hostname.\n");
- }
-
- if (argc < 2)
- {
- usage(argv[0]);
- free_connections();
- exit(1);
- }
-
- read_user_env(&usr.ntc);
-
- cmd_set_options &= ~CMD_HELP;
- cmd_set_options &= ~CMD_STR;
- cmd_set_options &= ~CMD_NOPW;
- cmd_set_options &= ~CMD_USER;
- cmd_set_options &= ~CMD_PASS;
-
- /* parse the command line args
- init the first connection if possible
- process a command if passed in on the command line */
- status = cmd_set(&cli_info, argc, argv);
-
- /* Should we exit? Are we done? */
- if (cmd_set_options & (CMD_HELP|CMD_STR)) {
- free_connections();
- get_nt_error_msg(status, msg, sizeof(msg));
-
- report(out_hnd, "Exit Status: %s\n", msg);
- /* unix only has 8 bit error codes - blergh */
- exit(status & 0xFF);
- }
-
- DEBUG(3, ("%s client started (version %s)\n",
- timestring(False), VERSION));
-
- /* enter shell mode */
- status = process(&cli_info, NULL);
-
- /* cleanup */
- free_connections();
- free_cmd_set_array(num_commands, commands);
- num_commands = 0;
- commands = NULL;
-
- /* report and exit */
- get_nt_error_msg(status, msg, sizeof(msg));
- report(out_hnd, "Exit Status: %s\n", msg);
- return status;
-}