2019-05-08 16:12:02 +03:00
|
|
|
require('dotenv').config()
|
|
|
|
const BN = require('bignumber.js')
|
2020-10-29 11:25:43 +03:00
|
|
|
const Web3Utils = require('web3').utils
|
2019-05-08 16:12:02 +03:00
|
|
|
const logger = require('./logger')('getBalances')
|
2019-07-12 15:49:46 +03:00
|
|
|
const { BRIDGE_MODES } = require('../commons')
|
2020-11-04 14:24:42 +03:00
|
|
|
const { web3Home, web3Foreign, getHomeBlockNumber } = require('./utils/web3')
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2021-04-02 12:59:49 +03:00
|
|
|
const {
|
|
|
|
MONITOR_HOME_START_BLOCK,
|
|
|
|
MONITOR_FOREIGN_START_BLOCK,
|
|
|
|
COMMON_HOME_BRIDGE_ADDRESS,
|
|
|
|
COMMON_FOREIGN_BRIDGE_ADDRESS
|
|
|
|
} = process.env
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2021-05-08 18:50:46 +03:00
|
|
|
const { ERC20_ABI, BLOCK_REWARD_ABI, HOME_ERC_TO_NATIVE_ABI, FOREIGN_ERC_TO_NATIVE_ABI } = require('../commons')
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2020-11-04 14:24:42 +03:00
|
|
|
async function main(bridgeMode, eventsInfo) {
|
|
|
|
const {
|
2021-04-02 12:59:49 +03:00
|
|
|
homeBlockNumber,
|
|
|
|
foreignBlockNumber,
|
2020-11-04 14:24:42 +03:00
|
|
|
homeToForeignConfirmations,
|
|
|
|
homeDelayedBlockNumber,
|
|
|
|
foreignDelayedBlockNumber
|
|
|
|
} = eventsInfo
|
|
|
|
|
|
|
|
// Events in the ./utils/events.js are fetched for different block ranges,
|
|
|
|
// In order to be consistent with the balance values, the following values might be needed
|
|
|
|
|
|
|
|
// Foreign balance should represent all UserRequestForAffirmation events up to block `N - requiredBlockConfirmation()`
|
|
|
|
// and all RelayedMessage events up to block `N`.
|
|
|
|
// This constant tells the difference between bridge balance at block `N - requiredBlockConfirmation() + 1`
|
|
|
|
// and the actual value monitor is interested in.
|
|
|
|
const lateForeignConfirmationsTotalValue = BN.sum(
|
|
|
|
0,
|
|
|
|
...homeToForeignConfirmations.filter(e => e.blockNumber > foreignDelayedBlockNumber).map(e => e.value)
|
|
|
|
)
|
|
|
|
|
2021-04-02 12:59:49 +03:00
|
|
|
const blockRanges = {
|
|
|
|
startBlockHome: MONITOR_HOME_START_BLOCK,
|
|
|
|
endBlockHome: homeBlockNumber,
|
|
|
|
startBlockForeign: MONITOR_FOREIGN_START_BLOCK,
|
|
|
|
endBlockForeign: foreignBlockNumber
|
|
|
|
}
|
|
|
|
|
2021-05-08 18:50:46 +03:00
|
|
|
if (bridgeMode === BRIDGE_MODES.ERC_TO_NATIVE) {
|
2019-09-13 10:11:38 +03:00
|
|
|
const foreignBridge = new web3Foreign.eth.Contract(FOREIGN_ERC_TO_NATIVE_ABI, COMMON_FOREIGN_BRIDGE_ADDRESS)
|
2019-05-30 21:05:36 +03:00
|
|
|
const erc20Address = await foreignBridge.methods.erc20token().call()
|
|
|
|
const erc20Contract = new web3Foreign.eth.Contract(ERC20_ABI, erc20Address)
|
2020-02-18 19:17:01 +03:00
|
|
|
|
2019-05-30 21:05:36 +03:00
|
|
|
logger.debug('calling erc20Contract.methods.balanceOf')
|
2020-11-04 14:24:42 +03:00
|
|
|
const foreignErc20Balance = await erc20Contract.methods
|
|
|
|
.balanceOf(COMMON_FOREIGN_BRIDGE_ADDRESS)
|
|
|
|
.call({}, foreignDelayedBlockNumber)
|
2021-10-12 18:06:50 +03:00
|
|
|
let foreignErc20BalanceBN = new BN(foreignErc20Balance).plus(lateForeignConfirmationsTotalValue)
|
|
|
|
try {
|
|
|
|
logger.debug('calling foreignBridge.methods.investedAmount')
|
|
|
|
const invested = await foreignBridge.methods.investedAmount(erc20Address).call({}, foreignDelayedBlockNumber)
|
|
|
|
foreignErc20BalanceBN = foreignErc20BalanceBN.plus(invested)
|
|
|
|
} catch (_) {
|
|
|
|
logger.debug('compounding related methods are not present in the foreign bridge')
|
|
|
|
}
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2019-09-13 10:11:38 +03:00
|
|
|
const homeBridge = new web3Home.eth.Contract(HOME_ERC_TO_NATIVE_ABI, COMMON_HOME_BRIDGE_ADDRESS)
|
2019-05-30 21:05:36 +03:00
|
|
|
logger.debug('calling homeBridge.methods.blockRewardContract')
|
|
|
|
const blockRewardAddress = await homeBridge.methods.blockRewardContract().call()
|
|
|
|
const blockRewardContract = new web3Home.eth.Contract(BLOCK_REWARD_ABI, blockRewardAddress)
|
2020-11-04 14:24:42 +03:00
|
|
|
const homeBlockNumber = await getHomeBlockNumber()
|
2019-05-30 21:05:36 +03:00
|
|
|
logger.debug('calling blockReward.methods.mintedTotally')
|
2020-11-04 14:24:42 +03:00
|
|
|
const mintedCoins = await blockRewardContract.methods
|
|
|
|
.mintedTotallyByBridge(COMMON_HOME_BRIDGE_ADDRESS)
|
|
|
|
.call({}, homeBlockNumber)
|
2019-05-30 21:05:36 +03:00
|
|
|
logger.debug('calling homeBridge.methods.totalBurntCoins')
|
2020-11-04 14:24:42 +03:00
|
|
|
const burntCoins = await homeBridge.methods.totalBurntCoins().call({}, homeDelayedBlockNumber)
|
2019-05-30 21:05:36 +03:00
|
|
|
const mintedCoinsBN = new BN(mintedCoins)
|
|
|
|
const burntCoinsBN = new BN(burntCoins)
|
|
|
|
const totalSupplyBN = mintedCoinsBN.minus(burntCoinsBN)
|
2020-02-18 19:17:01 +03:00
|
|
|
|
2021-08-24 11:31:15 +03:00
|
|
|
const diff = foreignErc20BalanceBN.minus(totalSupplyBN).toFixed()
|
2019-05-30 21:05:36 +03:00
|
|
|
logger.debug('Done')
|
|
|
|
return {
|
|
|
|
home: {
|
|
|
|
totalSupply: Web3Utils.fromWei(totalSupplyBN.toFixed())
|
|
|
|
},
|
2021-08-24 11:31:15 +03:00
|
|
|
foreign: {
|
|
|
|
erc20Balance: Web3Utils.fromWei(foreignErc20Balance)
|
|
|
|
},
|
2019-05-30 21:05:36 +03:00
|
|
|
balanceDiff: Number(Web3Utils.fromWei(diff)),
|
2021-04-02 12:59:49 +03:00
|
|
|
...blockRanges,
|
2019-05-30 21:05:36 +03:00
|
|
|
lastChecked: Math.floor(Date.now() / 1000)
|
2019-05-08 16:12:02 +03:00
|
|
|
}
|
2019-10-21 15:57:28 +03:00
|
|
|
} else if (bridgeMode === BRIDGE_MODES.ARBITRARY_MESSAGE) {
|
|
|
|
return {
|
|
|
|
home: {},
|
|
|
|
foreign: {},
|
2021-04-02 12:59:49 +03:00
|
|
|
...blockRanges,
|
2019-10-21 15:57:28 +03:00
|
|
|
lastChecked: Math.floor(Date.now() / 1000)
|
|
|
|
}
|
2019-05-30 21:05:36 +03:00
|
|
|
} else {
|
|
|
|
throw new Error(`Unrecognized bridge mode: '${bridgeMode}'`)
|
2019-05-08 16:12:02 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = main
|