4.5 KiB
iMessage bridge setup (iOS)
Please note that everything in these docs are meant for server admins who want to self-host the bridge. If you're just looking to use the bridges, check out Beeper, which provides fully managed instances of all of these bridges.
Requirements
- A jailbroken iOS device, minimum and recommended is iPhone 4S with iOS 8.4(.1).
- A Matrix homeserver that supports application services (e.g. Synapse). You need access to register an appservice, which usually involves editing the homeserver config file.
- A websocket proxy to receive appservice transactions.
Installation
The bridge consists of two components: Brooklyn for connecting to iMessage and mautrix-imessage for connecting to Matrix. The Brooklyn app runs mautrix-imessage as a subprocess and they communicate over stdio.
The recommended way to install the app is getting a precompiled build from the Cydia repo. You can technically also compile everything yourself, but that is less documented.
Compiling manually
There are instructions for compiling Brooklyn in the GitHub repo.
Compiling mautrix-imessage for darwin/armv7 is more complicated and not currently documented. For more recent devices (i.e. armv8/arm64), it should be as simple as compiling mautrix-imessage on a Mac with Apple Silicon.
Precompiled builds
You can get the Brooklyn app with a bundled mautrix-imessage from the Cydia repo. The repo is currently available at http://maunium.mau.life/brooklyn/ (repo URL subject to change). After adding the repo in Cydia, simply install the "Brooklyn" package from the repo.
Configuring and running
- Get the example config and fill it out. You'll at least need to:
- Fill everything in the
homeserver
section. - Set
bridge
->user
to your MXID. - Change
imessage
->platform
toios
. - Generate random tokens for the
as_token
andhs_token
fields.
- Fill everything in the
- Get the example registration and copy the relevant values from the config.
- Set up mautrix-wsproxy.
- Register the bridge on your homeserver (see Registering appservices).
- Serve the config file with the webserver of your choice. It's recommended
to use a random file name or add HTTP basic auth to prevent other people
from reading your config.
- HTTP basic auth documentation: Caddy, nginx, Apache
- N.B. Due to a bug in Brooklyn, the URL must be lowercase.
- Generate a QR code with the URL to your config
(e.g.
echo -n https://user:pass@example.com/your-config.yaml | qrencode -t ansiutf8
). - Scan the QR code with Brooklyn.
Troubleshooting
The brooklyn app keeps showing the QR Code reader popup
- Connect your iPhone to a Mac and open the Console app to see logs
- Filter for "Brooklyn" to see logs
- If you see
Brooklyn mautrix-imessage sent error:Failed to download config: failed to open config.yaml for writing config: open config.yaml: permission denied
, use the following to mitigate:- install OpenSSH via Cydia
- ssh to the iPhone (find out IP via settings, user is root, password is alpine)
- the first ssh will take minutes because SSH keys are generated
- once you are ssh'ed into your phone, run chmod 777 /var/mobile/Documents/mautrix-imessage-armv7
- scan QR Code again
- check that the config file downloaded by running the following over SSH on your iPhone:
cat /var/mobile/Documents/mautrix-imessage-armv7/config.yaml
- If you are seeing
[ERROR] Error in appservice websocket: failed to open websocket: dial tcp [::1]:29331: connect: connection refused
that means that your phone cannot talk tomautrix-wsproxy
, make sure that the configured value for homeserver -> websocket_proxy can be resolved from your phone. You can check this by installingnetcat
in Cydia and then running the following over ssh:nc -zv <hostname> 29331
to see if it connects