classic-relayer/src/index.js

93 lines
2.5 KiB
JavaScript
Raw Normal View History

2019-11-23 03:18:54 -05:00
const express = require('express')
2020-05-12 16:23:18 -04:00
const {
netId,
port,
relayerServiceFee,
version,
gasBumpPercentage,
pendingTxTimeout,
watherInterval,
maxGasPrice
} = require('../config')
2019-11-23 03:18:54 -05:00
const relayController = require('./relayController')
2020-07-16 09:33:35 -04:00
const { fetcher, web3, gasPriceOracle } = require('./instances')
2019-12-02 07:49:24 -05:00
const { getMixers } = require('./utils')
const mixers = getMixers()
2019-12-12 05:58:58 -05:00
const { redisClient } = require('./redis')
2019-11-23 03:18:54 -05:00
const app = express()
app.use(express.json())
app.use((err, req, res, next) => {
if (err) {
console.log('Invalid Request data')
res.send('Invalid Request data')
} else {
next()
}
})
2020-07-16 09:33:35 -04:00
app.use(function (req, res, next) {
2019-11-23 03:18:54 -05:00
res.header('Access-Control-Allow-Origin', '*')
res.header('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept')
next()
})
app.get('/', function (req, res) {
// just for testing purposes
res.send('This is <a href=https://tornado.cash>tornado.cash</a> Relayer service. Check the <a href=/status>/status</a> for settings')
2019-11-23 03:18:54 -05:00
})
2020-07-16 21:45:40 -04:00
2019-12-12 05:58:58 -05:00
app.get('/status', async function (req, res) {
let nonce = await redisClient.get('nonce')
2020-07-16 21:45:40 -04:00
let latestBlock = null
try {
latestBlock = await web3.eth.getBlockNumber()
} catch(e) {
console.error('Problem with RPC', e)
}
2020-07-16 09:33:35 -04:00
const { ethPrices } = fetcher
2020-05-12 16:23:18 -04:00
res.json({
2019-12-18 14:35:25 -05:00
relayerAddress: web3.eth.defaultAccount,
mixers,
2020-07-16 09:33:35 -04:00
gasPrices: await gasPriceOracle.gasPrices(),
2019-12-18 14:35:25 -05:00
netId,
ethPrices,
relayerServiceFee,
nonce,
2020-07-16 21:45:40 -04:00
version,
latestBlock
2019-12-18 14:35:25 -05:00
})
2019-11-23 03:18:54 -05:00
})
app.post('/relay', relayController)
let server = app.listen(port || 8000)
server.setTimeout(600000)
console.log('Gas price oracle started.')
fetcher.fetchPrices()
2019-12-03 08:26:16 -05:00
fetcher.fetchNonce()
2019-11-23 03:18:54 -05:00
console.log('Relayer started on port', port || 8000)
console.log(`relayerAddress: ${web3.eth.defaultAccount}`)
console.log(`mixers: ${JSON.stringify(mixers)}`)
console.log(`netId: ${netId}`)
2019-11-26 10:01:37 -05:00
console.log(`ethPrices: ${JSON.stringify(fetcher.ethPrices)}`)
2020-05-12 16:23:18 -04:00
const { GAS_PRICE_BUMP_PERCENTAGE, ALLOWABLE_PENDING_TX_TIMEOUT, NONCE_WATCHER_INTERVAL, MAX_GAS_PRICE } = process.env
2020-07-16 09:33:35 -04:00
if (!NONCE_WATCHER_INTERVAL) {
2020-05-12 16:23:18 -04:00
console.log(`NONCE_WATCHER_INTERVAL is not set. Using default value ${watherInterval / 1000} sec`)
}
2020-07-16 09:33:35 -04:00
if (!GAS_PRICE_BUMP_PERCENTAGE) {
2020-05-12 16:23:18 -04:00
console.log(`GAS_PRICE_BUMP_PERCENTAGE is not set. Using default value ${gasBumpPercentage}%`)
}
2020-07-16 09:33:35 -04:00
if (!ALLOWABLE_PENDING_TX_TIMEOUT) {
2020-05-12 16:23:18 -04:00
console.log(`ALLOWABLE_PENDING_TX_TIMEOUT is not set. Using default value ${pendingTxTimeout / 1000} sec`)
}
2020-07-16 09:33:35 -04:00
if (!MAX_GAS_PRICE) {
2020-05-12 16:23:18 -04:00
console.log(`ALLOWABLE_PENDING_TX_TIMEOUT is not set. Using default value ${maxGasPrice} Gwei`)
}