mirror of
https://github.com/Grasscutters/mitmproxy.git
synced 2024-11-30 03:14:22 +00:00
0c6663d0d5
- Add an options parameter to the start() event. This is to be used by addons on startup to add custom options. - Add a running() event that is called once the proxy is up and running. - With the new paradigm we can't log during master __init__, so add a tiny termstatus addon to print proxy status to terminal once we're running.
26 lines
874 B
Python
26 lines
874 B
Python
"""
|
|
This example shows how to graft a WSGI app onto mitmproxy. In this
|
|
instance, we're using the Flask framework (http://flask.pocoo.org/) to expose
|
|
a single simplest-possible page.
|
|
"""
|
|
from flask import Flask
|
|
from mitmproxy.addons import wsgiapp
|
|
|
|
app = Flask("proxapp")
|
|
|
|
|
|
@app.route('/')
|
|
def hello_world():
|
|
return 'Hello World!'
|
|
|
|
|
|
def start(opts):
|
|
# Host app at the magic domain "proxapp" on port 80. Requests to this
|
|
# domain and port combination will now be routed to the WSGI app instance.
|
|
return wsgiapp.WSGIApp(app, "proxapp", 80)
|
|
|
|
# SSL works too, but the magic domain needs to be resolvable from the mitmproxy machine due to mitmproxy's design.
|
|
# mitmproxy will connect to said domain and use serve its certificate (unless --no-upstream-cert is set)
|
|
# but won't send any data.
|
|
# mitmproxy.ctx.master.apps.add(app, "example.com", 443)
|