summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2009-02-09 16:55:48 +0000
committerNick Mathewson <nickm@torproject.org>2009-02-09 16:55:48 +0000
commit6f90f6f2a22d118d8aa7a8aad7770e690c4b7138 (patch)
tree366899106dc41c79c2658a23042fc24215c8fc88
parentc7315e65ae2940ac514fbd0e0a8e94e13db19cba (diff)
downloadtor-6f90f6f2a22d118d8aa7a8aad7770e690c4b7138.tar.gz
tor-6f90f6f2a22d118d8aa7a8aad7770e690c4b7138.zip
Retry circuits if the exit node is optional and nonexistant.
Previously, when we had the chosen_exit set but marked optional, and we failed because we couldn't find an onion key for it, we'd just give up on the circuit. But what we really want to do is try again, without the forced exit node. Spotted by rovv. Another case of bug 752. I think this might be unreachable in our current code, but proposal 158 could change that. svn:r18451
-rw-r--r--ChangeLog5
-rw-r--r--src/or/circuituse.c5
2 files changed, 9 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index ab192a01aa..1c0b8ee52d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -5,6 +5,11 @@ Changes in version 0.2.1.13-????? - 2009-0?-??
We previously did this from the startup script, but that was no
help to people who didn't use the startup script. Resolves
bug 863.
+ - When we had picked an exit node for a connection, but marked it as
+ "optional", and it turned out we had no onion key for the exit,
+ stop preferring the exit and try again. This situation may not be
+ possible now, but will probably become feasible with proposal 158.
+ Spotted by rovv. Fixes another case of bug 752.
o Minor features:
- On Linux, use the prctl call to re-enable core dumps when the user
diff --git a/src/or/circuituse.c b/src/or/circuituse.c
index 4bc6fcbe8f..a1c8d1c148 100644
--- a/src/or/circuituse.c
+++ b/src/or/circuituse.c
@@ -1165,7 +1165,10 @@ circuit_get_open_circ_or_launch(edge_connection_t *conn,
if (opt) {
conn->chosen_exit_optional = 0;
tor_free(conn->chosen_exit_name);
- return 0;
+ /* Try again with no requested exit */
+ return circuit_get_open_circ_or_launch(conn,
+ desired_circuit_purpose,
+ circp);
}
return -1;
}