fix code Complexity (#8)
* fix code Complexity * Update wrapper.py * codefactor badge
This commit is contained in:
parent
0ca6710334
commit
444675538f
@ -5,6 +5,7 @@
|
||||
[data:image/s3,"s3://crabby-images/2c8d8/2c8d8e18bb178c35484bc5490fbe20e6eceef46e" alt="Codacy Badge"](https://www.codacy.com/manual/akamhy/waybackpy?utm_source=github.com&utm_medium=referral&utm_content=akamhy/waybackpy&utm_campaign=Badge_Grade)
|
||||
[data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt="License: MIT"](https://github.com/akamhy/waybackpy/blob/master/LICENSE)
|
||||
[data:image/s3,"s3://crabby-images/c9c93/c9c93fd469dc68ae20530f27183d01aea3ba9599" alt="Maintainability"](https://codeclimate.com/github/akamhy/waybackpy/maintainability)
|
||||
[data:image/s3,"s3://crabby-images/585db/585db5b9cc9033c4739a5ac31f8af0ab11c509f5" alt="CodeFactor"](https://www.codefactor.io/repository/github/akamhy/waybackpy)
|
||||
[data:image/s3,"s3://crabby-images/53b98/53b981d4ad2e22fc4a1a55aaa7dd262dfcb61285" alt="made-with-python"](https://www.python.org/)
|
||||
data:image/s3,"s3://crabby-images/af22f/af22f8893e3e8f4e5e6072da7f7899f21abd4b44" alt="pypi"
|
||||
data:image/s3,"s3://crabby-images/cb2b2/cb2b2e0c7ddbff28914a5fb0896065dc5347519d" alt="PyPI - Python Version"
|
||||
|
@ -31,25 +31,29 @@ def wayback_timestamp(**kwargs):
|
||||
str(kwargs["minute"]).zfill(2)
|
||||
)
|
||||
|
||||
def handle_HTTPError(e):
|
||||
if e.code == 502:
|
||||
raise BadGateWay(e)
|
||||
elif e.code == 503:
|
||||
raise WaybackUnavailable(e)
|
||||
elif e.code == 429:
|
||||
raise TooManyArchivingRequests(e)
|
||||
elif e.code == 404:
|
||||
raise UrlNotFound(e)
|
||||
|
||||
def save(url, UA=default_UA):
|
||||
base_save_url = "https://web.archive.org/save/"
|
||||
request_url = (base_save_url + clean_url(url))
|
||||
url_check(url)
|
||||
request_url = ("https://web.archive.org/save/" + clean_url(url))
|
||||
|
||||
hdr = { 'User-Agent' : '%s' % UA } #nosec
|
||||
req = Request(request_url, headers=hdr) #nosec
|
||||
url_check(url)
|
||||
|
||||
|
||||
try:
|
||||
response = urlopen(req) #nosec
|
||||
except HTTPError as e:
|
||||
if e.code == 502:
|
||||
raise BadGateWay(e)
|
||||
elif e.code == 503:
|
||||
raise WaybackUnavailable(e)
|
||||
elif e.code == 429:
|
||||
raise TooManyArchivingRequests(e)
|
||||
elif e.code == 404:
|
||||
raise UrlNotFound(e)
|
||||
else:
|
||||
raise PageNotSaved(e)
|
||||
if handle_HTTPError(e) is None:
|
||||
raise PageNotSaved(e)
|
||||
except URLError:
|
||||
try:
|
||||
response = urlopen(req) #nosec
|
||||
@ -57,16 +61,17 @@ def save(url, UA=default_UA):
|
||||
raise UrlNotFound(e)
|
||||
|
||||
header = response.headers
|
||||
|
||||
if "exclusion.robots.policy" in str(header):
|
||||
raise ArchivingNotAllowed("Can not archive %s. Disabled by site owner." % (url))
|
||||
archive_id = header['Content-Location']
|
||||
archived_url = "https://web.archive.org" + archive_id
|
||||
return archived_url
|
||||
|
||||
return "https://web.archive.org" + header['Content-Location']
|
||||
|
||||
def get(url, encoding=None, UA=default_UA):
|
||||
url_check(url)
|
||||
hdr = { 'User-Agent' : '%s' % UA }
|
||||
req = Request(clean_url(url), headers=hdr) #nosec
|
||||
|
||||
try:
|
||||
resp=urlopen(req) #nosec
|
||||
except URLError:
|
||||
@ -74,13 +79,14 @@ def get(url, encoding=None, UA=default_UA):
|
||||
resp=urlopen(req) #nosec
|
||||
except URLError as e:
|
||||
raise UrlNotFound(e)
|
||||
|
||||
if encoding is None:
|
||||
try:
|
||||
encoding= resp.headers['content-type'].split('charset=')[-1]
|
||||
except AttributeError:
|
||||
encoding = "UTF-8"
|
||||
encoding = encoding.replace("text/html","UTF-8",1)
|
||||
return resp.read().decode(encoding)
|
||||
|
||||
return resp.read().decode(encoding.replace("text/html", "UTF-8", 1))
|
||||
|
||||
def near(
|
||||
url,
|
||||
@ -96,15 +102,12 @@ def near(
|
||||
request_url = "https://archive.org/wayback/available?url=%s×tamp=%s" % (clean_url(url), str(timestamp))
|
||||
hdr = { 'User-Agent' : '%s' % UA }
|
||||
req = Request(request_url, headers=hdr) # nosec
|
||||
|
||||
try:
|
||||
response = urlopen(req) #nosec
|
||||
except HTTPError as e:
|
||||
if e.code == 502:
|
||||
raise BadGateWay(e)
|
||||
elif e.code == 503:
|
||||
raise WaybackUnavailable(e)
|
||||
elif e.code == 404:
|
||||
raise UrlNotFound(e)
|
||||
handle_HTTPError(e)
|
||||
|
||||
data = json.loads(response.read().decode("UTF-8"))
|
||||
if not data["archived_snapshots"]:
|
||||
raise ArchiveNotFound("'%s' is not yet archived." % url)
|
||||
|
Loading…
x
Reference in New Issue
Block a user