summaryrefslogtreecommitdiff
path: root/src/or/dirvote.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2012-07-31 10:54:14 -0400
committerNick Mathewson <nickm@torproject.org>2012-07-31 10:54:14 -0400
commit7143d112a69806bde4a29bf8da94704cfb435fe3 (patch)
tree2c29dda86cb9165d3b6cbd8c256e17524a2757fa /src/or/dirvote.c
parent2503cfad240bfd59b033b4380b0ebd4a8a148802 (diff)
downloadtor-7143d112a69806bde4a29bf8da94704cfb435fe3.tar.gz
tor-7143d112a69806bde4a29bf8da94704cfb435fe3.zip
Don't include a router in an md consensus if we can't find a md for it.
The spec requires that every router in a microdesc consensus have an m line; we weren't obeying that spec. This creates a new consensus method (13) to allow voting to continue to work right. Partial fix for bug 6404; fix on 0.2.2.6-alpha.
Diffstat (limited to 'src/or/dirvote.c')
-rw-r--r--src/or/dirvote.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/or/dirvote.c b/src/or/dirvote.c
index 85ea85ce73..87af5becf7 100644
--- a/src/or/dirvote.c
+++ b/src/or/dirvote.c
@@ -54,7 +54,7 @@ static int dirvote_publish_consensus(void);
static char *make_consensus_method_list(int low, int high, const char *sep);
/** The highest consensus method that we currently support. */
-#define MAX_SUPPORTED_CONSENSUS_METHOD 12
+#define MAX_SUPPORTED_CONSENSUS_METHOD 13
/** Lowest consensus method that contains a 'directory-footer' marker */
#define MIN_METHOD_FOR_FOOTER 9
@@ -72,6 +72,10 @@ static char *make_consensus_method_list(int low, int high, const char *sep);
* for a param. */
#define MIN_METHOD_FOR_MAJORITY_PARAMS 12
+/** Lowest consensus method where microdesc consensuses omit any entry
+ * with no microdesc. */
+#define MIN_METHOD_FOR_MANDATORY_MICRODESC 13
+
/* =====
* Voting
* =====*/
@@ -1935,6 +1939,13 @@ networkstatus_compute_consensus(smartlist_t *votes,
}
}
+ if (flavor == FLAV_MICRODESC &&
+ consensus_method >= MIN_METHOD_FOR_MANDATORY_MICRODESC &&
+ tor_digest256_is_zero(microdesc_digest)) {
+ /* With no microdescriptor digest, we omit the entry entirely. */
+ continue;
+ }
+
{
char buf[4096];
/* Okay!! Now we can write the descriptor... */