aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorteor <teor2345@gmail.com>2016-12-06 22:25:12 +1100
committerteor <teor2345@gmail.com>2016-12-19 15:05:21 +1100
commit8381d928cfd5e0d1db8040e27e1e4d7d210a505a (patch)
treeec2954d6d7fd0f6a36d93c1a21bdf64691a758d8
parent243d6fa0c757b5ca379439f8363d2db053c778e6 (diff)
downloadtor-8381d928cfd5e0d1db8040e27e1e4d7d210a505a.tar.gz
tor-8381d928cfd5e0d1db8040e27e1e4d7d210a505a.zip
Exclude relays that deliver an expired consensus from the fallback list
Part of #20539, based on #20501.
-rwxr-xr-xscripts/maint/updateFallbackDirs.py40
1 files changed, 29 insertions, 11 deletions
diff --git a/scripts/maint/updateFallbackDirs.py b/scripts/maint/updateFallbackDirs.py
index 0dfe0af90b..40b0056987 100755
--- a/scripts/maint/updateFallbackDirs.py
+++ b/scripts/maint/updateFallbackDirs.py
@@ -38,7 +38,8 @@ import dateutil.parser
#from bson import json_util
import copy
-from stem.descriptor.remote import DescriptorDownloader
+from stem.descriptor import DocumentHandler
+from stem.descriptor.remote import get_consensus
import logging
# INFO tells you why each relay was included or excluded
@@ -80,6 +81,9 @@ PERFORM_IPV4_DIRPORT_CHECKS = False if OUTPUT_CANDIDATES else True
# Don't check ~1000 candidates when OUTPUT_CANDIDATES is True
PERFORM_IPV6_DIRPORT_CHECKS = False if OUTPUT_CANDIDATES else False
+# Clients have been using microdesc consensuses by default for a while now
+DOWNLOAD_MICRODESC_CONSENSUS = True
+
# Output fallback name, flags, bandwidth, and ContactInfo in a C comment?
OUTPUT_COMMENTS = True if OUTPUT_CANDIDATES else False
@@ -1120,25 +1124,30 @@ class Candidate(object):
return True
return False
- # report how long it takes to download a consensus from dirip:dirport
+ # log how long it takes to download a consensus from dirip:dirport
+ # returns True if the download failed, False if it succeeded within max_time
@staticmethod
def fallback_consensus_download_speed(dirip, dirport, nickname, max_time):
download_failed = False
- downloader = DescriptorDownloader()
start = datetime.datetime.utcnow()
# some directory mirrors respond to requests in ways that hang python
# sockets, which is why we log this line here
- logging.info('Initiating consensus download from %s (%s:%d).', nickname,
- dirip, dirport)
+ logging.info('Initiating %sconsensus download from %s (%s:%d).',
+ 'microdesc ' if DOWNLOAD_MICRODESC_CONSENSUS else '',
+ nickname, dirip, dirport)
# there appears to be about 1 second of overhead when comparing stem's
# internal trace time and the elapsed time calculated here
TIMEOUT_SLOP = 1.0
try:
- downloader.get_consensus(endpoints = [(dirip, dirport)],
- timeout = (max_time + TIMEOUT_SLOP),
- validate = True,
- retries = 0,
- fall_back_to_authority = False).run()
+ consensus = get_consensus(
+ endpoints = [(dirip, dirport)],
+ timeout = (max_time + TIMEOUT_SLOP),
+ validate = True,
+ retries = 0,
+ fall_back_to_authority = False,
+ document_handler = DocumentHandler.BARE_DOCUMENT,
+ microdescriptor = DOWNLOAD_MICRODESC_CONSENSUS
+ ).run()[0]
except Exception, stem_error:
logging.info('Unable to retrieve a consensus from %s: %s', nickname,
stem_error)
@@ -1146,10 +1155,19 @@ class Candidate(object):
level = logging.WARNING
download_failed = True
elapsed = (datetime.datetime.utcnow() - start).total_seconds()
- if elapsed > max_time:
+ if download_failed:
+ # keep the error failure status
+ pass
+ elif elapsed > max_time:
status = 'too slow'
level = logging.WARNING
download_failed = True
+ elif datetime.datetime.utcnow() > consensus.valid_until:
+ time_since_expiry = (datetime.datetime.utcnow() -
+ consensus.valid_until).total_seconds()
+ status = 'outdated consensus, expired %ds ago'%(int(time_since_expiry))
+ level = logging.WARNING
+ download_failed = True
else:
status = 'ok'
level = logging.DEBUG