2019-11-23 03:18:54 -05:00
|
|
|
const express = require('express')
|
2020-05-12 16:23:18 -04:00
|
|
|
const {
|
|
|
|
netId,
|
|
|
|
port,
|
|
|
|
relayerServiceFee,
|
|
|
|
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')
|
2020-08-12 07:15:28 -04:00
|
|
|
const { version } = require('../package.json')
|
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
|
2020-08-04 03:39:56 -04:00
|
|
|
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
|
|
|
})
|
|
|
|
|
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()
|
2020-08-04 03:39:56 -04:00
|
|
|
} catch (e) {
|
2020-07-16 21:45:40 -04:00
|
|
|
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)
|
2020-08-12 07:15:28 -04:00
|
|
|
console.log('Version:', version)
|
2019-12-13 07:32:09 -05:00
|
|
|
let server = app.listen(port || 8000)
|
|
|
|
server.setTimeout(600000)
|
2019-11-25 04:50:15 -05:00
|
|
|
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
|
|
|
|
2020-08-04 03:39:56 -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`)
|
|
|
|
}
|