If you’re unable to connect to WhatsApp directly through your mobile app you can set up a proxy that will bypass any internet blocks or shutdowns. This proxy supports up to 27,500 concurrent connections.
- Docker (enable Docker on startup if your host system allows)
- Docker compose (optional)
1. Install Docker for your system
If your version of docker doesn't come pre-installed with Docker compose, you can install a one-off version with (for Linux)
# Download the pkg
sudo curl -L https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m) -o /usr/bin/docker-compose
# Enable execution of the script
sudo chmod +x /usr/bin/docker-compose
Build the proxy host container with
docker build /path/to/git/repo/ -t whatsapp_proxy:1.0
The container will be compiled and tagged as whatsapp_proxy:1.0
for easy reference
You can manually execute the docker container with the following docker command
docker run -it -p 80:80 -p 443:443 -p 5222:5222 -p 8080:8080 -p 8443:8443 -p 8222:8222 -p 8199:8199 whatsapp_proxy:1.0
Docker compose helps manage your container setup and necessary port forwards without user interaction. We recommend utilizing Docker compose because you usually don’t want to manually run the container outside of testing scenarios.
Docker compose is an automated tool to run multi-container deployments, but it also helps automate the command-line arguments necessary to run a single container. It is a YAML definition file that denotes all the settings to start up and run the container. It also has restart strategies in the event the container crashes or self-restarts.
We provide a sample docker-compose.yml file for you which defines a standard deployment of the proxy container.
Once Docker compose is installed, you can test your specific configuration by running Docker compose interactively with
docker compose -f /path/to/this/repo/docker-compose.yml up
This will allow you to see the output from the build + container hosting process and check that everything is set up correctly.
When you are ready to run the container as a service, do*:
docker compose -f /path/to/this/repo/docker-compose.yml up -d
*Note the -d
flag which means "daemonize" and run as a service.
To stop the container you can similarly do:
docker compose down
Once you have Docker Compose set up, you can also automate the deployment for host reboots by utilizing a systemd
service (if your hosting environment supports it).
We provide a sample docker_boot.service
service definition for you which you should customize to your own environment.
To install and setup the systemd
service*:
# Copy the service definition to systemd folder
cp -v docker_boot.service /etc/systemd/system/
# Enable starting the service on startup
systemctl enable docker_boot.service
# Start the service (will docker compose up the container)
systemctl start docker_boot.service
# Check container status with
docker ps
*Make sure to update the path to your specific docker-compose.yml
file in the service definition docker_boot.service
If you would like to configure your proxy using Kubernetes, or run the Docker runtime through Kubernetes, please see our Helm chart README
Depending on the scenario in which you utilize your proxy, the proxy container exposes multiple ports. The basic ports may include:
- 80: Standard web traffic (HTTP)
- 443: Standard web traffic, encrypted (HTTPS)
- 5222: Jabber protocol traffic (WhatsApp default)
There are also ports configured which accept incoming proxy headers (version 1 or 2) on connections. If you have a network load balancer you can preserve the client IP address if you want.
- 8080: Standard web traffic (HTTP) with PROXY protocol expected
- 8443: Standard web traffic, encrypted (HTTPS) with PROXY protocol expected
- 8222: Jabber protocol traffic (WhatsApp default) with PROXY protocol expected
Additionally the container exposes a statistics port on :8199
which can be connected to directly with http://<host-ip>:8199
which you can use to monitor
HAProxy statistics.
Ports 443 and 8443 are protected by a self-signed encryption certificate generated at container start time. There are some custom options should you wish to tweak the settings of the generated certificates
SSL_DNS
comma seperate list of alternative hostnames, no defaultSSL_IP
comma seperate list of alternative IPs, no default
They can be set with commands like
docker build . --build-arg SSL_DNS=test.example.com
The authors of this code are Sean Lawlor (@slawlor).
To learn more about contributing to this project, see this document.
This project is licensed under MIT.