2019-05-08 16:12:02 +03:00
|
|
|
require('dotenv').config()
|
|
|
|
const logger = require('../logger')('eventsUtils')
|
2019-07-12 15:49:46 +03:00
|
|
|
const {
|
|
|
|
BRIDGE_MODES,
|
|
|
|
getBridgeABIs,
|
|
|
|
getBridgeMode,
|
2021-05-08 18:50:46 +03:00
|
|
|
HOME_ERC_TO_NATIVE_ABI,
|
2019-07-26 15:26:14 +03:00
|
|
|
ERC20_ABI,
|
2020-06-10 16:22:01 +03:00
|
|
|
ZERO_ADDRESS,
|
|
|
|
OLD_AMB_USER_REQUEST_FOR_SIGNATURE_ABI,
|
|
|
|
OLD_AMB_USER_REQUEST_FOR_AFFIRMATION_ABI
|
2019-07-12 15:49:46 +03:00
|
|
|
} = require('../../commons')
|
2019-10-29 22:22:02 +03:00
|
|
|
const { normalizeEventInformation } = require('./message')
|
2020-05-07 20:42:27 +03:00
|
|
|
const { writeFile, readCacheFile } = require('./file')
|
2020-11-04 14:24:42 +03:00
|
|
|
const { web3Home, web3Foreign, getHomeBlockNumber, getForeignBlockNumber } = require('./web3')
|
|
|
|
const { getPastEvents } = require('./web3Cache')
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2020-10-29 11:25:43 +03:00
|
|
|
const { COMMON_HOME_BRIDGE_ADDRESS, COMMON_FOREIGN_BRIDGE_ADDRESS, MONITOR_CACHE_EVENTS } = process.env
|
2020-11-04 14:24:42 +03:00
|
|
|
const MONITOR_HOME_START_BLOCK = Number(process.env.MONITOR_HOME_START_BLOCK) || 0
|
|
|
|
const MONITOR_FOREIGN_START_BLOCK = Number(process.env.MONITOR_FOREIGN_START_BLOCK) || 0
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2020-05-07 20:42:27 +03:00
|
|
|
const cacheFilePath = '/tmp/cachedEvents.json'
|
2019-05-31 21:35:50 +03:00
|
|
|
async function main(mode) {
|
2020-05-07 20:42:27 +03:00
|
|
|
if (MONITOR_CACHE_EVENTS === 'true') {
|
|
|
|
logger.debug('checking existing events cache')
|
|
|
|
const cachedEvents = readCacheFile(cacheFilePath)
|
|
|
|
if (cachedEvents !== false) {
|
|
|
|
logger.debug('returning events stored in cache')
|
|
|
|
return cachedEvents
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-08 18:50:46 +03:00
|
|
|
const homeErcBridge = new web3Home.eth.Contract(HOME_ERC_TO_NATIVE_ABI, COMMON_HOME_BRIDGE_ADDRESS)
|
2019-05-31 21:35:50 +03:00
|
|
|
const bridgeMode = mode || (await getBridgeMode(homeErcBridge))
|
|
|
|
const { HOME_ABI, FOREIGN_ABI } = getBridgeABIs(bridgeMode)
|
2019-09-13 10:11:38 +03:00
|
|
|
const homeBridge = new web3Home.eth.Contract(HOME_ABI, COMMON_HOME_BRIDGE_ADDRESS)
|
|
|
|
const foreignBridge = new web3Foreign.eth.Contract(FOREIGN_ABI, COMMON_FOREIGN_BRIDGE_ADDRESS)
|
2021-05-08 18:50:46 +03:00
|
|
|
let isExternalErc20 = false
|
2019-09-18 22:45:13 +03:00
|
|
|
let erc20Contract
|
2019-12-19 12:39:41 +03:00
|
|
|
let erc20Address
|
2019-10-29 22:22:02 +03:00
|
|
|
let normalizeEvent = normalizeEventInformation
|
2019-09-18 22:45:13 +03:00
|
|
|
if (bridgeMode !== BRIDGE_MODES.ARBITRARY_MESSAGE) {
|
2021-05-08 18:50:46 +03:00
|
|
|
erc20Address = await foreignBridge.methods.erc20token().call()
|
|
|
|
isExternalErc20 = true
|
2019-09-18 22:45:13 +03:00
|
|
|
erc20Contract = new web3Foreign.eth.Contract(ERC20_ABI, erc20Address)
|
2019-10-29 22:22:02 +03:00
|
|
|
} else {
|
|
|
|
normalizeEvent = e => e
|
2019-09-18 22:45:13 +03:00
|
|
|
}
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2019-05-31 21:35:50 +03:00
|
|
|
logger.debug('getting last block numbers')
|
2020-11-04 14:24:42 +03:00
|
|
|
const homeBlockNumber = await getHomeBlockNumber()
|
|
|
|
const foreignBlockNumber = await getForeignBlockNumber()
|
|
|
|
const homeConfirmations = await homeBridge.methods.requiredBlockConfirmations().call()
|
|
|
|
const foreignConfirmations = await foreignBridge.methods.requiredBlockConfirmations().call()
|
|
|
|
const homeDelayedBlockNumber = homeBlockNumber - homeConfirmations
|
|
|
|
const foreignDelayedBlockNumber = foreignBlockNumber - foreignConfirmations
|
2020-10-05 15:48:36 +03:00
|
|
|
|
2020-06-10 16:22:01 +03:00
|
|
|
let homeToForeignRequests = []
|
|
|
|
let foreignToHomeRequests = []
|
|
|
|
let homeMigrationBlock = MONITOR_HOME_START_BLOCK
|
|
|
|
let foreignMigrationBlock = MONITOR_FOREIGN_START_BLOCK
|
|
|
|
|
|
|
|
if (bridgeMode === BRIDGE_MODES.ARBITRARY_MESSAGE) {
|
|
|
|
const oldHomeBridge = new web3Home.eth.Contract(OLD_AMB_USER_REQUEST_FOR_SIGNATURE_ABI, COMMON_HOME_BRIDGE_ADDRESS)
|
|
|
|
const oldForeignBridge = new web3Foreign.eth.Contract(
|
|
|
|
OLD_AMB_USER_REQUEST_FOR_AFFIRMATION_ABI,
|
|
|
|
COMMON_FOREIGN_BRIDGE_ADDRESS
|
|
|
|
)
|
|
|
|
|
|
|
|
logger.debug("calling oldHomeBridge.getPastEvents('UserRequestForSignature(bytes)')")
|
|
|
|
homeToForeignRequests = (await getPastEvents(oldHomeBridge, {
|
|
|
|
event: 'UserRequestForSignature',
|
|
|
|
fromBlock: MONITOR_HOME_START_BLOCK,
|
2020-11-04 14:24:42 +03:00
|
|
|
toBlock: homeDelayedBlockNumber,
|
|
|
|
chain: 'home'
|
2020-06-10 16:22:01 +03:00
|
|
|
})).map(normalizeEvent)
|
|
|
|
logger.debug(`found ${homeToForeignRequests.length} events`)
|
|
|
|
if (homeToForeignRequests.length > 0) {
|
2020-11-04 14:24:42 +03:00
|
|
|
homeMigrationBlock = Math.max(...homeToForeignRequests.map(x => x.blockNumber))
|
2020-06-10 16:22:01 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
logger.debug("calling oldForeignBridge.getPastEvents('UserRequestForAffirmation(bytes)')")
|
|
|
|
foreignToHomeRequests = (await getPastEvents(oldForeignBridge, {
|
|
|
|
event: 'UserRequestForAffirmation',
|
|
|
|
fromBlock: MONITOR_FOREIGN_START_BLOCK,
|
2020-11-04 14:24:42 +03:00
|
|
|
toBlock: foreignDelayedBlockNumber,
|
|
|
|
chain: 'foreign'
|
2020-06-10 16:22:01 +03:00
|
|
|
})).map(normalizeEvent)
|
|
|
|
logger.debug(`found ${foreignToHomeRequests.length} events`)
|
|
|
|
if (foreignToHomeRequests.length > 0) {
|
2020-11-04 14:24:42 +03:00
|
|
|
foreignMigrationBlock = Math.max(...foreignToHomeRequests.map(x => x.blockNumber))
|
2020-06-10 16:22:01 +03:00
|
|
|
}
|
|
|
|
}
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2019-05-31 21:35:50 +03:00
|
|
|
logger.debug("calling homeBridge.getPastEvents('UserRequestForSignature')")
|
2020-06-10 16:22:01 +03:00
|
|
|
const homeToForeignRequestsNew = (await getPastEvents(homeBridge, {
|
2021-05-08 18:50:46 +03:00
|
|
|
event: 'UserRequestForSignature',
|
2020-06-10 16:22:01 +03:00
|
|
|
fromBlock: homeMigrationBlock,
|
2020-11-04 14:24:42 +03:00
|
|
|
toBlock: homeDelayedBlockNumber,
|
|
|
|
chain: 'home'
|
2019-10-29 22:22:02 +03:00
|
|
|
})).map(normalizeEvent)
|
2020-06-10 16:22:01 +03:00
|
|
|
homeToForeignRequests = [...homeToForeignRequests, ...homeToForeignRequestsNew]
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2019-05-31 21:35:50 +03:00
|
|
|
logger.debug("calling foreignBridge.getPastEvents('RelayedMessage')")
|
2019-10-29 22:22:02 +03:00
|
|
|
const homeToForeignConfirmations = (await getPastEvents(foreignBridge, {
|
2021-05-08 18:50:46 +03:00
|
|
|
event: 'RelayedMessage',
|
2019-09-13 10:11:38 +03:00
|
|
|
fromBlock: MONITOR_FOREIGN_START_BLOCK,
|
2020-11-04 14:24:42 +03:00
|
|
|
toBlock: foreignBlockNumber,
|
|
|
|
chain: 'foreign',
|
|
|
|
safeToBlock: foreignDelayedBlockNumber
|
2019-10-29 22:22:02 +03:00
|
|
|
})).map(normalizeEvent)
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2019-05-31 21:35:50 +03:00
|
|
|
logger.debug("calling homeBridge.getPastEvents('AffirmationCompleted')")
|
2019-10-29 22:22:02 +03:00
|
|
|
const foreignToHomeConfirmations = (await getPastEvents(homeBridge, {
|
2021-05-08 18:50:46 +03:00
|
|
|
event: 'AffirmationCompleted',
|
2019-09-13 10:11:38 +03:00
|
|
|
fromBlock: MONITOR_HOME_START_BLOCK,
|
2020-11-04 14:24:42 +03:00
|
|
|
toBlock: homeBlockNumber,
|
|
|
|
chain: 'home',
|
|
|
|
safeToBlock: homeDelayedBlockNumber
|
2019-10-29 22:22:02 +03:00
|
|
|
})).map(normalizeEvent)
|
2019-05-08 16:12:02 +03:00
|
|
|
|
2019-05-31 21:35:50 +03:00
|
|
|
logger.debug("calling foreignBridge.getPastEvents('UserRequestForAffirmation')")
|
2020-06-10 16:22:01 +03:00
|
|
|
const foreignToHomeRequestsNew = (await getPastEvents(foreignBridge, {
|
2021-05-08 18:50:46 +03:00
|
|
|
event: 'UserRequestForAffirmation',
|
2020-06-10 16:22:01 +03:00
|
|
|
fromBlock: foreignMigrationBlock,
|
2020-11-04 14:24:42 +03:00
|
|
|
toBlock: foreignDelayedBlockNumber,
|
|
|
|
chain: 'foreign'
|
2019-10-29 22:22:02 +03:00
|
|
|
})).map(normalizeEvent)
|
2020-06-10 16:22:01 +03:00
|
|
|
foreignToHomeRequests = [...foreignToHomeRequests, ...foreignToHomeRequestsNew]
|
|
|
|
|
2021-05-26 17:58:20 +03:00
|
|
|
let informationRequests
|
|
|
|
let informationResponses
|
|
|
|
if (bridgeMode === BRIDGE_MODES.ARBITRARY_MESSAGE) {
|
|
|
|
logger.debug("calling homeBridge.getPastEvents('UserRequestForInformation')")
|
|
|
|
informationRequests = (await getPastEvents(homeBridge, {
|
|
|
|
event: 'UserRequestForInformation',
|
|
|
|
fromBlock: MONITOR_HOME_START_BLOCK,
|
|
|
|
toBlock: homeDelayedBlockNumber,
|
|
|
|
chain: 'home'
|
|
|
|
})).map(normalizeEvent)
|
|
|
|
|
|
|
|
logger.debug("calling foreignBridge.getPastEvents('InformationRetrieved')")
|
|
|
|
informationResponses = (await getPastEvents(homeBridge, {
|
|
|
|
event: 'InformationRetrieved',
|
|
|
|
fromBlock: MONITOR_HOME_START_BLOCK,
|
|
|
|
toBlock: homeBlockNumber,
|
|
|
|
safeToBlock: homeDelayedBlockNumber,
|
|
|
|
chain: 'home'
|
|
|
|
})).map(normalizeEvent)
|
|
|
|
}
|
|
|
|
|
2019-10-29 22:22:02 +03:00
|
|
|
if (isExternalErc20) {
|
|
|
|
logger.debug("calling erc20Contract.getPastEvents('Transfer')")
|
2019-11-06 22:49:01 +03:00
|
|
|
let transferEvents = (await getPastEvents(erc20Contract, {
|
2019-10-29 22:22:02 +03:00
|
|
|
event: 'Transfer',
|
|
|
|
fromBlock: MONITOR_FOREIGN_START_BLOCK,
|
2020-10-05 15:48:36 +03:00
|
|
|
toBlock: foreignDelayedBlockNumber,
|
2019-10-29 22:22:02 +03:00
|
|
|
options: {
|
|
|
|
filter: { to: COMMON_FOREIGN_BRIDGE_ADDRESS }
|
2020-11-04 14:24:42 +03:00
|
|
|
},
|
|
|
|
chain: 'foreign'
|
2021-08-24 11:31:15 +03:00
|
|
|
}))
|
|
|
|
.map(normalizeEvent)
|
|
|
|
.filter(e => e.recipient !== ZERO_ADDRESS) // filter mint operation during SCD-to-MCD swaps
|
|
|
|
.filter(e => e.recipient.toLowerCase() !== '0x5d3a536e4d6dbd6114cc1ead35777bab948e3643') // filter cDai withdraws during compounding
|
|
|
|
|
|
|
|
// Get transfer events for each previously used Sai token
|
|
|
|
const saiTokenAddress = '0x89d24A6b4CcB1B6fAA2625fE562bDD9a23260359'
|
|
|
|
const halfDuplexTokenContract = new web3Foreign.eth.Contract(ERC20_ABI, saiTokenAddress)
|
|
|
|
logger.debug('Half duplex token:', saiTokenAddress)
|
|
|
|
logger.debug("calling halfDuplexTokenContract.getPastEvents('Transfer')")
|
|
|
|
// https://etherscan.io/tx/0xd0c3c92c94e05bc71256055ce8c4c993e047f04e04f3283a04e4cb077b71f6c6
|
|
|
|
const blockNumberHalfDuplexDisabled = 9884448
|
|
|
|
const halfDuplexTransferEvents = (await getPastEvents(halfDuplexTokenContract, {
|
|
|
|
event: 'Transfer',
|
|
|
|
fromBlock: MONITOR_FOREIGN_START_BLOCK,
|
|
|
|
toBlock: Math.min(blockNumberHalfDuplexDisabled, foreignDelayedBlockNumber),
|
|
|
|
options: {
|
|
|
|
filter: { to: COMMON_FOREIGN_BRIDGE_ADDRESS }
|
|
|
|
},
|
|
|
|
chain: 'foreign'
|
2019-10-29 22:22:02 +03:00
|
|
|
})).map(normalizeEvent)
|
|
|
|
|
2021-08-24 11:31:15 +03:00
|
|
|
transferEvents = [...halfDuplexTransferEvents, ...transferEvents]
|
2020-05-17 17:57:49 +03:00
|
|
|
|
2019-10-29 22:22:02 +03:00
|
|
|
// Get transfer events that didn't have a UserRequestForAffirmation event in the same transaction
|
2021-08-24 11:31:15 +03:00
|
|
|
const directTransfers = transferEvents.filter(
|
2019-10-29 22:22:02 +03:00
|
|
|
e => foreignToHomeRequests.findIndex(t => t.referenceTx === e.referenceTx) === -1
|
|
|
|
)
|
|
|
|
|
2020-05-17 17:57:49 +03:00
|
|
|
foreignToHomeRequests = [...foreignToHomeRequests, ...directTransfers]
|
2019-10-29 22:22:02 +03:00
|
|
|
}
|
|
|
|
|
2019-05-31 21:35:50 +03:00
|
|
|
logger.debug('Done')
|
2020-05-07 20:42:27 +03:00
|
|
|
const result = {
|
2019-09-18 22:45:13 +03:00
|
|
|
homeToForeignRequests,
|
|
|
|
homeToForeignConfirmations,
|
|
|
|
foreignToHomeConfirmations,
|
|
|
|
foreignToHomeRequests,
|
2021-05-26 17:58:20 +03:00
|
|
|
informationRequests,
|
|
|
|
informationResponses,
|
2019-09-18 22:45:13 +03:00
|
|
|
isExternalErc20,
|
2020-11-04 14:24:42 +03:00
|
|
|
bridgeMode,
|
2021-04-02 12:59:49 +03:00
|
|
|
homeBlockNumber,
|
|
|
|
foreignBlockNumber,
|
2020-11-04 14:24:42 +03:00
|
|
|
homeDelayedBlockNumber,
|
|
|
|
foreignDelayedBlockNumber
|
2019-05-08 16:12:02 +03:00
|
|
|
}
|
2020-05-07 20:42:27 +03:00
|
|
|
|
|
|
|
if (MONITOR_CACHE_EVENTS === 'true') {
|
|
|
|
logger.debug('saving obtained events into cache file')
|
2021-04-02 12:59:49 +03:00
|
|
|
writeFile(cacheFilePath, result, { useCwd: false })
|
2020-05-07 20:42:27 +03:00
|
|
|
}
|
|
|
|
return result
|
2019-05-08 16:12:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = main
|