MollySocket allows getting signal notifications via UnifiedPush. It works like a linked device, which doesn't have an encryption key, connected to the Signal server. Everytime it receives an encrypted event, it notifies your mobile via UnifiedPush.
---
title: Message flow
---
graph TD
MS[fa:fa-tablets MollySocket]
S[fa:fa-comment Signal Server]
P[fa:fa-server Push server]
subgraph "fa:fa-mobile Android"
D[fa:fa-tower-broadcast Distributor App]
MA[fa:fa-tablets Molly Android]
end
MS -- 1. Persistent connection --> S
MS -- 2. 'Notifications present' --> P
P -- 3. 'Notications present for Molly' --> D
D -- 4. 'Check Signal servers' --> MA
MA -- 5. 'Got messages?' --> S
S -- 6. Messages --> MA
docker pull ghcr.io/mollyim/mollysocket:latest
cargo install mollysocket
(see INSTALL.md for the setup) You can optionally install your own push server like ntfy or NextPush. For beginners, you can use a free service like ntfy.sh (do consider donating if you have the means).
MollySocket exposes a web server so that Molly can send the information it needs to operate. You must configure TLS with a reverse proxy in front of MollySocket. Molly can only connect to the server over HTTPS.
It is possible to use MollySocket without the web server, but you will have to manually register the information MollySocket needs: see the Air Gapped mode on Android settings.
The configuration file uses the TOML format. Below is an overview of configuration options. You can configure each parameter using either the conf file, the environment variable or the cli option (if available).
Parameter (conf. file) | Environment variable | Cli Option | Description | Default | Examples |
---|---|---|---|---|---|
RUST_LOG * | -v/-vv/-vvv | Verbosity | error | RUST_LOG=info, RUST_LOG=debug | |
MOLLY_CONF | -c * | Path to the configuration file, optional | /etc/mollysocket.conf | ||
host | MOLLY_HOST * | Listening address of the web server | 127.0.0.1 | 0.0.0.0 | |
port | MOLLY_PORT * | Listening port of the web server | 8020 | 8080 | |
webserver | MOLLY_WEBSERVER * | Wether to start the web server | true | false | |
allowed_endpoints | MOLLY_ALLOWED_ENDPOINTS * | List of UnifiedPush servers | ["*"] |
["*"] ,["https://yourdomain.tld","https://ntfy.sh"] |
|
allowed_uuids | MOLLY_ALLOWED_UUIDS * | UUIDs of signal accounts that may use this server | ["*"] |
["*"] , ["abcdef-12345-tuxyz-67890"] |
|
db | MOLLY_DB * | Path to the DB | db.sqlite |
"/data/ms.sqlite" |
|
vapid_privkey | MOLLY_VAPID_PRIVKEY * | VAPID key, see VAPID key | None | "DSqYuWchrB6yIMYJtidvqANeRQic4uWy34afzZRsZnI" | |
vapid_key_file | MOLLY_VAPID_KEY_FILE * | File with VAPID key, see VAPID key | None | "/etc/ms_vapid_key" |
* Takes the precedence
VAPID key is used to authorize mollysocket server to send requests to your push server, if it supports it.
To generate a new key, you can run this command mollysocket vapid gen
. Or using docker, docker-compose run mollysocket vapid gen
.
This value can be passed to mollysocket via a file, location given with vapid_key_file
parameter, or directly in the vapid_privkey
parameter. The key file takes the precedence.
To pass this value to mollysocket, you may wish to use systemd-creds:
$ mollysocket vapid gen | systemd-creds encrypt --name=ms_vapid -p - -
SetCredentialEncrypted=ms_vapid: \
k6iUCUh0RJCQyvL8k8q1UyAAAAABAAAADAAAABAAAAC1lFmbWAqWZ8dCCQkAAAAAgAAAA \
AAAAAALACMA0AAAACAAAAAAfgAg9uNpGmj8LL2nHE0ixcycvM3XkpOCaf+9rwGscwmqRJ \
cAEO24kB08FMtd/hfkZBX8PqoHd/yPTzRxJQBoBsvo9VqolKdy9Wkvih0HQnQ6NkTKEdP \
HQ08+x8sv5sr+Mkv4ubp3YT1Jvv7CIPCbNhFtag1n5y9J7bTOKt2SQwBOAAgACwAAABIA \
ID8H3RbsT7rIBH02CIgm/Gv1ukSXO3DMHmVQkDG0wEciABAAII6LvrmL60uEZcp5qnEkx \
SuhUjsDoXrJs0rfSWX4QAx5PwfdFuxPusgE==
This will output SetCredentialEncrypted
you can use in your systemd unit file:
[Service]
SetCredentialEncrypted=ms_vapid: \
k6iUCUh0RJCQyvL8k8q1UyAAAAABAAAADAAAABAAAAC1lFmbWAqWZ8dCCQkAAAAAgAAAA \
AAAAAALACMA0AAAACAAAAAAfgAg9uNpGmj8LL2nHE0ixcycvM3XkpOCaf+9rwGscwmqRJ \
cAEO24kB08FMtd/hfkZBX8PqoHd/yPTzRxJQBoBsvo9VqolKdy9Wkvih0HQnQ6NkTKEdP \
HQ08+x8sv5sr+Mkv4ubp3YT1Jvv7CIPCbNhFtag1n5y9J7bTOKt2SQwBOAAgACwAAABIA \
ID8H3RbsT7rIBH02CIgm/Gv1ukSXO3DMHmVQkDG0wEciABAAII6LvrmL60uEZcp5qnEkx \
SuhUjsDoXrJs0rfSWX4QAx5PwfdFuxPusgE==
Environment=MOLLY_VAPID_KEY_FILE=%d/ms_vapid
allowed_endpoints
These are the UnifiedPush endpoints that MollySocket may use to push notifications with.
⚠️ If you self-host your push server, add your push server to the allowed_endpoints
. ⚠️
That's because, for security reasons, endpoints on your local network must be allowed explicitly. You just have to set the scheme (https), the domain and the port if required. For instance allowed_endpoints=['https://push.mydomain.tld']
allowed_uuids
You can allow registration for all accounts by setting allowed_uuids
to ['*']
. Else set your account ids in the array: ['account_id1','account_id2']
.
The account IDs are showing in the Molly application under Settings > Notifications > UnifiedPush. You need to activate UnifiedPush first before your account ID is shown.
You haven't entered the right url.
This must be the one where MollySocket is reachable. To test it, open the link you have entered in a browser: you should see a json containing the version of MollySocket. For instance {"mollysocket":{"version":"1.2.0"}}
.
If you can access the web server, make sure it is accessible over HTTPS. Molly can't connect to the server over HTTP.
You have restricted the allowed account ID who can use your MollySocket server.
Add your account ID[1] to _alloweduuids to allow your account, or add a wildcard ["*"]
to allow all the accounts to use your server. See Configuration to configure your server correctly.
[1] Your account ID can be copied on the Android app, under the UnifiedPush settings
You have restricted the allowed UnifiedPush endpoints, or you are using a self-hosted server you haven't whitelisted.
Add your server to the _allowedendpoints: ["https://push.mydomain.tld"]
. This is NOT your MollySocket URL but the one from your push provider. See Configuration to configure your server correctly.
There might be 3 reasons for that:
You don't have yet registered your connection on a MollySocket server.
$ # If you use docker-compose:
$ docker compose run mollysocket <paste the parameters here>
$ # Else, if you use the binary:
$ mollysocket <paste the parameters here>
It is possible you don't use a recent enough version of MollySocket and it hasn't send a request during the registration. You can run :
$ # Replace the UUID with your account Id
$ # If you use docker-compose:
$ docker compose run mollysocket connection ping c8d44128-5c99-4810-a7d3-71c079891c27
$ # Else, if you use the binary:
$ mollysocket connection ping c8d44128-5c99-4810-a7d3-71c079891c27
You have a problem with your UnifiedPush setup. You can get further troubleshooting information on this page: https://unifiedpush.org/users/troubleshooting/.
On the Android app, the status is Waiting for test notification
It is possible you don't use a recent enough version of MollySocket and it hasn't send a request during the registration. You can either:
$ # Replace the UUID with your account Id
$ # If you use docker-compose:
$ docker compose run mollysocket connection ping c8d44128-5c99-4810-a7d3-71c079891c27
$ # Else, if you use the binary:
$ mollysocket connection ping c8d44128-5c99-4810-a7d3-71c079891c27
You have a problem with your UnifiedPush setup. You can get further troubleshooting information on this page: https://unifiedpush.org/users/troubleshooting/.
I use the Air-gapped mode and I don't receive notifications.
If you use air-gapped mode, then Molly (android) can't test the setup and it assumes you have correctly setup everything. You should double check that the account ID is accepted by your mollysocket server and the endpoint is allowed by your mollysocket server (check the output logs).
If you are using Molly version >= 7.1.3-1.up1 and MollySocket version >= 1.3.0, you can run this command:
$ # Replace the UUID with your account Id
$ # If you use docker-compose:
$ docker compose run mollysocket connection ping c8d44128-5c99-4810-a7d3-71c079891c27
$ # Else, if you use the binary:
$ mollysocket connection ping c8d44128-5c99-4810-a7d3-71c079891c27
If you receive a test notification (image bellow), then you should check that Molly and your distributor have unrestricted battery usage. You should check if you have additional configuration for your device regarding battery management: https://dontkillmyapp.com/.
If you don't receive a test notification, then your MollySocket server can't reach your push server or your phone don't have network access.
You can get further troubleshooting information on this page: https://unifiedpush.org/users/troubleshooting/.
Relative to Signal security
MollySocket never has any encryption key
MollySocket receives the credentials for a linked device and does not receive any encryption key. Which means:
AGPLv3: see LICENSE.txt.
This project is NOT sponsored by or affiliated to Signal Messenger or Signal Foundation.
The software is produced independently of Signal and carries no guarantee about quality, security or anything else. Use at your own risk.