diff options
author | smill <smill@cuckoo.sh> | 2016-09-05 14:19:08 +0000 |
---|---|---|
committer | smill <smill@cuckoo.sh> | 2016-09-05 14:19:08 +0000 |
commit | fad6ee6437f89c0b9e914e509b93e97471af9ed6 (patch) | |
tree | 488e1dacf1e9223baab5040daba34301447432c7 /docs | |
parent | 2ecd89fc51676a98c25a80857584923aae9248a1 (diff) | |
download | mitmproxy-fad6ee6437f89c0b9e914e509b93e97471af9ed6.tar.gz mitmproxy-fad6ee6437f89c0b9e914e509b93e97471af9ed6.tar.bz2 mitmproxy-fad6ee6437f89c0b9e914e509b93e97471af9ed6.zip |
Improved the documentation.
Diffstat (limited to 'docs')
-rw-r--r-- | docs/transparent.rst | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/docs/transparent.rst b/docs/transparent.rst index dc41f40f..7860238e 100644 --- a/docs/transparent.rst +++ b/docs/transparent.rst @@ -25,16 +25,28 @@ Fully transparent mode ======= By default mitmproxy will use its own local ip address for its server-side connections. In case this isn't desired, the --spoof-source-address argument can be used to -use the client's ip address for server-side connections. +use the client's ip address for server-side connections. The following config is +required for this mode to work: + + CLIENT_NET=192.168.1.0/24 + TABLE_ID=100 + MARK=1 + + echo "$TABLE_ID mitmproxy" >> /etc/iproute2/rt_tables + iptables -t mangle -A PREROUTING -d $CLIENT_NET -j MARK --set-mark $MARK + iptables -t nat -A PREROUTING -p tcp -s $CLIENT_NET --match multiport --dports 80,443 -j REDIRECT --to-port 8080 + + ip rule add fwmark $MARK lookup $TABLE_ID + ip route add local $CLIENT_NET dev lo table $TABLE_ID This mode does require root privileges though. There's a wrapper in the examples directory called 'mitmproxy_shim.c', which will enable you to use this mode with dropped priviliges. It can be used as follows: -gcc examples/mitmproxy_shim.c -o mitmproxy_shim -lcap -sudo chown root:root mitmproxy_shim -sudo chmod u+s mitmproxy_shim -./mitmproxy_shim $(which mitmproxy) -T --spoof-source-address + gcc examples/mitmproxy_shim.c -o mitmproxy_shim -lcap + sudo chown root:root mitmproxy_shim + sudo chmod u+s mitmproxy_shim + ./mitmproxy_shim $(which mitmproxy) -T --spoof-source-address .. _iptables: http://www.netfilter.org/ .. _pf: https://en.wikipedia.org/wiki/PF_\(firewall\) |