aboutsummaryrefslogtreecommitdiff
path: root/src/or/circuituse.c
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2007-01-27 19:29:16 +0000
committerRoger Dingledine <arma@torproject.org>2007-01-27 19:29:16 +0000
commitadd7d7af195109a06c46c6072b3a4faf4f6ce363 (patch)
tree33e15ddf3f3fcf3e9797a913e0571ae5da13f518 /src/or/circuituse.c
parent0e01dda145d372840011ad168d61b30b2b6cde32 (diff)
downloadtor-add7d7af195109a06c46c6072b3a4faf4f6ce363.tar
tor-add7d7af195109a06c46c6072b3a4faf4f6ce363.tar.gz
Bring us one step closer to being able to establish an encrypted
directory tunnel without knowing a descriptor first. Still not ready yet. As part of the change, now assume we can use a create_fast cell if we don't know anything about a router. svn:r9440
Diffstat (limited to 'src/or/circuituse.c')
-rw-r--r--src/or/circuituse.c40
1 files changed, 30 insertions, 10 deletions
diff --git a/src/or/circuituse.c b/src/or/circuituse.c
index 4114d1295..36c7a0ac1 100644
--- a/src/or/circuituse.c
+++ b/src/or/circuituse.c
@@ -1011,18 +1011,38 @@ circuit_get_open_circ_or_launch(edge_connection_t *conn,
if (conn->chosen_exit_name) {
routerinfo_t *r;
int opt = conn->_base.chosen_exit_optional;
- if (!(r = router_get_by_nickname(conn->chosen_exit_name, 1))) {
- log_fn(opt ? LOG_INFO : LOG_WARN, LD_APP,
- "Requested exit point '%s' is not known. %s.",
- conn->chosen_exit_name, opt ? "Trying others" : "Closing");
- if (opt) {
- conn->_base.chosen_exit_optional = 0;
- tor_free(conn->chosen_exit_name);
- return 0;
+ r = router_get_by_nickname(conn->chosen_exit_name, 1);
+ if (r) {
+ extend_info = extend_info_from_router(r);
+ } else {
+ if (want_onehop && conn->chosen_exit_name[0] == '$') {
+ /* We're asking for a one-hop circuit to a router that
+ * we don't have a routerinfo about. Hope we have a
+ * routerstatus or equivalent. */
+ routerstatus_t *s =
+ routerstatus_get_by_hexdigest(conn->chosen_exit_name+1);
+ if (s) {
+ extend_info = extend_info_from_routerstatus(s);
+ } else {
+ log_warn(LD_APP,
+ "Requested router '%s' is not known. Closing.",
+ conn->chosen_exit_name);
+ return -1;
+ }
+ } else {
+ /* We will need an onion key for the router, and we
+ * don't have one. Refuse or relax requirements. */
+ log_fn(opt ? LOG_INFO : LOG_WARN, LD_APP,
+ "Requested exit point '%s' is not known. %s.",
+ conn->chosen_exit_name, opt ? "Trying others" : "Closing");
+ if (opt) {
+ conn->_base.chosen_exit_optional = 0;
+ tor_free(conn->chosen_exit_name);
+ return 0;
+ }
+ return -1;
}
- return -1;
}
- extend_info = extend_info_from_router(r);
}
}