The relay server serves the clients to establish network connectivity between themselves. Providing them with the address and port information to attempt direct p2p connections and also support the proxying of traffic between clients if direct connections are not possible. This allows the clients to operate even when behind restrictive firewalls or NAT devices.
It is composed of:
- A custom server application, the tunshell-server
- A SQLite database which persists the session keys
- A Nginx + Let's Encrypt which generates SSL certificates and provides http -> https redirection
These services are containerised and can be easily spun up by docker compose.
The easiest way to spin up your own relay server is to use the CloudFormation template which is scripted to configure a new relay server in your own AWS environment.
- Go to Cloud Formation console: https://console.aws.amazon.com/cloudformation/home
- Create a new stack and select 'Upload a template file'
- Upload this template
- Fill out the parameters and let the stack initialise
- This stack will configure an EC2 instance
- Create DNS records for the server (for LetsEncrypt validation)
- Bootstrap the instance with docker and the containers
If you are hosting your server outside of AWS you will have to provision and configure the relay server yourself.
You may use the bootstrap script and docker-compose.yml files as a starting point.
Unfortunately the current tunshell.com website is hard-coded to use the standard relay.tunshell.com server to generate session keys so these will have to be created manually.
An easy way to create a new pair of session keys is via curl
:
curl -XPOST https://relay.yourdomain.com/api/sessions
Which will generate a pair of session keys:
{ "peer1_key": "M485rfdQg8h24byfwkEsc", "peer2_key": "FDxbfDDd67fRFd5skflmc" }
Additionally you will have to pass an additional argument to the client init scripts to override the default relay server:
# Local
sh <(curl -sSf https://lets.tunshell.com/init.sh) L M485rfdQg8h24byfwkEsc YcO8WqyFIEVv8mxReYugGq relay.yourdomain.com
# Target
curl -sSf https://lets.tunshell.com/init.sh | sh -s -- T FDxbfDDd67fRFd5skflmc YcO8WqyFIEVv8mxReYugGq relay.yourdomain.com