aboutsummaryrefslogtreecommitdiffstats
path: root/libmproxy/platform/pf.py
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2013-08-17 13:30:36 +0200
committerMaximilian Hils <git@maximilianhils.com>2013-08-17 13:30:36 +0200
commit729677cd85cffedec8f481f1b6025f00fb637e13 (patch)
tree39c245643c5a3a48bd14c6e13757148bda54e2f3 /libmproxy/platform/pf.py
parent6fe175913e611097fdfdf0a6b20b1c05909374e1 (diff)
parenta558c016d4430b67d221a369abe0cde1f4a40fce (diff)
downloadmitmproxy-729677cd85cffedec8f481f1b6025f00fb637e13.tar.gz
mitmproxy-729677cd85cffedec8f481f1b6025f00fb637e13.tar.bz2
mitmproxy-729677cd85cffedec8f481f1b6025f00fb637e13.zip
Merge branch 'master' into 0.10
Diffstat (limited to 'libmproxy/platform/pf.py')
-rw-r--r--libmproxy/platform/pf.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/libmproxy/platform/pf.py b/libmproxy/platform/pf.py
new file mode 100644
index 00000000..062d3311
--- /dev/null
+++ b/libmproxy/platform/pf.py
@@ -0,0 +1,16 @@
+
+def lookup(address, port, s):
+ """
+ Parse the pfctl state output s, to look up the destination host
+ matching the client (address, port).
+
+ Returns an (address, port) tuple, or None.
+ """
+ spec = "%s:%s"%(address, port)
+ for i in s.split("\n"):
+ if "ESTABLISHED:ESTABLISHED" in i and spec in i:
+ s = i.split()
+ if len(s) > 4:
+ s = s[4].split(":")
+ if len(s) == 2:
+ return s[0], int(s[1])