diff options
author | George Kadianakis <desnacked@riseup.net> | 2018-08-17 15:10:20 +0300 |
---|---|---|
committer | George Kadianakis <desnacked@riseup.net> | 2018-08-22 18:09:47 +0300 |
commit | 5febea0d54ea986ab66dc62905a686cc23abbcb6 (patch) | |
tree | d8ab754ed033a0dbf3ed8c286215f90118653ac8 /src/test/test_dir_handle_get.c | |
parent | 075fcb599c095d18ba554084b910619a6971cc44 (diff) | |
download | tor-5febea0d54ea986ab66dc62905a686cc23abbcb6.tar.gz tor-5febea0d54ea986ab66dc62905a686cc23abbcb6.zip |
Fix revision counter bugs caused by bad SRV start time computation.
Bug description: For each descriptor, its revision counter is the OPE
ciphertext of the number of seconds since the start time of its SRV value.
This bug caused us to confuse the SRV start time in the middle of the lifetime
of a descriptor in some edge-cases, which caused descriptor rejects.
Bug cause: The bug occurs when we fetch a 23:00 consensus after
midnight (e.g. at 00:08 when not all dirauths have fetched the latest 00:00
consensus). In that case, the voting schedule (which was used for SRV start
time calculation) would return a valid-after past-midnight, whereas our
consensus would be pre-midnight, and that would confuse the SRV start time
computation which is used by HS revision counters (because we would reset the
start time of SRV, without rotating descriptors).
Bug fix: We now use our local consensus time to calculate the SRV start time,
instead of the voting schedule. The voting schedule does not work as originally
envisioned in this case, because it was created for voting by dirauths and not
for scheduling stuff on clients.
Diffstat (limited to 'src/test/test_dir_handle_get.c')
0 files changed, 0 insertions, 0 deletions