diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-05-12 21:12:21 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-05-12 21:12:21 +0000 |
commit | e1ef199cf6d63b17e5487f3e38f9b102c875ab29 (patch) | |
tree | 3ee9c436757c664df8a70bf2e8279c4cb6762be5 /src | |
parent | 42dc560b1aee0fa2e8e1b12f1fd6ebc845930689 (diff) | |
download | tor-e1ef199cf6d63b17e5487f3e38f9b102c875ab29.tar.gz tor-e1ef199cf6d63b17e5487f3e38f9b102c875ab29.zip |
r19714@catbus: nickm | 2008-05-12 17:11:47 -0400
Fwdport Bugfix: an authority signature is "unrecognized" if we lack a dirserver entry for it, even if we have an older cached certificate that says it is recognized. This affects clients who remove entries from their dirserver list without clearing their certificate cache.
svn:r14597
Diffstat (limited to 'src')
-rw-r--r-- | src/or/networkstatus.c | 17 |
1 files changed, 9 insertions, 8 deletions
diff --git a/src/or/networkstatus.c b/src/or/networkstatus.c index f56ffff19e..7537fa27d3 100644 --- a/src/or/networkstatus.c +++ b/src/or/networkstatus.c @@ -392,17 +392,18 @@ networkstatus_check_consensus_signature(networkstatus_t *consensus, { if (!voter->good_signature && !voter->bad_signature && voter->signature) { /* we can try to check the signature. */ + int is_v3_auth = trusteddirserver_get_by_v3_auth_digest( + voter->identity_digest) != NULL; authority_cert_t *cert = authority_cert_get_by_digests(voter->identity_digest, voter->signing_key_digest); - if (! cert) { - if (!trusteddirserver_get_by_v3_auth_digest(voter->identity_digest)) { - smartlist_add(unrecognized, voter); - ++n_unknown; - } else { - smartlist_add(need_certs_from, voter); - ++n_missing_key; - } + if (!is_v3_auth) { + smartlist_add(unrecognized, voter); + ++n_unknown; + continue; + } else if (!cert) { + smartlist_add(need_certs_from, voter); + ++n_missing_key; continue; } if (networkstatus_check_voter_signature(consensus, voter, cert) < 0) { |