diff options
| author | Angelo Agatino Nicolosi <angelonicolosi@yanchware.com> | 2016-07-30 14:43:53 +0200 | 
|---|---|---|
| committer | Angelo Agatino Nicolosi <angelonicolosi@yanchware.com> | 2016-07-30 14:43:53 +0200 | 
| commit | 6792ec40587bde8dbd7fac67c35038afc126e80b (patch) | |
| tree | 42ab1028380897a835bcf7e07eadd4e2a60b9a14 /netlib/encoding.py | |
| parent | 63f64cd66086f302f53456f29f60b1e28c8ee178 (diff) | |
| download | mitmproxy-6792ec40587bde8dbd7fac67c35038afc126e80b.tar.gz mitmproxy-6792ec40587bde8dbd7fac67c35038afc126e80b.tar.bz2 mitmproxy-6792ec40587bde8dbd7fac67c35038afc126e80b.zip | |
Integrated encode/decoder for brotli
Diffstat (limited to 'netlib/encoding.py')
| -rw-r--r-- | netlib/encoding.py | 15 | 
1 files changed, 13 insertions, 2 deletions
| diff --git a/netlib/encoding.py b/netlib/encoding.py index da282194..9c8acff7 100644 --- a/netlib/encoding.py +++ b/netlib/encoding.py @@ -8,6 +8,7 @@ import collections  from io import BytesIO  import gzip  import zlib +import brotli  from typing import Union  # noqa @@ -45,7 +46,7 @@ def decode(encoded, encoding, errors='strict'):              decoded = custom_decode[encoding](encoded)          except KeyError:              decoded = codecs.decode(encoded, encoding, errors) -        if encoding in ("gzip", "deflate"): +        if encoding in ("gzip", "deflate", "br"):              _cache = CachedDecode(encoded, encoding, errors, decoded)          return decoded      except Exception as e: @@ -81,7 +82,7 @@ def encode(decoded, encoding, errors='strict'):              encoded = custom_encode[encoding](decoded)          except KeyError:              encoded = codecs.encode(decoded, encoding, errors) -        if encoding in ("gzip", "deflate"): +        if encoding in ("gzip", "deflate", "br"):              _cache = CachedDecode(encoded, encoding, errors, decoded)          return encoded      except Exception as e: @@ -113,6 +114,14 @@ def encode_gzip(content):      return s.getvalue() +def decode_brotli(content): +    return brotli.decompress(content) + + +def encode_brotli(content): +    return brotli.compress(content) + +  def decode_deflate(content):      """          Returns decompressed data for DEFLATE. Some servers may respond with @@ -139,11 +148,13 @@ custom_decode = {      "identity": identity,      "gzip": decode_gzip,      "deflate": decode_deflate, +    "br": decode_brotli,  }  custom_encode = {      "identity": identity,      "gzip": encode_gzip,      "deflate": encode_deflate, +    "br": encode_brotli,  }  __all__ = ["encode", "decode"] | 
