This directory contains code to use mitmproxy to proxy Signal iOS, allowing a developer to inspect, modify, respond to, or otherwise work with requests made by the app.
Beyond simply viewing "bytes on the wire", mitmproxy
also supports flexible "addons" that may be useful during development. See below for more.
Install mitmproxy
as described here.
Then, install the mitmproxy
CA certificate. The easiest way to do this (described here) is to run mitmproxy
, configure proxy settings to run your test device/simulator through mitmproxy
(see below), and visit the magic domain mitm.it
, which provides helpful links.
iOS simulators share network proxy settings with their host system, and so if you plan to use
mitmproxy
with a simulator your whole machine machine will need to proxy throughmitmproxy
. Consequently, if you are planning to use an iOS simulator make sure to install the CA cert for both the simulator and your host machine.
Signal clients pin a Signal-specific CA cert when communicating with Signal services. Consequently, when putting mitmproxy
between Signal iOS and Signal services there is some configuration required.
To configure and start mitmproxy
for proxying Signal iOS, simply run:
; ./start-proxy.py
Installing
mitmproxy
also installsmitmweb
, which provides similar request inspection capabilities asmitmproxy
, but through a browser-based UI instead of an interactive terminal app. If you'd prefer to use the web UI, pass--web-ui
to thestart-proxy.py
script.
This will do the following:
-
Replace the
signal-messenger.cer
CA cert included in the iOS repo (and built into the app) withmitmproxy
's (locally-generated, specific-to-your-machine) CA cert, somitmproxy
can inspect requests. -
Create a temporary copy of Signal's CA cert, formatted such that it can be passed to
mitmproxy
so it can communicate with Signal services. -
Configure the system's network settings to use
mitmproxy
as an HTTP(S) proxy. (This can be skipped by passing--no-network-proxy
.) -
Configure and run
mitmproxy
.
Since
mitmproxy
is interactive, the script will not complete until you exitmitmproxy
. Oncemitmproxy
shuts down, the script will clean up any file or configuration changes it made.While
start-proxy.py
is running, you may notice ingit
thatsignal-messenger.cer
has been modified, per (1) above.
Once mitmproxy
is configured and running, build and run Signal as normal - you should see requests running through mitmproxy
!
Once mitmproxy
is running, we need to forward network traffic through it.
As a convenience, you can use the
manage_proxy
script included here to quickly set/enable/disable system proxy settings on your machine:; manage_proxy set 127.0.0.1 8080 ; manage_proxy disable ; manage_proxy enable
iOS simulators share network settings with their host machine. Therefore, to proxy a simulator, you will need to configure your host's network to go through mitmproxy
.
This means that all your local traffic will go through
mitmproxy
, which in turn means you will need to installmitmproxy
's CA cert on the host machine in addition to in the simulator. See above.
start-proxy.py
will, by default, automatically configure system network proxy settings to forward all traffic on the local machine throughmitmproxy
.
If you're trying to proxy a physical device, you'll need to route it through the machine running mitmproxy
. For example, that might look like finding your machine's IP on the local network, and using that IP in the device's network settings.
If using a physical device, you may want to pass
--no-network-proxy
tostart-proxy.py
to skip the configuration of your local machine's network settings.
mitmproxy
has a robust and flexible addon system in which users can write Python scripts that can perform actions while mitmproxy
is running, such as "return a preconfigured response for requests to a given domain".
For example, you might want to test what happens in response to a 404 while making a particular request. If that scenario requires state that is difficult to set up, an addon script can intercept the request in question and respond with a 404 instead of allowing the request to continue to the service.
To load an addon, pass --script <path-to-script>
as an argument to start-proxy.py
. You may pass --script
multiple times, to load multiple addons.
; ./start-proxy.py --script my_addon.py