This commit is contained in:
poma 2019-12-03 20:26:16 +07:00
parent ced0b6a738
commit e326186364
No known key found for this signature in database
GPG Key ID: BA20CB01FE165657
4 changed files with 24 additions and 17 deletions

View File

@ -4,6 +4,7 @@ module.exports = {
netId: Number(process.env.NET_ID) || 42, netId: Number(process.env.NET_ID) || 42,
rpcUrl: process.env.RPC_URL || 'https://kovan.infura.io/v3/a3f4d001c1fc4a359ea70dd27fd9cb51', rpcUrl: process.env.RPC_URL || 'https://kovan.infura.io/v3/a3f4d001c1fc4a359ea70dd27fd9cb51',
privateKey: process.env.PRIVATE_KEY, privateKey: process.env.PRIVATE_KEY,
nonce: 0,
mixers: { mixers: {
netId1: { netId1: {
dai: { dai: {

View File

@ -3,6 +3,7 @@ const fetch = require('node-fetch')
const { toWei } = require('web3-utils') const { toWei } = require('web3-utils')
const { gasOracleUrls, defaultGasPrice } = require('../config') const { gasOracleUrls, defaultGasPrice } = require('../config')
const { getMainnetTokens } = require('./utils') const { getMainnetTokens } = require('./utils')
const config = require ('../config')
class Fetcher { class Fetcher {
@ -62,6 +63,9 @@ class Fetcher {
setTimeout(() => this.fetchGasPrice({ oracleIndex }), 15000) setTimeout(() => this.fetchGasPrice({ oracleIndex }), 15000)
} }
} }
async fetchNonce() {
config.nonce = await this.web3.eth.getTransactionCount(this.web3.eth.defaultAccount)
}
} }
module.exports = Fetcher module.exports = Fetcher

View File

@ -39,6 +39,7 @@ app.listen(port || 8000)
console.log('Gas price oracle started.') console.log('Gas price oracle started.')
fetcher.fetchGasPrice() fetcher.fetchGasPrice()
fetcher.fetchPrices() fetcher.fetchPrices()
fetcher.fetchNonce()
console.log('Relayer started on port', port || 8000) console.log('Relayer started on port', port || 8000)
console.log(`relayerAddress: ${web3.eth.defaultAccount}`) console.log(`relayerAddress: ${web3.eth.defaultAccount}`)

View File

@ -3,6 +3,7 @@ const mixerABI = require('../abis/mixerABI.json')
const { const {
isValidProof, isValidArgs, isKnownContract, isEnoughFee isValidProof, isValidArgs, isKnownContract, isEnoughFee
} = require('./utils') } = require('./utils')
const config = require('../config')
const { web3, fetcher } = require('./instances') const { web3, fetcher } = require('./instances')
@ -57,16 +58,7 @@ async function relay (req, resp) {
return resp.status(400).json({ error: 'The merkle root is too old or invalid.' }) return resp.status(400).json({ error: 'The merkle root is too old or invalid.' })
} }
const withdrawArgs = [ let gas = await mixer.methods.withdraw(proof, ...args).estimateGas({
proof,
root,
nullifierHash,
recipient,
relayer,
fee.toString(),
refund.toString()
]
let gas = await mixer.methods.withdraw(...withdrawArgs).estimateGas({
from: web3.eth.defaultAccount, from: web3.eth.defaultAccount,
value: refund value: refund
}) })
@ -79,22 +71,31 @@ async function relay (req, resp) {
return resp.status(400).json({ error: reason }) return resp.status(400).json({ error: reason })
} }
const result = mixer.methods.withdraw(...withdrawArgs).send({ const data = mixer.methods.withdraw(proof, ...args).encodeABI()
const tx = {
from: web3.eth.defaultAccount, from: web3.eth.defaultAccount,
value: refund, value: numberToHex(refund),
gas: numberToHex(gas), gas: numberToHex(gas),
gasPrice: toHex(toWei(gasPrices.fast.toString(), 'gwei')), gasPrice: toHex(toWei(gasPrices.fast.toString(), 'gwei')),
// TODO: nonce to: mixer._address,
}) netId: config.netId,
data,
nonce: config.nonce
}
config.nonce++
let signedTx = await web3.eth.accounts.signTransaction(tx, config.privateKey)
let result = web3.eth.sendSignedTransaction(signedTx.rawTransaction)
result.once('transactionHash', function(txHash){ result.once('transactionHash', function(txHash){
resp.json({ txHash }) resp.json({ txHash })
console.log(`A new successfuly sent tx ${txHash} for the ${recipient}`) console.log(`A new successfully sent tx ${txHash} for the ${recipient}`)
}).on('error', function(e){ }).on('error', function(e){
config.nonce--
console.log(e) console.log(e)
return resp.status(400).json({ error: 'Proof is malformed.' }) return resp.status(400).json({ error: 'Proof is malformed.' })
}) })
} catch (e) { } catch (e) {
console.error(e.message, 'estimate gas failed') console.error(e, 'estimate gas failed')
return resp.status(400).json({ error: 'Proof is malformed or spent.' }) return resp.status(400).json({ error: 'Proof is malformed or spent.' })
} }
} }