diff options
| author | 2019-09-09 16:17:26 +0100 | |
|---|---|---|
| committer | 2019-09-09 16:17:26 +0100 | |
| commit | a9b106c6bef1782156976d7091d075de984d89a0 (patch) | |
| tree | bbf4b0f3bbab0a9879e1e4ccea45cdac6b585113 /src/utils/http.py | |
| parent | use detect_encoding=False in github webhook url shortening (diff) | |
| signature | ||
Don't try to .decode non-html things, default iso-lat-1 for non-html too
Diffstat (limited to 'src/utils/http.py')
| -rw-r--r-- | src/utils/http.py | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/src/utils/http.py b/src/utils/http.py index 71cacef6..9459dcc0 100644 --- a/src/utils/http.py +++ b/src/utils/http.py @@ -121,10 +121,10 @@ def request(url: str, method: str="GET", get_params: dict={}, response_headers = utils.CaseInsensitiveDict(dict(response.headers)) content_type = response.headers.get("Content-Type", "").split(";", 1)[0] - encoding = response.encoding + encoding = response.encoding or "iso-8859-1" if detect_encoding and content_type and content_type in SOUP_CONTENT_TYPES: souped = bs4.BeautifulSoup(response_content, parser) - encoding = _find_encoding(souped) or encoding or "iso-8859-1" + encoding = _find_encoding(souped) or encoding def _decode_data(): return response_content.decode(encoding) @@ -137,15 +137,15 @@ def request(url: str, method: str="GET", get_params: dict={}, raise HTTPWrongContentTypeException( "Tried to soup non-html/non-xml data (%s)" % content_type) - data = _decode_data() - if json and data: + if json and response_content: + data = _decode_data() try: return Response(response.status_code, _json.loads(data), response_headers) except _json.decoder.JSONDecodeError as e: raise HTTPParsingException(str(e), data) - return Response(response.status_code, data, response_headers) + return Response(response.status_code, response_content, response_headers) def request_many(urls: typing.List[str]) -> typing.Dict[str, Response]: responses = {} |
