diff options
author | Aldo Cortesi <aldo@nullcube.com> | 2011-08-02 20:34:01 +1200 |
---|---|---|
committer | Aldo Cortesi <aldo@nullcube.com> | 2011-08-02 20:42:46 +1200 |
commit | 8cc0469ee72592d079750a9d5427853d95a7dbfe (patch) | |
tree | abbca7456a5321f26a0f5f45b820443a6bb292b0 | |
parent | bb6ec29b186fdd482bae98e3fc33b71be5bf103e (diff) | |
download | mitmproxy-8cc0469ee72592d079750a9d5427853d95a7dbfe.tar.gz mitmproxy-8cc0469ee72592d079750a9d5427853d95a7dbfe.tar.bz2 mitmproxy-8cc0469ee72592d079750a9d5427853d95a7dbfe.zip |
Tweak encoding behaviour
- Don't fail to identity encoding when an unknown encoding is specified.
- Don't constrain encodings. I want to try to modify traffic as little as
possible by default.
- When decoding, delete content-encoding header rather than set it to "identity"
- Refuse to decode/encode when there is an existing but unknown
content-encoding header.
-rw-r--r-- | libmproxy/encoding.py | 12 | ||||
-rw-r--r-- | libmproxy/flow.py | 2 | ||||
-rw-r--r-- | libmproxy/proxy.py | 7 |
3 files changed, 13 insertions, 8 deletions
diff --git a/libmproxy/encoding.py b/libmproxy/encoding.py index aab4141b..6886fb0b 100644 --- a/libmproxy/encoding.py +++ b/libmproxy/encoding.py @@ -8,21 +8,25 @@ __ALL__ = ["ENCODINGS"] ENCODINGS = set(["identity", "gzip", "deflate"]) -def decode(encoding, content): +def decode(e, content): encoding_map = { "identity": identity, "gzip": decode_gzip, "deflate": decode_deflate, } - return encoding_map.get(encoding, identity)(content) + if e not in encoding_map: + return None + return encoding_map[e](content) -def encode(encoding, content): +def encode(e, content): encoding_map = { "identity": identity, "gzip": encode_gzip, "deflate": encode_deflate, } - return encoding_map.get(encoding, identity)(content) + if e not in encoding_map: + return None + return encoding_map[e](content) def identity(content): """ diff --git a/libmproxy/flow.py b/libmproxy/flow.py index 090c539a..57bcc878 100644 --- a/libmproxy/flow.py +++ b/libmproxy/flow.py @@ -588,8 +588,6 @@ class FlowMaster(controller.Master): f.request.anticache() if self.anticomp: f.request.anticomp() - else: - f.request.constrain_encoding() if self.server_playback: pb = self.do_server_playback(f) diff --git a/libmproxy/proxy.py b/libmproxy/proxy.py index 0c142959..75c5bf8a 100644 --- a/libmproxy/proxy.py +++ b/libmproxy/proxy.py @@ -134,11 +134,14 @@ class HTTPMsg(controller.Msg): Content-Encoding header and changing Content-Encoding header to 'identity'. """ + ce = self.headers["content-encoding"] + if not ce or ce[0] not in encoding.ENCODINGS: + return self.content = encoding.decode( - (self.headers["content-encoding"] or ["identity"])[0], + ce[0], self.content ) - self.headers["content-encoding"] = ["identity"] + del self.headers["content-encoding"] def encode(self, e): """ |