@ -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 )
r esp . 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 = { }