Tornado Cash relayer software
Go to file
2022-08-02 14:42:51 +10:00
.github/workflows update workflow 2022-07-29 18:48:55 +10:00
abis lint 2022-06-29 20:03:25 +10:00
monitoring fix: lint 2022-01-19 22:11:00 +10:00
src update start command, cleanup 2022-08-02 14:42:51 +10:00
.dockerignore update libs, docker file, lint 2022-06-29 20:02:30 +10:00
.editorconfig watcher 2020-05-08 20:29:31 +03:00
.env.example cleanup and formatting code 2022-07-08 10:20:17 +10:00
.eslintrc.json update libs, docker file, lint 2022-06-29 20:02:30 +10:00
.gitignore wip DI implemented, Queue helpers 2022-05-23 17:17:39 +10:00
.nvmrc wip. relayer job flow. server api 2022-05-18 18:18:10 +10:00
.prettierrc update libs, docker file, lint 2022-06-29 20:02:30 +10:00
docker-compose.test.yml update start command, cleanup 2022-08-02 14:42:51 +10:00
docker-compose.yml update docker image, compose file 2022-07-26 18:09:26 +10:00
Dockerfile update start command, cleanup 2022-08-02 14:42:51 +10:00
package.json update start command, cleanup 2022-08-02 14:42:51 +10:00
README.md update start command, cleanup 2022-08-02 14:42:51 +10:00
tsconfig.json update libs, docker file, lint 2022-06-29 20:02:30 +10:00
yarn.lock check update job 2022-07-26 17:49:54 +10:00

Relayer for Tornado Cash Build Status Docker Image Version (latest semver)

Deploy with docker-compose

docker-compose.yml contains a stack that will automatically provision SSL certificates for your domain name and will add a https redirect to port 80.

  1. Download docker-compose.yml and .env.example
wget https://raw.githubusercontent.com/tornadocash/tornado-relayer/master/docker-compose.yml
wget https://raw.githubusercontent.com/tornadocash/tornado-relayer/master/.env.example -O .env
  1. Setup environment variables
  • set NET_ID (1 for mainnet, networks list)
  • set HTTP_RPC_URL rpc url for your ethereum node
  • set ORACLE_RPC_URL - rpc url for mainnet node for fetching prices(always have to be on mainnet)
  • set PRIVATE_KEY for your relayer address (without 0x prefix)
  • set VIRTUAL_HOST and LETSENCRYPT_HOST to your domain and add DNS record pointing to your relayer ip address
  • set REGULAR_TORNADO_WITHDRAW_FEE - fee in % that is used for tornado pool withdrawals
  • set REWARD_ACCOUNT - eth address that is used to collect fees
  • update AGGREGATOR if needed - Contract address of aggregator instance.
  • update CONFIRMATIONS if needed - how many block confirmations to wait before processing an event. Not recommended to set less than 3
  • update MAX_GAS_PRICE if needed - maximum value of gwei value for relayer's transaction
  • update BASE_FEE_RESERVE_PERCENTAGE if needed - how much in % will the network baseFee increase
  • set TELEGRAM_NOTIFIER_BOT_TOKEN and TELEGRAM_NOTIFIER_CHAT_ID if your want get notify to telegram

If you want to use more than 1 eth address for relaying transactions, please add as many workers as you want. For example, you can comment out worker2 in docker-compose.yml file, but please use a different PRIVATE_KEY for each worker.

  1. Run docker-compose up -d

V5 Migration Guide

This guide is intended to help with migration from Relayer v4 to v5.

  1. Stop relayer
docker-compose down
  1. Download the latest version of relayer`s docker compose file
wget https://raw.githubusercontent.com/tornadocash/tornado-relayer/master/docker-compose.yml
  1. Check your environment variables, add new ones if needed

  2. Run updated docker compose file

docker-compose up -d --pull

Run locally

  1. yarn
  2. cp .env.example .env
  3. Modify .env as needed
  4. yarn start
  5. Go to http://127.0.0.1:8000
  6. In order to execute withdraw request, you can run following command
curl -X POST -H 'content-type:application/json' --data '<input data>' http://127.0.0.1:8000/v1/tornadoWithdraw

Relayer should return a job id in uuid v4 format.

In that case you will need to add https termination yourself because browsers with default settings will prevent https tornado.cash UI from submitting your request over http connection

Run geth node

It is strongly recommended that you use your own RPC node. Instruction on how to run full node with geth can be found here.

Monitoring

Basic

For basic monitoring setup telegram bot and fill variables in .env file

Alerts about:

  • Main relayer currency balance
  • Torn balance
  • Withdraw transactions send errors

How to create bot: https://core.telegram.org/bots#3-how-do-i-create-a-bot

How to get chat id: https://stackoverflow.com/questions/32423837/telegram-bot-how-to-get-a-group-chat-id/32572159#32572159

Advanced

You can find the guide on how to install the Zabbix server in the /monitoring/README.md.

Compatible networks

  • Ethereum Mainnet (1)
  • Binance Smart Chain (56)
  • Polygon (Matic) Network (137)
  • Optimism (10)
  • Arbitrum One (42161)
  • Gnosis Chain (100)
  • Avalanche Mainnet (43114)
  • Ethereum Goerli (5)

Disclaimer:

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.