diff options
author | Nick Mathewson <nickm@torproject.org> | 2014-12-30 08:34:48 -0500 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2014-12-30 08:34:48 -0500 |
commit | e936b9b47de954fa1f34110b871edc695cbcf696 (patch) | |
tree | 36c41a9cf6efe518dafda23a0bdf11fe16abcf71 /src/or/connection_edge.c | |
parent | d7ecdd645a68eeb7a5ab8c839479a05cc8a1e10e (diff) | |
parent | 88901c39673aade6eecbf0b5a11a0b5c9acfd9f7 (diff) | |
download | tor-e936b9b47de954fa1f34110b871edc695cbcf696.tar.gz tor-e936b9b47de954fa1f34110b871edc695cbcf696.zip |
Merge remote-tracking branch 'dgoulet/bug13667_025_v4'
Diffstat (limited to 'src/or/connection_edge.c')
-rw-r--r-- | src/or/connection_edge.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/src/or/connection_edge.c b/src/or/connection_edge.c index 6c872852b3..a691239b6e 100644 --- a/src/or/connection_edge.c +++ b/src/or/connection_edge.c @@ -2613,12 +2613,23 @@ connection_exit_begin_conn(cell_t *cell, circuit_t *circ) if (rend_service_set_connection_addr_port(n_stream, origin_circ) < 0) { log_info(LD_REND,"Didn't find rendezvous service (port %d)", n_stream->base_.port); + /* Send back reason DONE because we want to make hidden service port + * scanning harder thus instead of returning that the exit policy + * didn't match, which makes it obvious that the port is closed, + * return DONE and kill the circuit. That way, a user (malicious or + * not) needs one circuit per bad port unless it matches the policy of + * the hidden service. */ relay_send_end_cell_from_edge(rh.stream_id, circ, - END_STREAM_REASON_EXITPOLICY, + END_STREAM_REASON_DONE, origin_circ->cpath->prev); connection_free(TO_CONN(n_stream)); tor_free(address); - return 0; + + /* Drop the circuit here since it might be someone deliberately + * scanning the hidden service ports. Note that this mitigates port + * scanning by adding more work on the attacker side to successfully + * scan but does not fully solve it. */ + return END_CIRC_AT_ORIGIN; } assert_circuit_ok(circ); log_debug(LD_REND,"Finished assigning addr/port"); |