summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2010-12-07 11:35:49 -0500
committerNick Mathewson <nickm@torproject.org>2010-12-07 11:35:49 -0500
commitf924fbf19f1244eed568bc799f77d8fb288c801d (patch)
tree2b51f2a02033d67d26a755b9346063d1c1193603 /src
parentdc2f10bd81cfcfdd65bad38a34c042259b1c1ece (diff)
parent5efe6f04c68debe6ef9307d0ed98f67ed5ca5f46 (diff)
downloadtor-f924fbf19f1244eed568bc799f77d8fb288c801d.tar.gz
tor-f924fbf19f1244eed568bc799f77d8fb288c801d.zip
Merge branch 'bug2081_followup_022' into maint-0.2.2
Diffstat (limited to 'src')
-rw-r--r--src/or/dirserv.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/or/dirserv.c b/src/or/dirserv.c
index 10b9000d51..841c86624b 100644
--- a/src/or/dirserv.c
+++ b/src/or/dirserv.c
@@ -386,13 +386,19 @@ dirserv_get_status_impl(const char *id_digest, const char *nickname,
strmap_size(fingerprint_list->fp_by_name),
digestmap_size(fingerprint_list->status_by_digest));
- /* Tor 0.1.2.x is pretty old, but there are a lot of them running still,
- * and there aren't any critical relay-side vulnerabilities. Once more
- * of them die off, we should raise this minimum to 0.2.0.x. */
- if (platform && !tor_version_as_new_as(platform,"0.1.2.14")) {
+ /* Tor 0.2.0.26-rc is the oldest version that currently caches the right
+ * directory information. Once more of them die off, we should raise this
+ * minimum. */
+ if (platform && !tor_version_as_new_as(platform,"0.2.0.26-rc")) {
if (msg)
*msg = "Tor version is far too old to work.";
return FP_REJECT;
+ } else if (platform && tor_version_as_new_as(platform,"0.2.1.3-alpha")
+ && !tor_version_as_new_as(platform, "0.2.1.19")) {
+ /* These versions mishandled RELAY_EARLY cells on rend circuits. */
+ if (msg)
+ *msg = "Tor version is too buggy to work.";
+ return FP_REJECT;
}
result = dirserv_get_name_status(id_digest, nickname);