summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-04-22 21:10:41 +0000
committerNick Mathewson <nickm@torproject.org>2008-04-22 21:10:41 +0000
commit41929c2684e003ab3babf836bfe88bfa0d336b26 (patch)
tree4b22a200e967e4f00853f320df098249e7fef015 /src
parentd72b256f4f0a3a9c90793ea12daae7af74072a16 (diff)
downloadtor-41929c2684e003ab3babf836bfe88bfa0d336b26.tar.gz
tor-41929c2684e003ab3babf836bfe88bfa0d336b26.zip
r15287@tombo: nickm | 2008-04-22 17:09:25 -0400
Periodically launch requests for server/authority.z when it might help us learn our IP. Fix for bug 652. svn:r14418
Diffstat (limited to 'src')
-rw-r--r--src/or/routerlist.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/or/routerlist.c b/src/or/routerlist.c
index 5ac4ee467b..994d019f56 100644
--- a/src/or/routerlist.c
+++ b/src/or/routerlist.c
@@ -4013,17 +4013,37 @@ update_consensus_router_descriptor_downloads(time_t now)
smartlist_free(no_longer_old);
}
+/** How often should we launch a server/authority request to be sure of getting
+ * a guess for our IP? */
+/*XXXX021 this info should come from netinfo cells or something, or we should
+ * do this only when we aren't seeing incoming data. see bug 652. */
+#define DUMMY_DOWNLOAD_INTERVAL (20*60)
+
/** Launch downloads for router status as needed. */
void
update_router_descriptor_downloads(time_t now)
{
or_options_t *options = get_options();
+ static time_t last_dummy_download = 0;
if (should_delay_dir_fetches(options))
return;
if (directory_fetches_dir_info_early(options)) {
update_router_descriptor_cache_downloads_v2(now);
}
update_consensus_router_descriptor_downloads(now);
+
+ /* XXXX021 we could be smarter here; see notes on bug 652. */
+ /* If we're a server that doesn't have a configured address, we rely on
+ * directory fetches to learn when our address changes. So if we haven't
+ * tried to get any routerdescs in a long time, try a dummy fetch now. */
+ if (!options->Address &&
+ server_mode(options) &&
+ last_routerdesc_download_attempted + DUMMY_DOWNLOAD_INTERVAL < now &&
+ last_dummy_download + DUMMY_DOWNLOAD_INTERVAL < now) {
+ last_dummy_download = now;
+ directory_get_from_dirserver(DIR_PURPOSE_FETCH_SERVERDESC,
+ ROUTER_PURPOSE_GENERAL, "authority.z", 1);
+ }
}
/** Launch extrainfo downloads as needed. */