Add documentation to extension to FuturesSession() which we use to get timing information. Fix problem where timing hook would not be installed properly if the hooks for the request was already filled out with a tuple. I am not sure if that is even possible, but if it does happen, then I just convert the tuple to a list and go on from there.

pull/350/head
Christopher K. Hoadley 5 years ago
parent 578248bf8e
commit d6d6b83b06

@ -34,30 +34,56 @@ global proxy_list
proxy_list = [] proxy_list = []
class ElapsedFuturesSession(FuturesSession): class SherlockFuturesSession(FuturesSession):
"""
Extends FutureSession to add a response time metric to each request.
This is taken (almost) directly from here: https://github.com/ross/requests-futures#working-in-the-background
"""
def request(self, method, url, hooks={}, *args, **kwargs): def request(self, method, url, hooks={}, *args, **kwargs):
"""Request URL.
This extends the FuturesSession request method to calculate a response
time metric to each request.
It is taken (almost) directly from the following StackOverflow answer:
https://github.com/ross/requests-futures#working-in-the-background
Keyword Arguments:
self -- This object.
method -- String containing method desired for request.
url -- String containing URL for request.
hooks -- Dictionary containing hooks to execute after
request finishes.
args -- Arguments.
kwargs -- Keyword arguments.
Return Value:
Request object.
"""
start = time() start = time()
def timing(r, *args, **kwargs): def response_time(resp, *args, **kwargs):
elapsed_sec = time() - start elapsed_sec = time() - start
r.elapsed = round(elapsed_sec * 1000) resp.elapsed = round(elapsed_sec * 1000)
#Install hook to execute when response completes.
#Make sure that the time measurement hook is first, so we will not
#track any later hook's execution time.
try: try:
if isinstance(hooks['response'], (list, tuple)): if isinstance(hooks['response'], list):
# needs to be first so we don't time other hooks execution hooks['response'].insert(0, response_time)
hooks['response'].insert(0, timing) elif isinstance(hooks['response'], tuple):
#Convert tuple to list and insert time measurement hook first.
hooks['response'] = list(hooks['response'])
hooks['response'].insert(0, response_time)
else: else:
hooks['response'] = [timing, hooks['response']] #Must have previously contained a single hook function,
#so convert to list.
hooks['response'] = [response_time, hooks['response']]
except KeyError: except KeyError:
hooks['response'] = timing #No response hook was already defined, so install it ourselves.
hooks['response'] = [response_time]
return super(ElapsedFuturesSession, self).request(method, url, hooks=hooks, *args, **kwargs) return super(SherlockFuturesSession, self).request(method,
url,
hooks=hooks,
*args, **kwargs)
def print_info(title, info): def print_info(title, info):
@ -177,9 +203,10 @@ def sherlock(username, site_data, verbose=False, tor=False, unique_tor=False, pr
underlying_session = requests.session() underlying_session = requests.session()
underlying_request = requests.Request() underlying_request = requests.Request()
# Create multi-threaded session for all requests. Use our custom FuturesSession that exposes response time #Create multi-threaded session for all requests.
session = ElapsedFuturesSession( session = SherlockFuturesSession(executor=executor,
executor=executor, session=underlying_session) session=underlying_session)
# Results from analysis of all sites # Results from analysis of all sites
results_total = {} results_total = {}

Loading…
Cancel
Save