summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatt Johnston <matt@ucc.asn.au>2008-09-17 14:36:49 +0000
committerMatt Johnston <matt@ucc.asn.au>2008-09-17 14:36:49 +0000
commit248a1a627550251a09caf7f75b4e3307a45945bf (patch)
tree10acbe7897eb344b39aa31dcd83cdc9719ae70e7
parent99acea6abb6e6063e9a9a7572a854bea25b51c7a (diff)
downloaddropbear-248a1a627550251a09caf7f75b4e3307a45945bf.tar.gz
Rework netcat-alike to be a proper mode, with -B argument.dbclient-netcat-alike
-rw-r--r--chansession.h3
-rw-r--r--cli-chansession.c63
-rw-r--r--cli-runopts.c76
-rw-r--r--cli-session.c26
-rw-r--r--dbutil.c2
-rw-r--r--options.h4
-rw-r--r--runopts.h5
7 files changed, 127 insertions, 52 deletions
diff --git a/chansession.h b/chansession.h
index 213c285..4513b1a 100644
--- a/chansession.h
+++ b/chansession.h
@@ -78,6 +78,9 @@ void addnewvar(const char* param, const char* var);
void cli_send_chansess_request();
void cli_tty_cleanup();
void cli_chansess_winchange();
+#ifdef ENABLE_CLI_NETCAT
+void cli_send_netcat_request();
+#endif
void svr_chansessinitialise();
extern const struct ChanType svrchansess;
diff --git a/cli-chansession.c b/cli-chansession.c
index beb065c..07b9b9d 100644
--- a/cli-chansession.c
+++ b/cli-chansession.c
@@ -338,9 +338,8 @@ static void send_chansess_shell_req(struct Channel *channel) {
TRACE(("leave send_chansess_shell_req"))
}
-static int cli_initchansess(struct Channel *channel) {
-
-
+/* Shared for normal client channel and netcat-alike */
+static int cli_init_stdpipe_sess(struct Channel *channel) {
channel->writefd = STDOUT_FILENO;
setnonblocking(STDOUT_FILENO);
@@ -351,6 +350,12 @@ static int cli_initchansess(struct Channel *channel) {
setnonblocking(STDERR_FILENO);
channel->extrabuf = cbuf_new(opts.recv_window);
+ return 0;
+}
+
+static int cli_initchansess(struct Channel *channel) {
+
+ cli_init_stdpipe_sess(channel);
if (cli_opts.wantpty) {
send_chansess_pty_req(channel);
@@ -363,52 +368,60 @@ static int cli_initchansess(struct Channel *channel) {
}
return 0; /* Success */
-
}
-void cli_send_chansess_request() {
+#ifdef ENABLE_CLI_NETCAT
+
+void cli_send_netcat_request() {
- unsigned int port = 0;
- unsigned char* addr = NULL;
- unsigned char* ipstring = "127.0.0.1";
- unsigned char* portstring = "22";
+ const unsigned char* source_host = "127.0.0.1";
+ const int source_port = 22;
- /* hack hack */
- static const struct ChanType cli_chan_tcphack = {
+ const struct ChanType cli_chan_netcat = {
0, /* sepfds */
"direct-tcpip",
- NULL,
+ cli_init_stdpipe_sess, /* inithandler */
NULL,
NULL,
cli_closechansess
};
- TRACE(("enter cli_send_chansess_request"))
- if (send_msg_channel_open_init(STDIN_FILENO, &cli_chan_tcphack)
+ cli_opts.wantpty = 0;
+
+ if (send_msg_channel_open_init(STDIN_FILENO, &cli_chan_netcat)
== DROPBEAR_FAILURE) {
dropbear_exit("Couldn't open initial channel");
}
- if (cli_opts.localfwds == NULL) {
- dropbear_exit("You need to give a \"-L ignored:host:port\" option with this hacked up dbclient.");
- }
+ buf_putstring(ses.writepayload, cli_opts.netcat_host,
+ strlen(cli_opts.netcat_host));
+ buf_putint(ses.writepayload, cli_opts.netcat_port);
- addr = cli_opts.localfwds->connectaddr;
- port = cli_opts.localfwds->connectport;
+ /* originator ip - localhost is accurate enough */
+ buf_putstring(ses.writepayload, source_host, strlen(source_host));
+ buf_putint(ses.writepayload, source_port);
- buf_putstring(ses.writepayload, addr, strlen(addr));
- buf_putint(ses.writepayload, port);
+ encrypt_packet();
+ TRACE(("leave cli_send_chansess_request"))
+}
+#endif
- /* originator ip */
- buf_putstring(ses.writepayload, ipstring, strlen(ipstring));
- /* originator port */
- buf_putint(ses.writepayload, atol(portstring));
+void cli_send_chansess_request() {
+ TRACE(("enter cli_send_chansess_request"))
+
+ if (send_msg_channel_open_init(STDIN_FILENO, &clichansess)
+ == DROPBEAR_FAILURE) {
+ dropbear_exit("Couldn't open initial channel");
+ }
+
+ /* No special channel request data */
encrypt_packet();
TRACE(("leave cli_send_chansess_request"))
}
+
#if 0
while (cli_opts.localfwds != NULL) {
ret = cli_localtcp(cli_opts.localfwds->listenport,
diff --git a/cli-runopts.c b/cli-runopts.c
index 42c5a9f..b45af05 100644
--- a/cli-runopts.c
+++ b/cli-runopts.c
@@ -33,12 +33,15 @@
cli_runopts cli_opts; /* GLOBAL */
static void printhelp();
-static void parsehostname(char* userhostarg);
+static void parsehostname(const char* orighostarg);
#ifdef ENABLE_CLI_PUBKEY_AUTH
static void loadidentityfile(const char* filename);
#endif
#ifdef ENABLE_CLI_ANYTCPFWD
-static void addforward(char* str, struct TCPFwdList** fwdlist);
+static void addforward(const char* str, struct TCPFwdList** fwdlist);
+#endif
+#ifdef ENABLE_CLI_NETCAT
+static void add_netcat(const char *str);
#endif
static void printhelp() {
@@ -65,6 +68,9 @@ static void printhelp() {
#endif
"-W <receive_window_buffer> (default %d, larger may be faster, max 1MB)\n"
"-K <keepalive> (0 is never, default %d)\n"
+#ifdef ENABLE_CLI_NETCAT
+ "-B <endhost:endport> Netcat-alike bouncing\n"
+#endif
#ifdef DEBUG_TRACE
"-v verbose\n"
#endif
@@ -87,6 +93,9 @@ void cli_getopts(int argc, char ** argv) {
#ifdef ENABLE_CLI_REMOTETCPFWD
int nextisremote = 0;
#endif
+#ifdef ENABLE_CLI_NETCAT
+ int nextisnetcat = 0;
+#endif
char* dummy = NULL; /* Not used for anything real */
char* recv_window_arg = NULL;
@@ -144,6 +153,14 @@ void cli_getopts(int argc, char ** argv) {
continue;
}
#endif
+#ifdef ENABLE_CLI_NETCAT
+ if (nextisnetcat) {
+ TRACE(("nextisnetcat true"))
+ add_netcat(argv[i]);
+ nextisnetcat = 0;
+ continue;
+ }
+#endif
if (next) {
/* The previous flag set a value to assign */
*next = argv[i];
@@ -199,6 +216,11 @@ void cli_getopts(int argc, char ** argv) {
nextisremote = 1;
break;
#endif
+#ifdef ENABLE_CLI_NETCAT
+ case 'B':
+ nextisnetcat = 1;
+ break;
+#endif
case 'l':
next = &cli_opts.username;
break;
@@ -351,15 +373,13 @@ static void loadidentityfile(const char* filename) {
#endif
-/* Parses a [user@]hostname argument. userhostarg is the argv[i] corresponding
- * - note that it will be modified */
-static void parsehostname(char* orighostarg) {
+/* Parses a [user@]hostname argument. orighostarg is the argv[i] corresponding */
+static void parsehostname(const char* orighostarg) {
uid_t uid;
struct passwd *pw = NULL;
char *userhostarg = NULL;
- /* We probably don't want to be editing argvs */
userhostarg = m_strdup(orighostarg);
cli_opts.remotehost = strchr(userhostarg, '@');
@@ -389,10 +409,48 @@ static void parsehostname(char* orighostarg) {
}
}
+#ifdef ENABLE_CLI_NETCAT
+static void add_netcat(const char* origstr) {
+ char *portstr = NULL;
+
+ char * str = m_strdup(origstr);
+
+ portstr = strchr(str, ':');
+ if (portstr == NULL) {
+ TRACE(("No netcat port"))
+ goto fail;
+ }
+ *portstr = '\0';
+ portstr++;
+
+ if (strchr(portstr, ':')) {
+ TRACE(("Multiple netcat colons"))
+ goto fail;
+ }
+
+ cli_opts.netcat_port = strtoul(portstr, NULL, 10);
+ if (errno != 0) {
+ TRACE(("bad netcat port"))
+ goto fail;
+ }
+
+ if (cli_opts.netcat_port > 65535) {
+ TRACE(("too large netcat port"))
+ goto fail;
+ }
+
+ cli_opts.netcat_host = str;
+ return;
+
+fail:
+ dropbear_exit("Bad netcat endpoint '%s'", origstr);
+}
+#endif
+
#ifdef ENABLE_CLI_ANYTCPFWD
/* Turn a "listenport:remoteaddr:remoteport" string into into a forwarding
* set, and add it to the forwarding list */
-static void addforward(char* origstr, struct TCPFwdList** fwdlist) {
+static void addforward(const char* origstr, struct TCPFwdList** fwdlist) {
char * listenport = NULL;
char * connectport = NULL;
@@ -428,13 +486,13 @@ static void addforward(char* origstr, struct TCPFwdList** fwdlist) {
/* Now we check the ports - note that the port ints are unsigned,
* the check later only checks for >= MAX_PORT */
- newfwd->listenport = strtol(listenport, NULL, 10);
+ newfwd->listenport = strtoul(listenport, NULL, 10);
if (errno != 0) {
TRACE(("bad listenport strtol"))
goto fail;
}
- newfwd->connectport = strtol(connectport, NULL, 10);
+ newfwd->connectport = strtoul(connectport, NULL, 10);
if (errno != 0) {
TRACE(("bad connectport strtol"))
goto fail;
diff --git a/cli-session.c b/cli-session.c
index 6668914..f14a2e3 100644
--- a/cli-session.c
+++ b/cli-session.c
@@ -197,20 +197,6 @@ static void cli_sessionloop() {
TRACE(("leave cli_sessionloop: cli_auth_try"))
return;
- /*
- case USERAUTH_SUCCESS_RCVD:
- send_msg_service_request(SSH_SERVICE_CONNECTION);
- cli_ses.state = SERVICE_CONN_REQ_SENT;
- TRACE(("leave cli_sessionloop: sent ssh-connection service req"))
- return;
-
- case SERVICE_CONN_ACCEPT_RCVD:
- cli_send_chansess_request();
- TRACE(("leave cli_sessionloop: cli_send_chansess_request"))
- cli_ses.state = SESSION_RUNNING;
- return;
- */
-
case USERAUTH_SUCCESS_RCVD:
if (cli_opts.backgrounded) {
@@ -230,12 +216,18 @@ static void cli_sessionloop() {
}
#ifdef ENABLE_CLI_LOCALTCPFWD
- //setup_localtcp();
+ setup_localtcp();
#endif
#ifdef ENABLE_CLI_REMOTETCPFWD
- //setup_remotetcp();
+ setup_remotetcp();
+#endif
+
+#ifdef ENABLE_CLI_NETCAT
+ if (cli_opts.netcat_host) {
+ cli_send_netcat_request();
+ } else
#endif
- if (!cli_opts.no_cmd) {
+ if (!cli_opts.no_cmd) {
cli_send_chansess_request();
}
TRACE(("leave cli_sessionloop: running"))
diff --git a/dbutil.c b/dbutil.c
index 0967ddc..b0496cf 100644
--- a/dbutil.c
+++ b/dbutil.c
@@ -146,7 +146,7 @@ void dropbear_trace(const char* format, ...) {
}
va_start(param, format);
- fprintf(stderr, "TRACE: ");
+ fprintf(stderr, "TRACE (%d): ", getpid());
vfprintf(stderr, format, param);
fprintf(stderr, "\n");
va_end(param);
diff --git a/options.h b/options.h
index 5385d30..d1abc81 100644
--- a/options.h
+++ b/options.h
@@ -66,6 +66,10 @@ etc) slower (perhaps by 50%). Recommended for most small systems. */
/* Enable Authentication Agent Forwarding - server only for now */
#define ENABLE_AGENTFWD
+/* Enable "Netcat mode". TODO describe here. */
+#define ENABLE_CLI_NETCAT
+
+
/* Encryption - at least one required.
* RFC Draft requires 3DES and recommends AES128 for interoperability.
* Including multiple keysize variants the same cipher
diff --git a/runopts.h b/runopts.h
index d6e8917..162c9fd 100644
--- a/runopts.h
+++ b/runopts.h
@@ -118,6 +118,11 @@ typedef struct cli_runopts {
struct TCPFwdList * localfwds;
#endif
+#ifdef ENABLE_CLI_NETCAT
+ char *netcat_host;
+ unsigned int netcat_port;
+#endif
+
} cli_runopts;
extern cli_runopts cli_opts;