summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2006-03-15 05:06:56 +0000
committerNick Mathewson <nickm@torproject.org>2006-03-15 05:06:56 +0000
commitfb7b5545ce8a964e526b6f07806c53c76b5e0191 (patch)
tree3b8ee169c7c7ab96d5136067bb46c26824336b11
parentd0f24b1e46eff11a6f8f4a9373410d05ad6418dd (diff)
downloadtor-fb7b5545ce8a964e526b6f07806c53c76b5e0191.tar.gz
tor-fb7b5545ce8a964e526b6f07806c53c76b5e0191.zip
Implement GETINFO(dir/server/foo); status will be harder.
svn:r6165
-rw-r--r--doc/control-spec.txt3
-rw-r--r--src/or/control.c21
-rw-r--r--src/or/dirserv.c3
3 files changed, 26 insertions, 1 deletions
diff --git a/doc/control-spec.txt b/doc/control-spec.txt
index 06e321e06a..7fb929575e 100644
--- a/doc/control-spec.txt
+++ b/doc/control-spec.txt
@@ -412,7 +412,8 @@ $Id$
contents, provided according to the specification for the URLs listed
in Section 4.4 of dir-spec.txt. Note that Tor MUST NOT provide
private information, such as descriptors for routers not marked as
- general-purpose.
+ general-purpose. When asked for 'authority' information for which this
+ Tor is not authoritative, Tor replies with an empty string.
Examples:
C: GETINFO version desc/name/moria1
diff --git a/src/or/control.c b/src/or/control.c
index 8f11e9c304..43970fc0e7 100644
--- a/src/or/control.c
+++ b/src/or/control.c
@@ -1455,6 +1455,27 @@ handle_getinfo_helper(const char *question, char **answer)
smartlist_free(mappings);
} else if (!strcmp(question, "dir-usage")) {
*answer = directory_dump_request_log();
+ } else if (!strcmpstart(question, "dir/server/")) {
+ size_t answer_len = 0, url_len = strlen(question)+2;
+ char *url = tor_malloc(url_len);
+ int res;
+ smartlist_t *descs = smartlist_create();
+ const char *msg;
+ char *cp;
+ tor_snprintf(url, url_len, "/tor/%s", question+4);
+ res = dirserv_get_routerdescs(descs, url, &msg);
+ SMARTLIST_FOREACH(descs, signed_descriptor_t *, sd,
+ answer_len += sd->signed_descriptor_len);
+ cp = *answer = tor_malloc(answer_len+1);
+ SMARTLIST_FOREACH(descs, signed_descriptor_t *, sd,
+ {
+ memcpy(cp, signed_descriptor_get_body(sd),
+ sd->signed_descriptor_len);
+ cp += sd->signed_descriptor_len;
+ });
+ *cp = '\0';
+ tor_free(url);
+ smartlist_free(descs);
}
return 0;
}
diff --git a/src/or/dirserv.c b/src/or/dirserv.c
index 90bf2cde09..a78bfca7d7 100644
--- a/src/or/dirserv.c
+++ b/src/or/dirserv.c
@@ -1555,6 +1555,9 @@ dirserv_get_networkstatus_v2(smartlist_t *result,
* recognize the key (URL).
* If -1 is returned *<b>msg</b> will be set to an appropriate error
* message.
+ *
+ * (Despite its name, this function is also called from the controller, which
+ * exposes a similar means to fetch descriptors.)
*/
int
dirserv_get_routerdescs(smartlist_t *descs_out, const char *key,