| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 | #!/usr/bin/env python# set pathfrom sys import pathfrom os.path import realpath, dirname, joinpath.append(realpath(dirname(realpath(__file__)) + '/../'))#import jsonimport requestsimport refrom urllib.parse import urlparse, urljoinfrom distutils.version import LooseVersion, StrictVersionfrom lxml import htmlfrom searx import searx_dirURL = 'https://ftp.mozilla.org/pub/firefox/releases/'RELEASE_PATH = '/pub/firefox/releases/'NORMAL_REGEX = re.compile('^[0-9]+\.[0-9](\.[0-9])?$')# BETA_REGEX = re.compile('.*[0-9]b([0-9\-a-z]+)$')# ESR_REGEX = re.compile('^[0-9]+\.[0-9](\.[0-9])?esr$')# useragents = {    "versions": (),    "os": ('Windows NT 10.0; WOW64',           'X11; Linux x86_64'),    "ua": "Mozilla/5.0 ({os}; rv:{version}) Gecko/20100101 Firefox/{version}"}def fetch_firefox_versions():    resp = requests.get(URL, timeout=2.0)    if resp.status_code != 200:        raise Exception("Error fetching firefox versions, HTTP code " + resp.status_code)    else:        dom = html.fromstring(resp.text)        versions = []        for link in dom.xpath('//a/@href'):            url = urlparse(urljoin(URL, link))            path = url.path            if path.startswith(RELEASE_PATH):                version = path[len(RELEASE_PATH):-1]                if NORMAL_REGEX.match(version):                    versions.append(LooseVersion(version))        list.sort(versions, reverse=True)        return versionsdef fetch_firefox_last_versions():    versions = fetch_firefox_versions()    result = []    major_last = versions[0].version[0]    major_list = (major_last, major_last - 1)    for version in versions:        major_current = version.version[0]        if major_current in major_list:            result.append(version.vstring)    return resultdef get_useragents_filename():    return join(join(searx_dir, "data"), "useragents.json")useragents["versions"] = fetch_firefox_last_versions()with open(get_useragents_filename(), "w") as f:    json.dump(useragents, f, indent=4, ensure_ascii=False)
 |