diff options
author | Roger Dingledine <arma@torproject.org> | 2008-09-14 04:07:29 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2008-09-14 04:07:29 +0000 |
commit | dbb481c169e8dd5ea9d7ee62bd22df0a511d442f (patch) | |
tree | 07291e447f5cc1917d711333e3b3f2a65a5e8325 /src | |
parent | 4045ef72f5db967033bd14217eed4bfea4ea9453 (diff) | |
download | tor-dbb481c169e8dd5ea9d7ee62bd22df0a511d442f.tar.gz tor-dbb481c169e8dd5ea9d7ee62bd22df0a511d442f.zip |
Serve the latest v3 networkstatus consensus via the control
port. Use "getinfo dir/status-vote/current/consensus" to fetch it.
svn:r16907
Diffstat (limited to 'src')
-rw-r--r-- | src/or/control.c | 20 | ||||
-rw-r--r-- | src/or/directory.c | 2 | ||||
-rw-r--r-- | src/or/dirserv.c | 2 |
3 files changed, 19 insertions, 5 deletions
diff --git a/src/or/control.c b/src/or/control.c index ac31f5d940..93a946405d 100644 --- a/src/or/control.c +++ b/src/or/control.c @@ -1401,7 +1401,7 @@ getinfo_helper_misc(control_connection_t *conn, const char *question, * <b>ei</b> into the resulting string. The thing you get back won't * necessarily have a valid signature. * - * New code should never use this; it's for backward compatibiliy. + * New code should never use this; it's for backward compatibility. * * NOTE: <b>ri_body</b> is as returned by signed_descriptor_get_body: it might * not be NUL-terminated. */ @@ -1572,7 +1572,18 @@ getinfo_helper_dir(control_connection_t *control_conn, SMARTLIST_FOREACH(status_list, char *, s, tor_free(s)); smartlist_free(status_list); } - } else if (!strcmp(question, "network-status")) { + } else if (!strcmp(question, "dir/status-vote/current/consensus")) { /* v3 */ + if (directory_caches_dir_info(get_options())) { + const cached_dir_t *consensus = dirserv_get_consensus(); + if (consensus) + *answer = tor_strdup(consensus->dir); + } + if (!*answer) { /* try loading it from disk */ + char *filename = get_datadir_fname("cached-consensus"); + *answer = read_file_to_str(filename, RFTS_IGNORE_MISSING, NULL); + tor_free(filename); + } + } else if (!strcmp(question, "network-status")) { /* v1 */ routerlist_t *routerlist = router_get_routerlist(); int verbose = control_conn->use_long_names; if (!routerlist || !routerlist->routers || @@ -1920,7 +1931,10 @@ static const getinfo_item_t getinfo_items[] = { ITEM("dir-usage", misc, "Breakdown of bytes transferred over DirPort."), PREFIX("desc-annotations/id/", dir, "Router annotations by hexdigest."), PREFIX("dir/server/", dir,"Router descriptors as retrieved from a DirPort."), - PREFIX("dir/status/", dir,"Networkstatus docs as retrieved from a DirPort."), + PREFIX("dir/status/", dir, + "v2 networkstatus docs as retrieved from a DirPort."), + ITEM("dir/status-vote/current/consensus", dir, + "v3 Networkstatus consensus as retrieved from a DirPort."), PREFIX("exit-policy/default", policies, "The default value appended to the configured exit policy."), PREFIX("ip-to-country/", geoip, "Perform a GEOIP lookup"), diff --git a/src/or/directory.c b/src/or/directory.c index 3c2c05da27..f494fe2839 100644 --- a/src/or/directory.c +++ b/src/or/directory.c @@ -2408,7 +2408,7 @@ directory_handle_command_get(dir_connection_t *conn, const char *headers, url_len -= 2; } - if (!strcmp(url,"/tor/") || !strcmp(url,"/tor/dir")) { /* dir fetch */ + if (!strcmp(url,"/tor/") || !strcmp(url,"/tor/dir")) { /* v1 dir fetch */ cached_dir_t *d = dirserv_get_directory(); if (!d) { diff --git a/src/or/dirserv.c b/src/or/dirserv.c index 9d718baa08..b7080aa785 100644 --- a/src/or/dirserv.c +++ b/src/or/dirserv.c @@ -1300,7 +1300,7 @@ _free_cached_dir(void *_d) cached_dir_decref(d); } -/** If we have no cached directory, or it is older than <b>published</b>, +/** If we have no cached v1 directory, or it is older than <b>published</b>, * then replace it with <b>directory</b>, published at <b>published</b>. * * If <b>published</b> is too old, do nothing. |