diff options
author | Matt Johnston <matt@ucc.asn.au> | 2005-12-06 16:51:55 +0000 |
---|---|---|
committer | Matt Johnston <matt@ucc.asn.au> | 2005-12-06 16:51:55 +0000 |
commit | 6c56271e8c2f1a07de8ca7fddeb4f8efb5041b4c (patch) | |
tree | dc6bece4692049393b3d3ffd4990629c2c502ff5 | |
parent | a673d609639b180eee3a4ba49d7f07d0239ea666 (diff) |
* fix -L forwarding on the client, broke last rev
--HG--
extra : convert_revision : 826db75f8001f7da7b0b8c91dcf66a44bf107b49
-rw-r--r-- | cli-tcpfwd.c | 1 | ||||
-rw-r--r-- | svr-tcpfwd.c | 1 | ||||
-rw-r--r-- | tcp-accept.c | 29 | ||||
-rw-r--r-- | tcpfwd.h | 2 |
4 files changed, 24 insertions, 9 deletions
diff --git a/cli-tcpfwd.c b/cli-tcpfwd.c index d8f1da6..c3bfd4d 100644 --- a/cli-tcpfwd.c +++ b/cli-tcpfwd.c @@ -107,6 +107,7 @@ static int cli_localtcp(unsigned int listenport, const char* remoteaddr, tcpinfo->listenport = listenport; tcpinfo->chantype = &cli_chan_tcplocal; + tcpinfo->tcp_type = direct; ret = listen_tcpfwd(tcpinfo); diff --git a/svr-tcpfwd.c b/svr-tcpfwd.c index 6e70d67..53a115e 100644 --- a/svr-tcpfwd.c +++ b/svr-tcpfwd.c @@ -208,6 +208,7 @@ static int svr_remotetcpreq() { tcpinfo->listenaddr = bindaddr; tcpinfo->listenport = port; tcpinfo->chantype = &svr_chan_tcpremote; + tcpinfo->tcp_type = forwarded; ret = listen_tcpfwd(tcpinfo); diff --git a/tcp-accept.c b/tcp-accept.c index ac33566..90d72b3 100644 --- a/tcp-accept.c +++ b/tcp-accept.c @@ -65,15 +65,28 @@ static void tcp_acceptor(struct Listener *listener, int sock) { } if (send_msg_channel_open_init(fd, tcpinfo->chantype) == DROPBEAR_SUCCESS) { - - // address that was connected - buf_putstring(ses.writepayload, tcpinfo->listenaddr, - strlen(tcpinfo->listenaddr)); - // port that was connected - buf_putint(ses.writepayload, tcpinfo->listenport); - // originator ip + unsigned char* addr = NULL; + unsigned int port = 0; + + if (tcpinfo->tcp_type == direct) { + /* "direct-tcpip" */ + /* host to connect, port to connect */ + addr = tcpinfo->sendaddr; + port = tcpinfo->sendport; + } else { + dropbear_assert(tcpinfo->tcp_type == forwarded); + /* "forwarded-tcpip" */ + /* address that was connected, port that was connected */ + addr = tcpinfo->listenaddr; + port = tcpinfo->listenport; + } + + buf_putstring(ses.writepayload, addr, strlen(addr)); + buf_putint(ses.writepayload, port); + + /* originator ip */ buf_putstring(ses.writepayload, ipstring, strlen(ipstring)); - // originator port + /* originator port */ buf_putint(ses.writepayload, atol(portstring)); encrypt_packet(); @@ -40,7 +40,7 @@ struct TCPListener { unsigned int listenport; const struct ChanType *chantype; - + enum {direct, forwarded} tcp_type; }; /* A link in a list of forwards */ |