diff options
author | Nick Mathewson <nickm@torproject.org> | 2011-03-08 15:52:43 -0500 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2011-03-08 15:52:43 -0500 |
commit | 0d78a16c3642f7538266e007da79c39860aac332 (patch) | |
tree | 5e342568b1f08b14318ddd3b3996aa1125d20787 /src/or/dirserv.c | |
parent | 9c72324ae85c3f2cc23fee7d383128fa239b36d0 (diff) | |
parent | 5a4f7fa1e48923730376c0a42121e4c3022eef3b (diff) | |
download | tor-0d78a16c3642f7538266e007da79c39860aac332.tar.gz tor-0d78a16c3642f7538266e007da79c39860aac332.zip |
Merge remote branch 'sebastian/bug1035' into maint-0.2.2
Diffstat (limited to 'src/or/dirserv.c')
-rw-r--r-- | src/or/dirserv.c | 18 |
1 files changed, 13 insertions, 5 deletions
diff --git a/src/or/dirserv.c b/src/or/dirserv.c index 3c15c59dc4..aeeab45383 100644 --- a/src/or/dirserv.c +++ b/src/or/dirserv.c @@ -3116,19 +3116,27 @@ dirserv_orconn_tls_done(const char *address, tor_assert(address); tor_assert(digest_rcvd); - SMARTLIST_FOREACH(rl->routers, routerinfo_t *, ri, { + /* XXX023 Doing a loop like this is stupid. We should just look up the + * router by digest_rcvd, and see if address, orport, and as_advertised + * match up. -NM */ + SMARTLIST_FOREACH_BEGIN(rl->routers, routerinfo_t *, ri) { if (!strcasecmp(address, ri->address) && or_port == ri->or_port && as_advertised && !memcmp(ri->cache_info.identity_digest, digest_rcvd, DIGEST_LEN)) { /* correct digest. mark this router reachable! */ if (!bridge_auth || ri->purpose == ROUTER_PURPOSE_BRIDGE) { - log_info(LD_DIRSERV, "Found router %s to be reachable. Yay.", - ri->nickname); - rep_hist_note_router_reachable(digest_rcvd, now); + tor_addr_t addr, *addrp=NULL; + log_info(LD_DIRSERV, "Found router %s to be reachable at %s:%d. Yay.", + ri->nickname, address, ri->or_port ); + if (tor_addr_from_str(&addr, ri->address) != -1) + addrp = &addr; + else + log_warn(LD_BUG, "Couldn't parse IP address \"%s\"", ri->address); + rep_hist_note_router_reachable(digest_rcvd, addrp, or_port, now); ri->last_reachable = now; } } - }); + } SMARTLIST_FOREACH_END(ri); /* FFFF Maybe we should reinstate the code that dumps routers with the same * addr/port but with nonmatching keys, but instead of dumping, we should * skip testing. */ |