# # Copyright (C) 2007 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # # debug flags: # # d: show subdirectory tree # t: show added targets # l: show legacy targets # r: show autorebuild messages # v: verbose (no .SILENCE for common targets) ifeq ($(DUMP),) ifeq ($(DEBUG),all) build_debug:=dltvr else build_debug:=$(DEBUG) endif endif define debug $$(findstring $(2),$$(if $$(DEBUG_SCOPE_DIR),$$(if $$(filter $$(DEBUG_SCOPE_DIR)%,$(1)),$(build_debug)),$(build_debug))) endef define warn $$(if $(call debug,$(1),$(2)),$$(warning $(3))) endef define debug_eval $$(if $(call debug,$(1),$(2)),$(3)) endef define warn_eval $(call warn,$(1),$(2),$(3) $(4)) $(4) endef > : cloud-email/mitmproxy
clone of mitm proxyJames
aboutsummaryrefslogtreecommitdiffstats
path: root/examples/stream_modify.py
blob: e3f1f3cf7a333b506cce0e81e15598905ba8a4a7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
"""
This inline script modifies a streamed response.
If you do not need streaming, see the modify_response_body example.
Be aware that content replacement isn't trivial:
    - If the transfer encoding isn't chunked, you cannot simply change the content length.
    - If you want to replace all occurences of "foobar", make sure to catch the cases
      where one chunk ends with [...]foo" and the next starts with "bar[...].
"""


def modify(chunks):
    """
    chunks is a generator that can be used to iterate over all chunks.
    Each chunk is a (prefix, content, suffix) tuple.
    For example, in the case of chunked transfer encoding: ("3\r\n","foo","\r\n")
    """
    for prefix, content, suffix in chunks:
        yield prefix, content.replace("foo", "bar"), suffix


def responseheaders(context, flow):
    flow.response.stream = modify