From 1789ff5207faa1390783d7119e9a7cc152bde491 Mon Sep 17 00:00:00 2001 From: Mike Kuth Date: Tue, 8 Nov 2022 17:06:23 -0800 Subject: [PATCH 1/2] disable tldextract caching Fetching updated TLD lists is already disabled, so the default TLD list that is included with the library will always be used and there is nothing to cache. Explicitly disabling the cache prevents possible occurences of john-kurkowski/tldextract#254. --- pypac/wpad.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pypac/wpad.py b/pypac/wpad.py index 180f73a..2857406 100644 --- a/pypac/wpad.py +++ b/pypac/wpad.py @@ -9,7 +9,7 @@ logger = logging.getLogger(__name__) # First use of tldextract goes online to update its Public Suffix List cache. Stop it. -no_fetch_extract = tldextract.TLDExtract(suffix_list_urls=None) +no_fetch_extract = tldextract.TLDExtract(cache_dir=None, suffix_list_urls=None) def proxy_urls_from_dns(local_hostname=None): From 1711e9d02e5b602270d15e5444ec6d7fe7b92808 Mon Sep 17 00:00:00 2001 From: Carson Lam <46059+carsonyl@users.noreply.github.com> Date: Tue, 8 Nov 2022 21:02:16 -0800 Subject: [PATCH 2/2] Maintain Python 2.7 support. --- pypac/wpad.py | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/pypac/wpad.py b/pypac/wpad.py index 2857406..c0142e1 100644 --- a/pypac/wpad.py +++ b/pypac/wpad.py @@ -9,7 +9,12 @@ logger = logging.getLogger(__name__) # First use of tldextract goes online to update its Public Suffix List cache. Stop it. -no_fetch_extract = tldextract.TLDExtract(cache_dir=None, suffix_list_urls=None) +try: + no_fetch_extract = tldextract.TLDExtract(cache_dir=None, suffix_list_urls=None) +except TypeError: + # tldextract added cache_dir in v3.0.0, which also dropped PY27 support. + # Maintain PY27 support / allow old tldextract by retrying here. + no_fetch_extract = tldextract.TLDExtract(suffix_list_urls=None) def proxy_urls_from_dns(local_hostname=None):