aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAldo Cortesi <aldo@corte.si>2018-05-12 10:44:26 +1200
committerGitHub <noreply@github.com>2018-05-12 10:44:26 +1200
commitce6029b435f3a0ce6269adf38fde6ef50c45c513 (patch)
tree320c19b787d1bfffcc17d0c142bee316cf14d993
parent30d11a56740766092a22df084914453553b5d9e2 (diff)
parente305a320a22cb88e5431baf5848d2787b31f7508 (diff)
downloadmitmproxy-ce6029b435f3a0ce6269adf38fde6ef50c45c513.tar.gz
mitmproxy-ce6029b435f3a0ce6269adf38fde6ef50c45c513.tar.bz2
mitmproxy-ce6029b435f3a0ce6269adf38fde6ef50c45c513.zip
Merge pull request #3114 from Kriechi/fix-tcp-example
fix tcp example
-rw-r--r--examples/complex/tcp_message.py23
1 files changed, 11 insertions, 12 deletions
diff --git a/examples/complex/tcp_message.py b/examples/complex/tcp_message.py
index 634e2a9f..b1311d08 100644
--- a/examples/complex/tcp_message.py
+++ b/examples/complex/tcp_message.py
@@ -6,23 +6,22 @@ tcp_message Inline Script Hook API Demonstration
* prints various details for each packet.
example cmdline invocation:
-mitmdump -T --host --tcp ".*" -q -s examples/tcp_message.py
+mitmdump --rawtcp --tcp-host ".*" -s examples/complex/tcp_message.py
"""
from mitmproxy.utils import strutils
from mitmproxy import ctx
+from mitmproxy import tcp
-def tcp_message(tcp_msg):
- modified_msg = tcp_msg.message.replace("foo", "bar")
-
- is_modified = False if modified_msg == tcp_msg.message else True
- tcp_msg.message = modified_msg
+def tcp_message(flow: tcp.TCPFlow):
+ message = flow.messages[-1]
+ old_content = message.content
+ message.content = old_content.replace(b"foo", b"bar")
ctx.log.info(
- "[tcp_message{}] from {} {} to {} {}:\r\n{}".format(
- " (modified)" if is_modified else "",
- "client" if tcp_msg.sender == tcp_msg.client_conn else "server",
- tcp_msg.sender.address,
- "server" if tcp_msg.receiver == tcp_msg.server_conn else "client",
- tcp_msg.receiver.address, strutils.bytes_to_escaped_str(tcp_msg.message))
+ "[tcp_message{}] from {} to {}:\n{}".format(
+ " (modified)" if message.content != old_content else "",
+ "client" if message.from_client else "server",
+ "server" if message.from_client else "client",
+ strutils.bytes_to_escaped_str(message.content))
)