2016-06-14 01:17:09 +00:00
|
|
|
"""
|
2016-01-02 15:00:27 +00:00
|
|
|
tcp_message Inline Script Hook API Demonstration
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
|
|
* modifies packets containing "foo" to "bar"
|
|
|
|
* prints various details for each packet.
|
|
|
|
|
|
|
|
example cmdline invocation:
|
|
|
|
mitmdump -T --host --tcp ".*" -q -s examples/tcp_message.py
|
2016-06-14 01:17:09 +00:00
|
|
|
"""
|
2016-06-02 00:31:41 +00:00
|
|
|
from netlib import strutils
|
2016-01-02 15:00:27 +00:00
|
|
|
|
2016-05-29 08:23:39 +00:00
|
|
|
|
2016-01-02 15:00:27 +00:00
|
|
|
def tcp_message(ctx, 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
|
|
|
|
|
2016-07-05 22:11:32 +00:00
|
|
|
print(
|
|
|
|
"[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))
|
|
|
|
)
|