Merge branch 'fix-stray-that-breaks-on-linux'

pull/206/head
Yahya SayadArbabi 6 years ago
commit c75ce71dcc

@ -30,7 +30,7 @@ def check_proxy(proxy_ip, proxy_port, protocol):
We use 'wikipedia.org' as a test, since we can test the proxy anonymity We use 'wikipedia.org' as a test, since we can test the proxy anonymity
by check if the returning 'X-Client-IP' header matches the proxy ip. by check if the returning 'X-Client-IP' header matches the proxy ip.
""" """
full_proxy = f'{protocol}://{proxy_ip}:{proxy_port}' full_proxy = '{protocol}://{proxy_ip}:{proxy_port}'
proxies = {'http': full_proxy, 'https': full_proxy} proxies = {'http': full_proxy, 'https': full_proxy}
try: try:
r = requests.get('https://www.wikipedia.org',proxies=proxies, timeout=4) r = requests.get('https://www.wikipedia.org',proxies=proxies, timeout=4)

@ -75,16 +75,16 @@ class ElapsedFuturesSession(FuturesSession):
def print_info(title, info): def print_info(title, info):
print(Style.BRIGHT + Fore.GREEN + "[" + print(Style.BRIGHT + Fore.GREEN + "[" +
Fore.YELLOW + "*" + Fore.YELLOW + "*" +
Fore.GREEN + f"] {title}" + Fore.GREEN + " {title}" +
Fore.WHITE + f" {info}" + Fore.WHITE + " {info}" +
Fore.GREEN + " on:") Fore.GREEN + " on:")
def print_error(err, errstr, var, verbose=False): def print_error(err, errstr, var, verbose=False):
print(Style.BRIGHT + Fore.WHITE + "[" + print(Style.BRIGHT + Fore.WHITE + "[" +
Fore.RED + "-" + Fore.RED + "-" +
Fore.WHITE + "]" + Fore.WHITE + "]" +
Fore.RED + f" {errstr}" + Fore.RED + " {errstr}" +
Fore.YELLOW + f" {err if verbose else var}") Fore.YELLOW + " {err if verbose else var}")
def format_response_time(response_time, verbose): def format_response_time(response_time, verbose):
@ -112,7 +112,7 @@ def print_invalid(social_network, msg):
Fore.RED + "-" + Fore.RED + "-" +
Fore.WHITE + "]" + Fore.WHITE + "]" +
Fore.GREEN + " {}:" + Fore.GREEN + " {}:" +
Fore.YELLOW + f" {msg}").format(social_network)) Fore.YELLOW + " {msg}").format(social_network))
def get_response(request_future, error_type, social_network, verbose=False, retry_no=None): def get_response(request_future, error_type, social_network, verbose=False, retry_no=None):
@ -131,8 +131,8 @@ def get_response(request_future, error_type, social_network, verbose=False, retr
if retry_no>0 and len(proxy_list)>0: if retry_no>0 and len(proxy_list)>0:
#Selecting the new proxy. #Selecting the new proxy.
new_proxy = random.choice(proxy_list) new_proxy = random.choice(proxy_list)
new_proxy = f'{new_proxy.protocol}://{new_proxy.ip}:{new_proxy.port}' new_proxy = '{new_proxy.protocol}://{new_proxy.ip}:{new_proxy.port}'
print(f'Retrying with {new_proxy}') print('Retrying with {new_proxy}')
request_future.proxy = {'http':new_proxy,'https':new_proxy} request_future.proxy = {'http':new_proxy,'https':new_proxy}
get_response(request_future,error_type, social_network, verbose,retry_no=retry_no-1) get_response(request_future,error_type, social_network, verbose,retry_no=retry_no-1)
else: else:
@ -365,12 +365,12 @@ def main():
# Colorama module's initialization. # Colorama module's initialization.
init(autoreset=True) init(autoreset=True)
version_string = f"%(prog)s {__version__}\n" + \ version_string = "%(prog)s {__version__}\n" + \
f"{requests.__description__}: {requests.__version__}\n" + \ "{requests.__description__}: {requests.__version__}\n" + \
f"Python: {platform.python_version()}" "Python: {platform.python_version()}"
parser = ArgumentParser(formatter_class=RawDescriptionHelpFormatter, parser = ArgumentParser(formatter_class=RawDescriptionHelpFormatter,
description=f"{module_name} (Version {__version__})" description="{module_name} (Version {__version__})"
) )
parser.add_argument("--version", parser.add_argument("--version",
action="version", version=version_string, action="version", version=version_string,
@ -391,10 +391,10 @@ def main():
) )
parser.add_argument("--tor", "-t", parser.add_argument("--tor", "-t",
action="store_true", dest="tor", default=False, action="store_true", dest="tor", default=False,
help="Make requests over TOR; increases runtime; requires TOR to be installed and in system path.") help="Make requests over Tor; increases runtime; requires Tor to be installed and in system path.")
parser.add_argument("--unique-tor", "-u", parser.add_argument("--unique-tor", "-u",
action="store_true", dest="unique_tor", default=False, action="store_true", dest="unique_tor", default=False,
help="Make requests over TOR with new TOR circuit after each request; increases runtime; requires TOR to be installed and in system path.") help="Make requests over Tor with new Tor circuit after each request; increases runtime; requires Tor to be installed and in system path.")
parser.add_argument("--csv", parser.add_argument("--csv",
action="store_true", dest="csv", default=False, action="store_true", dest="csv", default=False,
help="Create Comma-Separated Values (CSV) File." help="Create Comma-Separated Values (CSV) File."
@ -438,7 +438,7 @@ def main():
# Argument check # Argument check
# TODO regex check on args.proxy # TODO regex check on args.proxy
if args.tor and (args.proxy != None or args.proxy_list != None): if args.tor and (args.proxy != None or args.proxy_list != None):
raise Exception("TOR and Proxy cannot be set in the meantime.") raise Exception("Tor and Proxy cannot be set in the meantime.")
# Proxy argument check. # Proxy argument check.
# Does not necessarily need to throw an error, # Does not necessarily need to throw an error,
@ -472,8 +472,8 @@ def main():
raise Exception("Prameter --check_proxies/-cp must be a positive intiger.") raise Exception("Prameter --check_proxies/-cp must be a positive intiger.")
if args.tor or args.unique_tor: if args.tor or args.unique_tor:
print("Using TOR to make requests") print("Using Tor to make requests")
print("Warning: some websites might refuse connecting over TOR, so note that using this option might increase connection errors.") print("Warning: some websites might refuse connecting over Tor, so note that using this option might increase connection errors.")
# Check if both output methods are entered as input. # Check if both output methods are entered as input.
if args.output is not None and args.folderoutput is not None: if args.output is not None and args.folderoutput is not None:
@ -536,11 +536,11 @@ def main():
site_data[existing_site] = site_data_all[existing_site] site_data[existing_site] = site_data_all[existing_site]
if not site_data: if not site_data:
# Build up list of sites not supported for future error message. # Build up list of sites not supported for future error message.
site_missing.append(f"'{site}'") site_missing.append("'{site}'")
if site_missing: if site_missing:
print( print(
f"Error: Desired sites not found: {', '.join(site_missing)}.") "Error: Desired sites not found: {', '.join(site_missing)}.")
sys.exit(1) sys.exit(1)
if args.rank: if args.rank:
@ -570,7 +570,7 @@ def main():
# If we can't access the list or it is empty, we proceed with args.proxy as the proxy. # If we can't access the list or it is empty, we proceed with args.proxy as the proxy.
try: try:
random_proxy = random.choice(proxy_list) random_proxy = random.choice(proxy_list)
proxy = f'{random_proxy.protocol}://{random_proxy.ip}:{random_proxy.port}' proxy = '{random_proxy.protocol}://{random_proxy.ip}:{random_proxy.port}'
except (NameError, IndexError): except (NameError, IndexError):
proxy = args.proxy proxy = args.proxy

Loading…
Cancel
Save