Sen descrición

smart_ex 2247730603 bump tx-manager %!s(int64=2) %!d(string=hai) anos
.github 1f900843de added discord notification (#86) %!s(int64=2) %!d(string=hai) anos
abis fa77997896 fix: prices oracle %!s(int64=3) %!d(string=hai) anos
cache 043356f5fe fix: initializing mining tree %!s(int64=3) %!d(string=hai) anos
keys 02eba55def update key %!s(int64=3) %!d(string=hai) anos
monitoring 31d697701e fix: lint %!s(int64=2) %!d(string=hai) anos
src c915c97b85 priceWatcher oracle fix %!s(int64=2) %!d(string=hai) anos
test 7f657c1d7d add test for isKnownContract validation %!s(int64=2) %!d(string=hai) anos
.dockerignore c379ae7b7a fix timeouts under high load in nginx and express, fix redis persistence %!s(int64=5) %!d(string=hai) anos
.editorconfig a49746180e watcher %!s(int64=4) %!d(string=hai) anos
.env.example 8f5b673f3b feat: add env baseFeeReserve variable %!s(int64=3) %!d(string=hai) anos
.eslintrc.json 9cd97feef0 prettier + tidy %!s(int64=4) %!d(string=hai) anos
.gitignore 2da481cf16 fix: gas limit for cDAI %!s(int64=3) %!d(string=hai) anos
.prettierignore 9cd97feef0 prettier + tidy %!s(int64=4) %!d(string=hai) anos
.prettierrc 9cd97feef0 prettier + tidy %!s(int64=4) %!d(string=hai) anos
Dockerfile cf430641cc update refs %!s(int64=4) %!d(string=hai) anos
README.md 3c5eaa2c4b Update README.md %!s(int64=2) %!d(string=hai) anos
app.js 8868040882 write errors with positive score %!s(int64=2) %!d(string=hai) anos
docker-compose.test.yml 95c6dc23c6 increment errors score %!s(int64=2) %!d(string=hai) anos
docker-compose.yml 0f8d1cf010 add healthWather to docker-compose %!s(int64=3) %!d(string=hai) anos
package.json 2247730603 bump tx-manager %!s(int64=2) %!d(string=hai) anos
yarn.lock 2247730603 bump tx-manager %!s(int64=2) %!d(string=hai) anos

README.md

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, 5 for Goerli)
    • set HTTP_RPC_URL rpc url for your ethereum node
    • set WS_RPC_URL websocket url
    • 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 MINING_SERVICE_FEE - fee in % that is used for mining AP 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

    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.

  2. Run docker-compose up -d

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/relay

Relayer should return a transaction hash

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

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

Architecture

  1. TreeWatcher module keeps track of Account Tree changes and automatically caches the actual state in Redis and emits treeUpdate event to redis pub/sub channel
  2. Server module is Express.js instance that accepts http requests
  3. Controller contains handlers for the Server endpoints. It validates input data and adds a Job to Queue.
  4. Queue module is used by Controller to put and get Job from queue (bull wrapper)
  5. Status module contains handler to get a Job status. It's used by UI for pull updates
  6. Validate contains validation logic for all endpoints
  7. Worker is the main module that gets a Job from queue and processes it

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.