2010-03-01 01:48:06 +00:00
|
|
|
#!/usr/bin/env python
|
2012-04-14 22:35:19 +00:00
|
|
|
import sys, signal
|
2014-01-22 15:21:17 +00:00
|
|
|
from libmproxy import proxy, dump, cmdline
|
2014-03-09 20:51:24 +00:00
|
|
|
from libmproxy.proxy.config import process_proxy_options
|
|
|
|
from libmproxy.proxy.primitives import ProxyServerError
|
|
|
|
from libmproxy.proxy.server import DummyServer, ProxyServer
|
2014-01-22 15:21:17 +00:00
|
|
|
import libmproxy.version, netlib.version
|
2012-08-17 17:04:39 +00:00
|
|
|
import argparse
|
2010-03-01 01:48:06 +00:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2014-01-22 15:21:17 +00:00
|
|
|
# We don't introduce backward-incompatible changes in patch versions. Only consider major and minor version.
|
|
|
|
if netlib.version.IVERSION[:2] != libmproxy.version.IVERSION[:2]:
|
|
|
|
print >> sys.stderr, ("warning: You are using mitmdump %s with netlib %s. "
|
|
|
|
"Most likely, that doesn't work - please upgrade!") % (libmproxy.version.VERSION,
|
|
|
|
netlib.version.VERSION)
|
2012-08-17 17:04:39 +00:00
|
|
|
parser = argparse.ArgumentParser(usage = "%(prog)s [options] [filter]")
|
2014-01-22 15:21:17 +00:00
|
|
|
parser.add_argument('--version', action='version', version="mitmdump" + " " + libmproxy.version.VERSION)
|
2011-03-12 01:30:12 +00:00
|
|
|
cmdline.common_options(parser)
|
2012-08-17 17:04:39 +00:00
|
|
|
parser.add_argument(
|
2011-03-06 04:52:06 +00:00
|
|
|
"--keepserving",
|
|
|
|
action="store_true", dest="keepserving", default=False,
|
2011-05-14 23:54:12 +00:00
|
|
|
help="Continue serving after client playback or file read. We exit by default."
|
2011-03-06 04:52:06 +00:00
|
|
|
)
|
2014-03-12 21:39:23 +00:00
|
|
|
parser.add_argument(
|
|
|
|
"-d",
|
|
|
|
action="count", dest="flow_detail", default=1,
|
|
|
|
help="Increase flow detail display level. Can be passed multiple times."
|
|
|
|
)
|
2012-08-17 17:04:39 +00:00
|
|
|
parser.add_argument('args', nargs=argparse.REMAINDER)
|
2011-02-17 23:40:45 +00:00
|
|
|
|
2012-08-17 17:04:39 +00:00
|
|
|
options = parser.parse_args()
|
2010-03-01 01:48:06 +00:00
|
|
|
|
|
|
|
if options.quiet:
|
|
|
|
options.verbose = 0
|
2014-03-12 21:39:23 +00:00
|
|
|
options.flow_detail = 0
|
2010-03-01 01:48:06 +00:00
|
|
|
|
2014-03-09 20:51:24 +00:00
|
|
|
proxyconfig = process_proxy_options(parser, options)
|
2011-05-13 22:44:25 +00:00
|
|
|
if options.no_server:
|
2014-03-09 20:51:24 +00:00
|
|
|
server = DummyServer(proxyconfig)
|
2011-05-13 22:44:25 +00:00
|
|
|
else:
|
|
|
|
try:
|
2014-03-09 20:51:24 +00:00
|
|
|
server = ProxyServer(proxyconfig, options.port, options.addr)
|
|
|
|
except ProxyServerError, v:
|
2011-05-13 22:44:25 +00:00
|
|
|
print >> sys.stderr, "mitmdump:", v.args[0]
|
|
|
|
sys.exit(1)
|
|
|
|
|
2011-03-12 00:47:37 +00:00
|
|
|
|
2012-03-17 04:20:34 +00:00
|
|
|
try:
|
|
|
|
dumpopts = dump.Options(**cmdline.get_common_options(options))
|
|
|
|
except cmdline.OptionException, v:
|
|
|
|
parser.error(v.message)
|
2011-03-12 01:30:12 +00:00
|
|
|
dumpopts.keepserving = options.keepserving
|
|
|
|
|
2012-08-17 17:04:39 +00:00
|
|
|
if options.args:
|
|
|
|
filt = " ".join(options.args)
|
2011-02-16 21:44:08 +00:00
|
|
|
else:
|
|
|
|
filt = None
|
|
|
|
|
2011-02-17 23:40:45 +00:00
|
|
|
try:
|
|
|
|
m = dump.DumpMaster(server, dumpopts, filt)
|
2012-04-14 22:35:19 +00:00
|
|
|
def cleankill(*args, **kwargs):
|
|
|
|
m.shutdown()
|
|
|
|
signal.signal(signal.SIGTERM, cleankill)
|
2011-02-17 23:40:45 +00:00
|
|
|
m.run()
|
|
|
|
except dump.DumpError, e:
|
|
|
|
print >> sys.stderr, "mitmdump:", e
|
|
|
|
sys.exit(1)
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
pass
|
2012-04-14 22:35:19 +00:00
|
|
|
|