mirror of
https://github.com/Grasscutters/mitmproxy.git
synced 2024-11-26 18:18:25 +00:00
mitmweb: include console logging
This commit is contained in:
parent
1d3cb9eeb8
commit
0386740404
@ -1,6 +1,5 @@
|
|||||||
import sys
|
|
||||||
import webbrowser
|
import webbrowser
|
||||||
from typing import Optional
|
from typing import Optional, IO
|
||||||
|
|
||||||
import tornado.httpserver
|
import tornado.httpserver
|
||||||
import tornado.ioloop
|
import tornado.ioloop
|
||||||
@ -11,6 +10,7 @@ from mitmproxy import master
|
|||||||
from mitmproxy import options
|
from mitmproxy import options
|
||||||
from mitmproxy.addons import eventstore
|
from mitmproxy.addons import eventstore
|
||||||
from mitmproxy.addons import intercept
|
from mitmproxy.addons import intercept
|
||||||
|
from mitmproxy.addons import termlog
|
||||||
from mitmproxy.addons import view
|
from mitmproxy.addons import view
|
||||||
from mitmproxy.tools.web import app
|
from mitmproxy.tools.web import app
|
||||||
|
|
||||||
@ -20,6 +20,7 @@ class Options(options.Options):
|
|||||||
self,
|
self,
|
||||||
*, # all args are keyword-only.
|
*, # all args are keyword-only.
|
||||||
intercept: Optional[str] = None,
|
intercept: Optional[str] = None,
|
||||||
|
tfile: Optional[IO[str]] = None,
|
||||||
open_browser: bool = True,
|
open_browser: bool = True,
|
||||||
wdebug: bool = False,
|
wdebug: bool = False,
|
||||||
wport: int = 8081,
|
wport: int = 8081,
|
||||||
@ -27,6 +28,7 @@ class Options(options.Options):
|
|||||||
**kwargs
|
**kwargs
|
||||||
) -> None:
|
) -> None:
|
||||||
self.intercept = intercept
|
self.intercept = intercept
|
||||||
|
self.tfile = tfile
|
||||||
self.open_browser = open_browser
|
self.open_browser = open_browser
|
||||||
self.wdebug = wdebug
|
self.wdebug = wdebug
|
||||||
self.wport = wport
|
self.wport = wport
|
||||||
@ -50,7 +52,12 @@ class WebMaster(master.Master):
|
|||||||
self.options.changed.connect(self._sig_options_update)
|
self.options.changed.connect(self._sig_options_update)
|
||||||
|
|
||||||
self.addons.add(*addons.default_addons())
|
self.addons.add(*addons.default_addons())
|
||||||
self.addons.add(self.view, self.events, intercept.Intercept())
|
self.addons.add(
|
||||||
|
self.view,
|
||||||
|
self.events,
|
||||||
|
intercept.Intercept(),
|
||||||
|
termlog.TermLog(),
|
||||||
|
)
|
||||||
self.app = app.Application(
|
self.app = app.Application(
|
||||||
self, self.options.wdebug
|
self, self.options.wdebug
|
||||||
)
|
)
|
||||||
@ -121,14 +128,27 @@ class WebMaster(master.Master):
|
|||||||
|
|
||||||
iol.add_callback(self.start)
|
iol.add_callback(self.start)
|
||||||
tornado.ioloop.PeriodicCallback(lambda: self.tick(timeout=0), 5).start()
|
tornado.ioloop.PeriodicCallback(lambda: self.tick(timeout=0), 5).start()
|
||||||
try:
|
|
||||||
url = "http://{}:{}/".format(self.options.wiface, self.options.wport)
|
|
||||||
print("Server listening at {}".format(url), file=sys.stderr)
|
|
||||||
if self.options.open_browser:
|
|
||||||
success = open_browser(url)
|
|
||||||
if not success:
|
|
||||||
print("No webbrowser found. Please open a browser and point it to {}".format(url))
|
|
||||||
|
|
||||||
|
self.add_log(
|
||||||
|
"Proxy server listening at http://{}/".format(self.server.address),
|
||||||
|
"info"
|
||||||
|
)
|
||||||
|
|
||||||
|
web_url = "http://{}:{}/".format(self.options.wiface, self.options.wport)
|
||||||
|
self.add_log(
|
||||||
|
"Web server listening at {}".format(web_url),
|
||||||
|
"info"
|
||||||
|
)
|
||||||
|
|
||||||
|
if self.options.open_browser:
|
||||||
|
success = open_browser(web_url)
|
||||||
|
if not success:
|
||||||
|
self.add_log(
|
||||||
|
"No web browser found. Please open a browser and point it to {}".format(web_url),
|
||||||
|
"info"
|
||||||
|
)
|
||||||
|
|
||||||
|
try:
|
||||||
iol.start()
|
iol.start()
|
||||||
except KeyboardInterrupt:
|
except KeyboardInterrupt:
|
||||||
self.shutdown()
|
self.shutdown()
|
||||||
|
Loading…
Reference in New Issue
Block a user