remove multicall

This commit is contained in:
Roman Storm 2021-03-01 20:38:16 -08:00
parent 77021a52a9
commit 0dd025bd30
No known key found for this signature in database
GPG Key ID: 522F2A785F34E71F
6 changed files with 73 additions and 90 deletions

View File

@ -1,22 +0,0 @@
[
{
"inputs": [
{
"components": [
{ "internalType": "address", "name": "to", "type": "address" },
{ "internalType": "bytes", "name": "data", "type": "bytes" }
],
"internalType": "struct MultiCall.Call[]",
"name": "calls",
"type": "tuple[]"
}
],
"name": "multicall",
"outputs": [
{ "internalType": "bytes[]", "name": "results", "type": "bytes[]" },
{ "internalType": "bool[]", "name": "success", "type": "bool[]" }
],
"stateMutability": "view",
"type": "function"
}
]

View File

@ -8,8 +8,7 @@ module.exports = {
httpRpcUrl: process.env.HTTP_RPC_URL, httpRpcUrl: process.env.HTTP_RPC_URL,
wsRpcUrl: process.env.WS_RPC_URL, wsRpcUrl: process.env.WS_RPC_URL,
oracleRpcUrl: process.env.ORACLE_RPC_URL || 'https://mainnet.infura.io/', oracleRpcUrl: process.env.ORACLE_RPC_URL || 'https://mainnet.infura.io/',
offchainOracleAddress: '0x080ab73787a8b13ec7f40bd7d00d6cc07f9b24d0', offchainOracleAddress: '0x080AB73787A8B13EC7F40bd7d00d6CC07F9b24d0',
multiCallAddress: '0xda3c19c6fe954576707fa24695efb830d9cca1ca',
aggregatorAddress: process.env.AGGREGATOR, aggregatorAddress: process.env.AGGREGATOR,
minerMerkleTreeHeight: 20, minerMerkleTreeHeight: 20,
privateKey: process.env.PRIVATE_KEY, privateKey: process.env.PRIVATE_KEY,

View File

@ -1,48 +1,42 @@
const Redis = require('ioredis') const Redis = require('ioredis')
const { redisUrl, offchainOracleAddress, multiCallAddress, oracleRpcUrl } = require('./config') const { redisUrl, offchainOracleAddress, oracleRpcUrl } = require('./config')
const { getArgsForOracle, setSafeInterval } = require('./utils') const { getArgsForOracle, setSafeInterval } = require('./utils')
const redis = new Redis(redisUrl) const redis = new Redis(redisUrl)
const Web3 = require('web3') const Web3 = require('web3')
const web3 = new Web3(oracleRpcUrl) const web3 = new Web3(oracleRpcUrl, {
timeout: 200000, // ms
})
const multiCallABI = require('../abis/MultiCall.abi.json')
const offchainOracleABI = require('../abis/OffchainOracle.abi.json') const offchainOracleABI = require('../abis/OffchainOracle.abi.json')
const offchainOracle = new web3.eth.Contract(offchainOracleABI) const offchainOracle = new web3.eth.Contract(offchainOracleABI, offchainOracleAddress)
const multiCall = new web3.eth.Contract(multiCallABI, multiCallAddress)
const { tokenAddresses, oneUintAmount, currencyLookup } = getArgsForOracle() const { tokenAddresses, oneUintAmount, currencyLookup } = getArgsForOracle()
const { toBN } = require('web3-utils') const { toBN } = require('web3-utils')
async function main() { async function main() {
const callData = tokenAddresses.map(address => ({ try {
to: offchainOracleAddress,
data: offchainOracle.methods
.getRate(
address,
'0x0000000000000000000000000000000000000000', // rate to ETH
)
.encodeABI(),
}))
const { results, success } = await multiCall.methods.multicall(callData).call()
const ethPrices = {} const ethPrices = {}
for (let i = 0; i < results.length; i++) { for (let i = 0; i < tokenAddresses.length; i++) {
if (!success[i]) { try {
continue const price = await offchainOracle.methods
} .getRate(tokenAddresses[i], '0x0000000000000000000000000000000000000000')
.call()
const decodedRate = web3.eth.abi.decodeParameter('uint256', results[i]).toString()
const numerator = toBN(oneUintAmount[i]) const numerator = toBN(oneUintAmount[i])
const denominator = toBN(10).pow(toBN(18)) // eth decimals const denominator = toBN(10).pow(toBN(18)) // eth decimals
const price = toBN(decodedRate).mul(numerator).div(denominator) const priceFormatted = toBN(price).mul(numerator).div(denominator)
ethPrices[currencyLookup[tokenAddresses[i]]] = price.toString() ethPrices[currencyLookup[tokenAddresses[i]]] = priceFormatted.toString()
} catch (e) {
console.error('cant get price of ', tokenAddresses[i])
}
} }
await redis.hmset('prices', ethPrices) await redis.hmset('prices', ethPrices)
console.log('Wrote following prices to redis', ethPrices) console.log('Wrote following prices to redis', ethPrices)
} catch (e) {
console.error('priceWatcher error', e)
}
} }
setSafeInterval(main, 30 * 1000) setSafeInterval(main, 30 * 1000)

View File

@ -22,6 +22,7 @@ let tree, eventSubscription, blockSubscription
// todo handle the situation when we have two rewards in one block // todo handle the situation when we have two rewards in one block
async function fetchEvents(from = 0, to = 'latest') { async function fetchEvents(from = 0, to = 'latest') {
try {
const events = await contract.getPastEvents('NewAccount', { const events = await contract.getPastEvents('NewAccount', {
fromBlock: from, fromBlock: from,
toBlock: to, toBlock: to,
@ -29,6 +30,9 @@ async function fetchEvents(from = 0, to = 'latest') {
return events return events
.sort((a, b) => a.returnValues.index - b.returnValues.index) .sort((a, b) => a.returnValues.index - b.returnValues.index)
.map(e => toBN(e.returnValues.commitment)) .map(e => toBN(e.returnValues.commitment))
} catch (e) {
console.error('error fetching events', e)
}
} }
async function processNewEvent(err, event) { async function processNewEvent(err, event) {
@ -95,6 +99,7 @@ async function rebuild() {
} }
async function init() { async function init() {
try {
console.log('Initializing') console.log('Initializing')
const miner = await resolver.resolve(torn.miningV2.address) const miner = await resolver.resolve(torn.miningV2.address)
contract = new web3.eth.Contract(MinerABI, miner) contract = new web3.eth.Contract(MinerABI, miner)
@ -105,6 +110,9 @@ async function init() {
eventSubscription = contract.events.NewAccount({ fromBlock: block + 1 }, processNewEvent) eventSubscription = contract.events.NewAccount({ fromBlock: block + 1 }, processNewEvent)
blockSubscription = web3.eth.subscribe('newBlockHeaders', processNewBlock) blockSubscription = web3.eth.subscribe('newBlockHeaders', processNewBlock)
await updateRedis() await updateRedis()
} catch (e) {
console.error('error on init treeWatcher', e.message)
}
} }
init() init()

View File

@ -3,7 +3,7 @@ const { poseidon } = require('circomlib')
const { toBN, toChecksumAddress, BN } = require('web3-utils') const { toBN, toChecksumAddress, BN } = require('web3-utils')
const TORN_TOKEN = { const TORN_TOKEN = {
tokenAddress: '0x77777feddddffc19ff86db637967013e6c6a116c', tokenAddress: '0x77777FeDdddFfC19Ff86DB637967013e6C6A116C',
symbol: 'TORN', symbol: 'TORN',
decimals: 18, decimals: 18,
} }

View File

@ -74,6 +74,7 @@ async function fetchTree() {
} }
async function start() { async function start() {
try {
web3 = new Web3(httpRpcUrl) web3 = new Web3(httpRpcUrl)
const { CONFIRMATIONS, MAX_GAS_PRICE } = process.env const { CONFIRMATIONS, MAX_GAS_PRICE } = process.env
txManager = new TxManager({ txManager = new TxManager({
@ -94,6 +95,9 @@ async function start() {
await controller.init() await controller.init()
queue.process(processJob) queue.process(processJob)
console.log('Worker started') console.log('Worker started')
} catch (e) {
console.error('error on start worker', e.message)
}
} }
function checkFee({ data }) { function checkFee({ data }) {