Skip to content

Latest commit

 

History

History
43 lines (32 loc) · 4.46 KB

README.md

File metadata and controls

43 lines (32 loc) · 4.46 KB

mitmproxy_rs

autofix.ci: enabled Continuous Integration Status Latest Version Supported Python versions PyPI - Wheel

This repository contains mitmproxy's Rust bits, most notably:

  • WireGuard Mode: The ability to proxy any device that can be configured as a WireGuard client.
  • Local Redirect Mode: The ability to proxy arbitrary macOS or Windows applications by name or pid.

Contributing

Dev Guide dev documentation

Structure

  • src/: The mitmproxy crate containing most of the "meat".
  • mitmproxy-rs/: The mitmproxy-rs Python package, which provides Python bindings for the Rust crate using PyO3.
    Source and binary distributions are available on PyPI.
  • mitmproxy-macos/: The mitmproxy-macos Python package, which contains a macOS Network Extension to transparently intercept macOS traffic.
    Only a binary distribution is available on PyPI due to code signing and notarization requirements.
  • mitmproxy-windows/: The mitmproxy-windows Python package, which contains the Windows traffic redirector based on WinDivert.
    Only a binary distribution is available on PyPI due to build complexity.
  • mitmproxy-linux/: The mitmproxy-linux Python package, which contains the Linux traffic redirector based on Aya.
    Source and binary distributions are available on PyPI.
  • mitmproxy-linux-ebpf/: The eBPF program embedded in mitmproxy-linux.
  • mitmproxy-linux-ebpf-common/: Data structures shared by user space and eBPF.

Architecture

library architecture