This is not an official Cryptostorm client, it just supports Cryptostorm.
Connects to Cryptostorm VPN and allows you to link other containers to it. Image name: microbug/cryptostorm-client
.
This image is designed to work with Cryptostorm's VPN service. Pass it a username and (optionally) specify which node to use (by setting which config file to use), and it will connect to Cryptostorm. You can then connect other containers to it via --net=container:vpn_container_name
or through docker-compose.
Since it's based on Alpine, the image is very lightweight at around 6MB compressed.
If you don't have a Cryptostorm token, you can purchase them here. Note that different tokens have different numbers of maximum simultaneous connections; if you want to use the VPN on your phone/computer and in the container at the same time you'll need to buy a 3 month or longer token.
For additional security you can store the username in a separate secrets file and specify it with env_file. Excluding the secrets file in your .gitignore allows you to push your config to a public repository without worrying about someone stealing your credentials.
version: '3'
services:
vpn:
image: microbug/cryptostorm-client:latest
environment:
CRYPTOSTORM_USERNAME: your_long_sha512_hash
CRYPTOSTORM_CONFIG_FILE: Balancer_UDP.ovpn
CONNECTION_PORT: 1194
restart: always
cap_add:
- NET_ADMIN
deluge:
image: linuxserver/deluge:latest
depends-on:
- vpn
environment:
TZ: Europe/London
PGID: 1000
PUID: 1000
network_mode: "service:vpn"
restart: always
volumes:
- /your/config/folder:/config:rw
- /your/downloads/folder:/downloads:rw
docker run -d \
--cap-add NET_ADMIN \
--env CRYPTOSTORM_USERNAME=your_long_sha512_hash \
--env CRYPTOSTORM_CONFIG_FILE=Balancer_UDP.ovpn \
--env CONNECTION_PORT=1194 \
--name vpn \
microbug/cryptostorm-client:latest
docker run -d \
--env TZ=Europe/London --env PGID=1000 --env PUID=1000 \
--net container:vpn \
-v /your/config/folder:/config:rw \
-v /your/downloads/folder:/downloads:rw \
linuxserver/deluge:latest
Start the container as above. Run docker ps
and copy the container ID. Run docker logs -f [CONTAINER ID]
to inspect the logs and check if it's working. After the VPN connects you should see the killswitch script check the current IP address (which should be from your VPN) against the original IP address (your host's public IP).
Port 1194 is commonly blocked by ISPs and organisations, if that is the case you can try 443 instead (see the section on port striping below).
With docker run
, you can use --net=container:vpn_container_name
. With docker-compose
you can use network_mode: "service:vpn_container_name"
.
This works with macvlan networks, which allow you to give your container its own IP address on your LAN.
It's not possible to do this within the container without making it privileged. There are various (1) guides (2) online (3) for this.
All environment variables:
CRYPTOSTORM_USERNAME
: the sha512 hash of your tokenCRYPTOSTORM_CONFIG_FILE
: the name of the config file you want to use. There is a list of filenames here.CONNECTION_PORT
: the port that OpenVPN will connect over. Defaults to 1194. Can be 1-65535.FORWARDING_PORT
: after the VPN is connected, this port will be requested to be forwarded to the container. Note that this does not guarantee success as the port may be unavailable.KILLSWITCH_CHECK_INTERVAL
: the time to wait between each killswitch check. Defaults to 30s.
The container automatically checks the current IP every
$KILLSWITCH_CHECK_INTERVAL
seconds. If there is a timeout (or curl exits
non-zero), or the IP matches the host's public IP, openvpn is restarted. This
should allow automatic recovery from openvpn's regular hiccups.
If openvpn doesn't respond to TERM then the container may become unresponsive. There is a HEALTHCHECK command specified in the Dockerfile, you should define a restart policy in your Compose file to define what happens if the container is unresponsive.
You must give the image NET_ADMIN or it won't be able to connect and will exit. Running VPN clients in Docker requires NET_ADMIN. To give this, add --cap-add NET_ADMIN
if running through docker run
or use the relevant docker-compose method.
Cryptostorm uses a SHA512-based authentication system. The SHA512 hash of your token is used as the username, and the password is ignored. You must provide a valid SHA512 through --env CRYPSTOSTORM_USERNAME=your_long_sha512_hash
or docker-compose. If you don't do this, the container won't be able to connect and will exit.
It is recommended to set CRYPTOSTORM_CONFIG_FILE
to a choice from this list. If you don't do this the container will connect to a randomly chosen Cryptostorm node, which could decrease performance if that node is far away from you.
Every 30s (by default) the container will check its IP address. If it is different from the host's public IP, it will do nothing. If it is the same that means the VPN is down,
Cryptostorm supports port forwarding for ports between 30000 and 65535
(inclusive). To request a port to be forwarded, set the FORWARDING_PORT
environment variable to the port number you want to forward to the container.
Make sure you check the logs as this can fail if someone else is already using
the port. It can also fail if the container is killed, as Cryptostorm won't know
to release the port. (The port will be released after a few minutes if that
happens).
Unless you know why you need TCP, you should use the UDP config files.
Cryptostorm supports port striping, so you can connect to the VPN via any port. By default port 1194 is used, you can change this by specifying --env CONNECTION_PORT=your_port
or adding CONNECTION_PORT: your_port
under environment:
in docker-compose.
If your ISP/firewall blocks port 1194 (quite common), you should try port 80 or port 443. To change the port, set the environment variable CONNECTION_PORT
to the port number you want to use (1-65535).
The image used to have a firewall, but eth0 appears to be blocked anyway once the VPN
is running so the firewall is redundant. You can test this yourself by entering the
container and running curl --interface eth0 api.ipify.org
(this should fail).
Compare this to curl --interface tun0 api.ipify.org
. This should work,
indicating that traffic can only pass over tun0.
Your network's default DNS will be used to look up the Cryptostorm node. Once the VPN is connected, the Cryptostorm DNS resolver will be used (10.31.33.8 from within the Cryptostorm network).
Having the system clock correct is important for VPNs as the server may reject requests that have incorrect timestamps. The container uses the host's timekeeping so make sure you have NTP correctly set up on the host.
Contributions, suggestions and bug reports are welcomed. Full guidelines are in CONTRIBUTING.md
.
The contents of this repository (except update-resolv-conf
) are licensed under the MIT license, which can be found in the LICENSE file. update-resolv-conf
is licensed under the GPL license, which can be found online.