aboutsummaryrefslogtreecommitdiff
path: root/src/or/buffers.c
diff options
context:
space:
mode:
authorrl1987 <rl1987@sdf.lonestar.org>2014-10-12 21:04:15 +0300
committerNick Mathewson <nickm@torproject.org>2014-11-04 00:36:42 -0500
commit2862b769deaaaa40347ffe808349c4e139e7eb45 (patch)
tree6ba337a532f9e8df33a43f6d06870087004f15b8 /src/or/buffers.c
parente8e45ff13ed86d8851bab77d65d899d0ca6e3b89 (diff)
downloadtor-2862b769deaaaa40347ffe808349c4e139e7eb45.tar.gz
tor-2862b769deaaaa40347ffe808349c4e139e7eb45.zip
Validating SOCKS5 hostname more correctly.
Diffstat (limited to 'src/or/buffers.c')
-rw-r--r--src/or/buffers.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/or/buffers.c b/src/or/buffers.c
index d174f8147a..e98f56932d 100644
--- a/src/or/buffers.c
+++ b/src/or/buffers.c
@@ -2048,7 +2048,15 @@ parse_socks(const char *data, size_t datalen, socks_request_t *req,
req->address[len] = 0;
req->port = ntohs(get_uint16(data+5+len));
*drain_out = 5+len+2;
- if (!tor_strisprint(req->address) || strchr(req->address,'\"')) {
+
+ if (string_is_valid_ipv4_address(req->address)) {
+ log_unsafe_socks_warning(5,req->address,req->port,safe_socks);
+
+ if (safe_socks)
+ return -1;
+ }
+
+ if (!string_is_valid_hostname(req->address)) {
log_warn(LD_PROTOCOL,
"Your application (using socks5 to port %d) gave Tor "
"a malformed hostname: %s. Rejecting the connection.",