diff options
author | Nick Mathewson <nickm@torproject.org> | 2004-06-17 18:13:09 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2004-06-17 18:13:09 +0000 |
commit | 37088869396bd862ff24a46b1ff554f7d7f8c772 (patch) | |
tree | 8cc653886db276a2389cb8275a1c85f3c927d2dd /src/or/buffers.c | |
parent | dfaa5ce70ff2c96275512c4921998d0865828f81 (diff) | |
download | tor-37088869396bd862ff24a46b1ff554f7d7f8c772.tar.gz tor-37088869396bd862ff24a46b1ff554f7d7f8c772.zip |
Implement RESOLVE/RESOLVED cells and socks resolve code
svn:r1978
Diffstat (limited to 'src/or/buffers.c')
-rw-r--r-- | src/or/buffers.c | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/src/or/buffers.c b/src/or/buffers.c index 13824a20a7..855443dd3f 100644 --- a/src/or/buffers.c +++ b/src/or/buffers.c @@ -409,6 +409,9 @@ int fetch_from_buf_http(buf_t *buf, return 1; } +#define SOCKS_COMMAND_CONNECT 0x01 +#define SOCKS_COMMAND_RESOLVE 0xF0 + /** There is a (possibly incomplete) socks handshake on <b>buf</b>, of one * of the forms * - socks4: "socksheader username\\0" @@ -467,8 +470,12 @@ int fetch_from_buf_socks(buf_t *buf, socks_request_t *req) { log_fn(LOG_DEBUG,"socks5: checking request"); if(buf->datalen < 8) /* basic info plus >=2 for addr plus 2 for port */ return 0; /* not yet */ - if(*(buf->mem+1) != 1) { /* not a connect? we don't support it. */ - log_fn(LOG_WARN,"socks5: command %d not '1'. Rejecting.",*(buf->mem+1)); + req->command = (unsigned char) *(buf->mem+1); + if(req->command != SOCKS_COMMAND_CONNECT && + req->command != SOCKS_COMMAND_RESOLVE) { + /* not a connect or resolve? we don't support it. */ + log_fn(LOG_WARN,"socks5: command %d not recognized. Rejecting.", + req->command); return -1; } switch(*(buf->mem+3)) { /* address type */ @@ -516,14 +523,18 @@ int fetch_from_buf_socks(buf_t *buf, socks_request_t *req) { if(buf->datalen < SOCKS4_NETWORK_LEN) /* basic info available? */ return 0; /* not yet */ - if(*(buf->mem+1) != 1) { /* not a connect? we don't support it. */ - log_fn(LOG_WARN,"socks4: command %d not '1'. Rejecting.",*(buf->mem+1)); + req->command = (unsigned char) *(buf->mem+1); + if(req->command != SOCKS_COMMAND_CONNECT && + req->command != SOCKS_COMMAND_RESOLVE) { + /* not a connect or resolve? we don't support it. */ + log_fn(LOG_WARN,"socks4: command %d not recognized. Rejecting.", + req->command); return -1; } req->port = ntohs(*(uint16_t*)(buf->mem+2)); destip = ntohl(*(uint32_t*)(buf->mem+4)); - if(!req->port || !destip) { + if((!req->port && req->command!=SOCKS_COMMAND_RESOLVE) || !destip) { log_fn(LOG_WARN,"socks4: Port or DestIP is zero. Rejecting."); return -1; } |