diff options
author | Roger Dingledine <arma@torproject.org> | 2005-09-10 01:01:40 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2005-09-10 01:01:40 +0000 |
commit | 1d9786a3927fa4342e0396a02a962fcaea017708 (patch) | |
tree | 6e15a36a0a3c05bb8e8f13519d43c06f902348b7 | |
parent | 035b1953eba11febfd975727b7101f7bd423c3fc (diff) | |
download | tor-1d9786a3927fa4342e0396a02a962fcaea017708.tar.gz tor-1d9786a3927fa4342e0396a02a962fcaea017708.zip |
generalize route length to three plus one if the exit node is risky.
svn:r4978
-rw-r--r-- | src/or/circuitbuild.c | 28 |
1 files changed, 9 insertions, 19 deletions
diff --git a/src/or/circuitbuild.c b/src/or/circuitbuild.c index 29193f9955..12e34f8ee2 100644 --- a/src/or/circuitbuild.c +++ b/src/or/circuitbuild.c @@ -894,7 +894,8 @@ onionskin_answer(circuit_t *circ, uint8_t cell_type, char *payload, char *keys) * is feasible, except if it's less than 2, in which case return -1. */ static int -new_route_len(double cw, uint8_t purpose, smartlist_t *routers) +new_route_len(double cw, uint8_t purpose, extend_info_t *exit, + smartlist_t *routers) { int num_acceptable_routers; int routelen; @@ -906,23 +907,11 @@ new_route_len(double cw, uint8_t purpose, smartlist_t *routers) #ifdef TOR_PERF routelen = 2; #else - if (purpose == CIRCUIT_PURPOSE_C_GENERAL) - routelen = 3; - else if (purpose == CIRCUIT_PURPOSE_TESTING) - routelen = 3; - else if (purpose == CIRCUIT_PURPOSE_C_INTRODUCING) - routelen = 4; - else if (purpose == CIRCUIT_PURPOSE_C_ESTABLISH_REND) - routelen = 3; - else if (purpose == CIRCUIT_PURPOSE_S_ESTABLISH_INTRO) - routelen = 3; - else if (purpose == CIRCUIT_PURPOSE_S_CONNECT_REND) - routelen = 4; - else { - log_fn(LOG_WARN,"Bug: unhandled purpose %d", purpose); - tor_fragile_assert(); - return -1; - } + routelen = 3; + if (exit && + purpose != CIRCUIT_PURPOSE_TESTING && + purpose != CIRCUIT_PURPOSE_S_ESTABLISH_INTRO) + routelen++; #endif log_fn(LOG_DEBUG,"Chosen route length %d (%d routers available).",routelen, smartlist_len(routers)); @@ -1259,7 +1248,8 @@ onion_pick_cpath_exit(circuit_t *circ, extend_info_t *exit) log_fn(LOG_WARN,"router_get_routerlist returned empty list; closing circ."); return -1; } - r = new_route_len(get_options()->PathlenCoinWeight, circ->purpose, rl->routers); + r = new_route_len(get_options()->PathlenCoinWeight, circ->purpose, + exit, rl->routers); if (r < 1) /* must be at least 1 */ return -1; state->desired_path_len = r; |