diff options
author | Roger Dingledine <arma@mit.edu> | 2009-06-12 11:18:02 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2009-06-12 11:18:02 -0400 |
commit | cb1617f18e94b244dc0847658e006057040dcc37 (patch) | |
tree | 2fde225a99244539b3a48bda27bbdd7e4592e1d0 | |
parent | 77f5ad6b07dcdd3271d56f5e9edde3dc56ffe411 (diff) | |
download | tor-cb1617f18e94b244dc0847658e006057040dcc37.tar.gz tor-cb1617f18e94b244dc0847658e006057040dcc37.zip |
Check answer_len in the remap_addr case of process_relay_cell_not_open.
Fix an edge case where a malicious exit relay could convince a
controller that the client's DNS question resolves to an internal IP
address. Bug found and fixed by "optimist"; bugfix on 0.1.2.8-beta.
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | src/or/relay.c | 2 |
2 files changed, 6 insertions, 1 deletions
@@ -1,4 +1,9 @@ Changes in version 0.2.2.1-alpha - 2009-??-?? + o Security fixes: + - Fix an edge case where a malicious exit relay could convince a + controller that the client's DNS question resolves to an internal IP + address. Bug found and fixed by "optimist"; bugfix on 0.1.2.8-beta. + o Major features: - Add support for dynamic OpenSSL hardware crypto acceleration engines via new AccelName and AccelDir options. diff --git a/src/or/relay.c b/src/or/relay.c index 4e09c0040b..e9baac6a45 100644 --- a/src/or/relay.c +++ b/src/or/relay.c @@ -947,7 +947,7 @@ connection_edge_process_relay_cell_not_open( cell->payload+RELAY_HEADER_SIZE+2, /*answer*/ ttl, -1); - if (answer_type == RESOLVED_TYPE_IPV4) { + if (answer_type == RESOLVED_TYPE_IPV4 && answer_len >= 4) { uint32_t addr = ntohl(get_uint32(cell->payload+RELAY_HEADER_SIZE+2)); remap_event_helper(conn, addr); } |