aboutsummaryrefslogtreecommitdiff
path: root/src/or/directory.c
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2005-09-29 23:59:36 +0000
committerRoger Dingledine <arma@torproject.org>2005-09-29 23:59:36 +0000
commitea18827ceef0612344d51a2a3f39f6003cd1491a (patch)
tree51303cb434854eae4e642bc30f3a460be7954ba2 /src/or/directory.c
parentf8d430653e1d7426d3725cb851881baead6d1c16 (diff)
downloadtor-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.c20
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) {