aboutsummaryrefslogtreecommitdiffstats
path: root/libmproxy/main.py
diff options
context:
space:
mode:
authorAldo Cortesi <aldo@nullcube.com>2015-05-31 13:13:12 +1200
committerAldo Cortesi <aldo@nullcube.com>2015-05-31 13:13:12 +1200
commit13ee54da86319e4a028279c4dce0967d8a786067 (patch)
treec915a2fe2d8582824195dbd7bd7c5d7ca9f4260b /libmproxy/main.py
parenta05a70d8168a07c92b2a3ecbbb1958d85532efe3 (diff)
downloadmitmproxy-13ee54da86319e4a028279c4dce0967d8a786067.tar.gz
mitmproxy-13ee54da86319e4a028279c4dce0967d8a786067.tar.bz2
mitmproxy-13ee54da86319e4a028279c4dce0967d8a786067.zip
Remove dependency on PyOpenSSL, move version check into netlib.
There are a few more functions in the code that accesses PyOpenSSL directly that should probably also be moved to netlib. Later.
Diffstat (limited to 'libmproxy/main.py')
-rw-r--r--libmproxy/main.py48
1 files changed, 4 insertions, 44 deletions
diff --git a/libmproxy/main.py b/libmproxy/main.py
index 73e6c62b..98413c7a 100644
--- a/libmproxy/main.py
+++ b/libmproxy/main.py
@@ -2,52 +2,12 @@ from __future__ import print_function, absolute_import
import os
import signal
import sys
-import netlib.version
+import netlib.version, 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"]:
@@ -78,7 +38,7 @@ def get_server(dummy_server, options):
def mitmproxy(args=None): # pragma: nocover
from . import console
- check_versions()
+ netlib.version_check.version_check(version.IVERSION)
assert_utf8_env()
parser = cmdline.mitmproxy()
@@ -106,7 +66,7 @@ def mitmproxy(args=None): # 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(args)
@@ -140,7 +100,7 @@ def mitmdump(args=None): # 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(args)