mitmproxy docs

libmproxy: mitmproxy as a library

All of mitmproxy's basic functionality is exposed through the libmproxy library. The example below shows a simple implementation of the "sticky cookie" functionality included in the interactive mitmproxy program. Traffic is monitored for cookie and set-cookie headers, and requests are rewritten to include a previously seen cookie if they don't already have one. In effect, this lets you log in to a site using your browser, and then make subsequent requests using a tool like curl, which will then seem to be part of the authenticated session.

from libmproxy import controller, proxy

proxy.config = proxy.Config(
    "~/.mitmproxy/cert.pem"
)

class StickyMaster(controller.Master):
    def __init__(self, server):
        controller.Master.__init__(self, server)
        self.stickyhosts = {}

    def run(self):
        try:
            return controller.Master.run(self)
        except KeyboardInterrupt:
            self.shutdown()

    def handle_request(self, msg):
        hid = (msg.host, msg.port)
        if msg.headers.has_key("cookie"):
            self.stickyhosts[hid] = msg.headers["cookie"]
        elif hid in self.stickyhosts:
            msg.headers["cookie"] = self.stickyhosts[hid]
        msg.ack()

    def handle_response(self, msg):
        hid = (msg.request.host, msg.request.port)
        if msg.headers.has_key("set-cookie"):
            self.stickyhosts[hid] = f.response.headers["set-cookie"]
        msg.ack()


server = proxy.ProxyServer(8080)
m = StickyMaster(server)
m.run()

© mitmproxy project, 2011