[tor-commits] [stem/master] Simplifying DescriptorDownloader class
atagar at torproject.org
atagar at torproject.org
Mon Jul 22 03:10:17 UTC 2013
commit 6f12acc9e54842371f52203550a6ef2f9cbfb835
Author: Damian Johnson <atagar at torproject.org>
Date: Sun Jul 21 16:25:58 2013 -0700
Simplifying DescriptorDownloader class
The DescriptorDownloader is a very, very simple class that simply issues
Queries on your behalf. Why should it pretend to be anything else?
Dropping most of its attributes (and with it a lot of copy-and-pasted pydocs).
Also making the query() method public.
---
stem/descriptor/remote.py | 62 ++++++++++++++++++---------------------------
1 file changed, 25 insertions(+), 37 deletions(-)
diff --git a/stem/descriptor/remote.py b/stem/descriptor/remote.py
index 777f769..01130f3 100644
--- a/stem/descriptor/remote.py
+++ b/stem/descriptor/remote.py
@@ -51,7 +51,8 @@ itself...
|- get_server_descriptors - provides present :class:`~stem.descriptor.stem.descriptor.server_descriptor.ServerDescriptor`
|- get_extrainfo_descriptors - provides present :class:`~stem.descriptor.extrainfo_descriptor.ExtraInfoDescriptor`
|- get_microdescriptors - provides present :class:`~stem.descriptor.microdescriptor.Microdescriptor`
- +- get_consensus - provides present :class:`~stem.descriptor.router_status_entry.RouterStatusEntryV3`
+ |- get_consensus - provides present :class:`~stem.descriptor.router_status_entry.RouterStatusEntryV3`
+ +- query - request an arbitrary descriptor resource
.. data:: MAX_DESCRIPTOR_BATCH_SIZE
@@ -365,35 +366,18 @@ class Query(object):
class DescriptorDownloader(object):
"""
- Configurable class through which descriptors can be downloaded. This provides
- caching, retries, and other capabilities to make downloading descriptors easy
- and efficient.
-
- For more advanced use cases you can use the
- :class:`~stem.descriptor.remote.Query` class directly.
+ Configurable class that issues :class:`~stem.descriptor.remote.Query`
+ instances on your behalf.
:param bool use_mirrors: downloads the present consensus and uses the directory
mirrors to fetch future requests, this fails silently if the consensus
cannot be downloaded
-
- :var int retries: number of times to attempt the request if it fails
- :var bool fall_back_to_authority: when retrying request issues the last
- request to a directory authority if **True**
- :var float timeout: duration before we'll time out our request, no timeout is
- applied if **None**
- :var bool start_when_requested: issues requests when our methods are called
- if **True**, otherwise provides non-running
- :class:`~stem.descriptor.remote.Query` instances
- :var bool validate: checks the validity of the descriptor's content if
- **True**, skips these checks otherwise
+ :param default_args: default arguments for the
+ :class:`~stem.descriptor.remote.Query` constructor
"""
- def __init__(self, use_mirrors = False, retries = 2, fall_back_to_authority = True, timeout = None, start_when_requested = True, validate = True):
- self.retries = retries
- self.fall_back_to_authority = fall_back_to_authority
- self.timeout = timeout
- self.start_when_requested = start_when_requested
- self.validate = validate
+ def __init__(self, use_mirrors = False, **default_args):
+ self._default_args = default_args
self._endpoints = DIRECTORY_AUTHORITIES.values()
if use_mirrors:
@@ -448,7 +432,7 @@ class DescriptorDownloader(object):
resource = '/tor/server/fp/%s.z' % '+'.join(fingerprints)
- return self._query(resource)
+ return self.query(resource)
def get_extrainfo_descriptors(self, fingerprints = None):
"""
@@ -476,7 +460,7 @@ class DescriptorDownloader(object):
resource = '/tor/extra/fp/%s.z' % '+'.join(fingerprints)
- return self._query(resource)
+ return self.query(resource)
def get_microdescriptors(self, hashes):
"""
@@ -501,7 +485,7 @@ class DescriptorDownloader(object):
if len(hashes) > MAX_MICRODESCRIPTOR_BATCH_SIZE:
raise ValueError("Unable to request more than %i microdescriptors at a time by their hashes" % MAX_MICRODESCRIPTOR_BATCH_SIZE)
- return self._query('/tor/micro/d/%s.z' % '-'.join(hashes))
+ return self.query('/tor/micro/d/%s.z' % '-'.join(hashes))
def get_consensus(self, document_handler = stem.descriptor.DocumentHandler.ENTRIES, authority_v3ident = None):
"""
@@ -523,23 +507,27 @@ class DescriptorDownloader(object):
if authority_v3ident:
resource += '/%s' % authority_v3ident
- return self._query(resource + '.z', document_handler = document_handler)
+ return self.query(resource + '.z', document_handler = document_handler)
- def _query(self, resource, descriptor_type = None, document_handler = stem.descriptor.DocumentHandler.ENTRIES):
+ def query(self, resource, **kwargs):
"""
Issues a request for the given resource.
+
+ :param str resource: resource being fetched, such as '/tor/server/all.z'
+ :param kwargs: additional arguments for the
+ :class:`~stem.descriptor.remote.Query` constructor
+
+ :returns: :class:`~stem.descriptor.remote.Query` for the descriptors
+
+ :raises: **ValueError** if resource is clearly invalid or the descriptor
+ type can't be determined when 'descriptor_type' is **None**
"""
- log.trace("Retrieving descriptors (resource: %s, type: %s)" % (resource, descriptor_type))
+ query_args = dict(self._default_args)
+ query_args.update(kwargs)
return Query(
resource,
- descriptor_type,
endpoints = self._endpoints,
- retries = self.retries,
- fall_back_to_authority = self.fall_back_to_authority,
- timeout = self.timeout,
- start = self.start_when_requested,
- validate = self.validate,
- document_handler = document_handler,
+ **query_args
)
More information about the tor-commits
mailing list