diff options
author | Roger Dingledine <arma@torproject.org> | 2005-09-29 23:59:36 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2005-09-29 23:59:36 +0000 |
commit | ea18827ceef0612344d51a2a3f39f6003cd1491a (patch) | |
tree | 51303cb434854eae4e642bc30f3a460be7954ba2 /src/or/directory.c | |
parent | f8d430653e1d7426d3725cb851881baead6d1c16 (diff) | |
download | tor-ea18827ceef0612344d51a2a3f39f6003cd1491a.tar.gz tor-ea18827ceef0612344d51a2a3f39f6003cd1491a.zip |
do the other half of dirport reachability testing.
it should be back and working now.
svn:r5155
Diffstat (limited to 'src/or/directory.c')
-rw-r--r-- | src/or/directory.c | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/src/or/directory.c b/src/or/directory.c index db2f4f16cc..850ad07351 100644 --- a/src/or/directory.c +++ b/src/or/directory.c @@ -1008,10 +1008,14 @@ connection_dir_client_reached_eof(connection_t *conn) tor_free(body); tor_free(headers); tor_free(reason); return -1; } - /* as we learn from them, we remove them from 'which' */ - router_load_routers_from_string(body, 0, which); - directory_info_has_arrived(time(NULL), 0); if (which) { + /* We only call these if it's a "fp/" request, since + * it's the only way we'll be adding new server descriptors + * and thus the only way we'd affect has_fetched_directory. */ + + /* as we learn from them, we remove them from 'which' */ + router_load_routers_from_string(body, 0, which); + directory_info_has_arrived(time(NULL), 0); log_fn(LOG_NOTICE, "Received %d/%d routers.", n_asked_for-smartlist_len(which), n_asked_for); if (smartlist_len(which)) { @@ -1020,6 +1024,16 @@ connection_dir_client_reached_eof(connection_t *conn) SMARTLIST_FOREACH(which, char *, cp, tor_free(cp)); smartlist_free(which); } + if (conn->requested_resource && + !strcmpstart(conn->requested_resource,"authority")) { + /* this might have been a dirport reachability test. see if it is. */ + routerinfo_t *me = router_get_my_routerinfo(); + if (me && + !memcmp(me->identity_digest, conn->identity_digest, DIGEST_LEN) && + me->addr == conn->addr && + me->dir_port == conn->port) + router_dirport_found_reachable(); + } } if (conn->purpose == DIR_PURPOSE_UPLOAD_DIR) { |