summaryrefslogtreecommitdiff
path: root/src/or/dircollate.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2016-02-23 09:31:23 -0500
committerNick Mathewson <nickm@torproject.org>2016-03-21 13:24:09 -0400
commitfa07c60c67d69ff25c4e64172e3a38b29a2e6143 (patch)
treecd848412ad4864f116b9b9629b9ab89503a4df2c /src/or/dircollate.c
parent60ca3f358f80930778b12c9fcc8e3cf562b64e8e (diff)
downloadtor-fa07c60c67d69ff25c4e64172e3a38b29a2e6143.tar.gz
tor-fa07c60c67d69ff25c4e64172e3a38b29a2e6143.zip
Fix another case of 17668: Add NoEdConsensus
I had a half-built mechanism to track, during the voting process, whether the Ed25519 value (or lack thereof) reflected a true consensus among the authorities. But we never actually inserted this field in the consensus. The key idea here is that we first attempt to match up votes by pairs of <Ed,RSA>, where <Ed> can be NULL if we're told that there is no Ed key. If this succeeds, then we can treat all those votes as 'a consensus for Ed'. And we can include all other votes with a matching RSA key and no statement about Ed keys as being "also about the same relay." After that, we look for RSA keys we haven't actually found an entry for yet, and see if there are enough votes for them, NOT considering Ed keys. If there are, we match them as before, but we treat them as "not a consensus about ed". When we include an entry in a consensus, if it does not reflect a consensus about ed keys, then we include a new NoEdConsensus flag on it. This is all only for consensus method 22 or later. Also see corresponding dir-spec patch.
Diffstat (limited to 'src/or/dircollate.c')
-rw-r--r--src/or/dircollate.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/or/dircollate.c b/src/or/dircollate.c
index eeb0c24008..ca8b7ca847 100644
--- a/src/or/dircollate.c
+++ b/src/or/dircollate.c
@@ -81,6 +81,8 @@ dircollator_add_routerstatus(dircollator_t *dc,
{
const char *id = vrs->status.identity_digest;
+ vrs->ed25519_reflects_consensus = 0;
+
(void) vote;
vote_routerstatus_t **vrs_lst = digestmap_get(dc->by_rsa_sha1, id);
if (NULL == vrs_lst) {
@@ -92,7 +94,7 @@ dircollator_add_routerstatus(dircollator_t *dc,
const uint8_t *ed = vrs->ed25519_id;
- if (tor_mem_is_zero((char*)ed, DIGEST256_LEN))
+ if (! vrs->has_ed25519_listing)
return;
ddmap_entry_t search, *found;