summaryrefslogtreecommitdiff
path: root/src/or/buffers.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2004-06-17 18:13:09 +0000
committerNick Mathewson <nickm@torproject.org>2004-06-17 18:13:09 +0000
commit37088869396bd862ff24a46b1ff554f7d7f8c772 (patch)
tree8cc653886db276a2389cb8275a1c85f3c927d2dd /src/or/buffers.c
parentdfaa5ce70ff2c96275512c4921998d0865828f81 (diff)
downloadtor-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.c21
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;
}