From 7247838a258d6dff4e3f4b65d88ac46d5921640c Mon Sep 17 00:00:00 2001 From: Roger Dingledine Date: Mon, 29 Sep 2008 23:13:43 +0000 Subject: v3 authorities write down all the votes they used for the consensus to the datadir, for debugging. svn:r17008 --- src/or/dirvote.c | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/or/dirvote.c b/src/or/dirvote.c index 2076875c46..611ee4e704 100644 --- a/src/or/dirvote.c +++ b/src/or/dirvote.c @@ -1789,7 +1789,7 @@ dirvote_add_vote(const char *vote_body, const char **msg_out, int *status_out) goto err; } - /* Now see whether we already hvote->cert->cache_info.identity_digest, vote->cert->cache_info.identity_digest, @@ -1874,14 +1874,14 @@ dirvote_add_vote(const char *vote_body, const char **msg_out, int *status_out) /** Try to compute a v3 networkstatus consensus from the currently pending * votes. Return 0 on success, -1 on failure. Store the consensus in * pending_consensus: it won't be ready to be published until we have - * everybody else's signatures collected too. (V3 Authoritity only) */ + * everybody else's signatures collected too. (V3 Authority only) */ static int dirvote_compute_consensus(void) { /* Have we got enough votes to try? */ int n_votes, n_voters; - smartlist_t *votes = NULL; - char *consensus_body = NULL, *signatures = NULL; + smartlist_t *votes = NULL, *votestrings = NULL; + char *consensus_body = NULL, *signatures = NULL, *votefile; networkstatus_t *consensus = NULL; authority_cert_t *my_cert; @@ -1902,8 +1902,22 @@ dirvote_compute_consensus(void) } votes = smartlist_create(); + votestrings = smartlist_create(); SMARTLIST_FOREACH(pending_vote_list, pending_vote_t *, v, - smartlist_add(votes, v->vote)); + { + sized_chunk_t *c = tor_malloc(sizeof(sized_chunk_t)); + c->bytes = v->vote_body->dir; + c->len = v->vote_body->dir_len; + smartlist_add(votestrings, c); /* collect strings to write to disk */ + + smartlist_add(votes, v->vote); /* collect votes to compute consensus */ + }); + + votefile = get_datadir_fname("v3-status-votes"); + write_chunks_to_file(votefile, votestrings, 0); + tor_free(votefile); + SMARTLIST_FOREACH(votestrings, sized_chunk_t *, c, tor_free(c)); + smartlist_free(votestrings); { char legacy_dbuf[DIGEST_LEN]; -- cgit v1.2.3-54-g00ecf