|
|
|
"""Sherlock: Supported Site Listing
|
|
|
|
This module generates the listing of supported sites.
|
|
|
|
"""
|
|
|
|
import json
|
|
|
|
import sys
|
|
|
|
import requests
|
|
|
|
import threading
|
|
|
|
import xml.etree.ElementTree as ET
|
|
|
|
from datetime import datetime
|
|
|
|
from argparse import ArgumentParser, RawDescriptionHelpFormatter
|
|
|
|
|
|
|
|
pool = list()
|
|
|
|
|
|
|
|
def get_rank(domain_to_query, dest):
|
|
|
|
|
|
|
|
#Retrieve ranking data via alexa API
|
|
|
|
url = f"http://data.alexa.com/data?cli=10&url={domain_to_query}"
|
|
|
|
xml_data = requests.get(url).text
|
|
|
|
root = ET.fromstring(xml_data)
|
|
|
|
try:
|
|
|
|
#Get ranking for this site.
|
|
|
|
dest['rank'] = int(root.find(".//REACH").attrib["RANK"])
|
|
|
|
except:
|
|
|
|
#We did not find the rank for some reason.
|
|
|
|
print(f"Error retrieving rank information for '{domain_to_query}'")
|
|
|
|
print(f" Returned XML is |{xml_data}|")
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
parser = ArgumentParser(formatter_class=RawDescriptionHelpFormatter
|
|
|
|
)
|
|
|
|
parser.add_argument("--rank","-r",
|
|
|
|
action="store_true", dest="rank", default=False,
|
|
|
|
help="Update all website ranks (not recommended)."
|
|
|
|
)
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
with open("sherlock/resources/data.json", "r", encoding="utf-8") as data_file:
|
|
|
|
data = json.load(data_file)
|
|
|
|
|
|
|
|
with open("sites.md", "w") as site_file:
|
|
|
|
data_length = len(data)
|
|
|
|
site_file.write(f'## List Of Supported Sites ({data_length} Sites In Total!)\n')
|
|
|
|
|
|
|
|
for social_network in data:
|
|
|
|
url_main = data.get(social_network).get("urlMain")
|
|
|
|
data.get(social_network)["rank"] = 0
|
|
|
|
if args.rank:
|
|
|
|
th = threading.Thread(target=get_rank, args=(url_main, data.get(social_network)))
|
|
|
|
else:
|
|
|
|
th = None
|
|
|
|
pool.append((social_network, url_main, th))
|
|
|
|
if args.rank:
|
|
|
|
th.start()
|
|
|
|
|
|
|
|
index = 1
|
|
|
|
for social_network, url_main, th in pool:
|
|
|
|
if args.rank:
|
|
|
|
th.join()
|
|
|
|
site_file.write(f'{index}. [{social_network}]({url_main})\n')
|
|
|
|
sys.stdout.write("\r{0}".format(f"Updated {index} out of {data_length} entries"))
|
|
|
|
sys.stdout.flush()
|
|
|
|
index = index + 1
|
|
|
|
|
|
|
|
if args.rank:
|
|
|
|
site_file.write(f'\nAlexa.com rank data fetched at ({datetime.utcnow()} UTC)\n')
|
|
|
|
|
|
|
|
sorted_json_data = json.dumps(data, indent=2, sort_keys=True)
|
|
|
|
|
|
|
|
with open("data.json", "w") as data_file:
|
|
|
|
data_file.write(sorted_json_data)
|
|
|
|
|
|
|
|
print("\nFinished updating supported site listing!")
|