aboutsummaryrefslogtreecommitdiffstats
path: root/libmproxy/main.py
diff options
context:
space:
mode:
Diffstat (limited to 'libmproxy/main.py')
-rw-r--r--libmproxy/main.py63
1 files changed, 13 insertions, 50 deletions
diff --git a/libmproxy/main.py b/libmproxy/main.py
index e5b7f56b..e7d0f7e0 100644
--- a/libmproxy/main.py
+++ b/libmproxy/main.py
@@ -3,51 +3,12 @@ import os
import signal
import sys
import netlib.version
+import netlib.version_check
from . import version, cmdline
from .proxy import process_proxy_options, ProxyServerError
from .proxy.server import DummyServer, ProxyServer
-# This file is not included in coverage analysis or tests - anything that can be
-# tested should live elsewhere.
-
-def check_versions():
- """
- Having installed a wrong version of pyOpenSSL or netlib is unfortunately a
- very common source of error. Check before every start that both versions are
- somewhat okay.
- """
- # We don't introduce backward-incompatible changes in patch versions. Only
- # consider major and minor version.
- if netlib.version.IVERSION[:2] != version.IVERSION[:2]:
- print(
- "Warning: You are using mitmdump %s with netlib %s. "
- "Most likely, that won't work - please upgrade!" % (
- version.VERSION, netlib.version.VERSION
- ),
- file=sys.stderr
- )
- import OpenSSL
- import inspect
- v = tuple([int(x) for x in OpenSSL.__version__.split(".")][:2])
- if v < (0, 14):
- print(
- "You are using an outdated version of pyOpenSSL:"
- " mitmproxy requires pyOpenSSL 0.14 or greater.",
- file=sys.stderr
- )
- # Some users apparently have multiple versions of pyOpenSSL installed.
- # Report which one we got.
- pyopenssl_path = os.path.dirname(inspect.getfile(OpenSSL))
- print(
- "Your pyOpenSSL %s installation is located at %s" % (
- OpenSSL.__version__, pyopenssl_path
- ),
- file=sys.stderr
- )
- sys.exit(1)
-
-
def assert_utf8_env():
spec = ""
for i in ["LANG", "LC_CTYPE", "LC_ALL"]:
@@ -70,27 +31,29 @@ def get_server(dummy_server, options):
else:
try:
return ProxyServer(options)
- except ProxyServerError, v:
+ except ProxyServerError as v:
print(str(v), file=sys.stderr)
sys.exit(1)
-def mitmproxy(): # pragma: nocover
+def mitmproxy(args=None): # pragma: nocover
from . import console
- check_versions()
+ netlib.version_check.version_check(version.IVERSION)
assert_utf8_env()
parser = cmdline.mitmproxy()
- options = parser.parse_args()
+ options = parser.parse_args(args)
if options.quiet:
options.verbose = 0
proxy_config = process_proxy_options(parser, options)
console_options = console.Options(**cmdline.get_common_options(options))
console_options.palette = options.palette
+ console_options.palette_transparent = options.palette_transparent
console_options.eventlog = options.eventlog
console_options.intercept = options.intercept
+ console_options.limit = options.limit
server = get_server(console_options.no_server, proxy_config)
@@ -101,13 +64,13 @@ def mitmproxy(): # pragma: nocover
pass
-def mitmdump(): # pragma: nocover
+def mitmdump(args=None): # pragma: nocover
from . import dump
- check_versions()
+ netlib.version_check.version_check(version.IVERSION)
parser = cmdline.mitmdump()
- options = parser.parse_args()
+ options = parser.parse_args(args)
if options.quiet:
options.verbose = 0
options.flow_detail = 0
@@ -135,13 +98,13 @@ def mitmdump(): # pragma: nocover
pass
-def mitmweb(): # pragma: nocover
+def mitmweb(args=None): # pragma: nocover
from . import web
- check_versions()
+ netlib.version_check.version_check(version.IVERSION)
parser = cmdline.mitmweb()
- options = parser.parse_args()
+ options = parser.parse_args(args)
if options.quiet:
options.verbose = 0