8b010f887d
* Add console.table * First steps in validate script * env rename * Added parameter names * Descriptions * Print and configuration * Added more parameters * Rename gas oracle to gas supplier * More changes * Removed env examples for now * RPC rename * Bridge address rename * More changes * jobs * Renames * Typo * jobs * Changes * jobs * Changes * Monitor changes * jovs * Typo * Changes * REACT_APP_ env prefix * Typo * Rollback changes * Oracle deployment * Defaults * Monitor * Naming * Typo * Typo * Envs * ui deployment * ALl jobs * Vars in ultimate * Lint * Lint * Lint * Another way to add REACT_APP prefixing * Unnecessary mapping * No output timeout * No output timeout * Got rid of ERC20_TOKEN_ADDRESS * Configuration readme * Configuration * Prefixes * timeout * Docs * Docs * docs * docs * docs * Roll back ERC20_TOKEN_ADDRESS for erc-to-erc * Typo * lint * Rollback * ROllback validator * Rollback yarn.lock * dai and wetc update * Rollback ERC20_TOKEN_ADDRESS * erc to native * examples * all jobs * roll back * roll back ERC20_TOKEN_ADDRESS: "0xdbeE25CbE97e4A5CC6c499875774dc7067E9426B" * ui env example * typo * Allow rpc for ultimate * Test * ERC20_TOKEN_ADDRESS rollback * Specify port * React port * All jobs * cosmetics * Values * Restore erc20 token * Rearrange example for easier comparision * Rearrange ultimate for easier comparision * Rearrange for easier comparision * Refactor * Conditional app styles * Loading environment variables in react app * Add missing vars for UI in wetc and dai * Bring back test parameters readme * Readme for monitor vars * Reading environment variables in e2e-commons (#207)
106 lines
2.9 KiB
JavaScript
106 lines
2.9 KiB
JavaScript
require('dotenv').config()
|
|
const express = require('express')
|
|
const fs = require('fs')
|
|
const { isV1Bridge } = require('./utils/serverUtils')
|
|
|
|
const app = express()
|
|
|
|
const MONITOR_TX_NUMBER_THRESHOLD = Number(process.env.MONITOR_TX_NUMBER_THRESHOLD) || 100
|
|
console.log('MONITOR_TX_NUMBER_THRESHOLD = ' + MONITOR_TX_NUMBER_THRESHOLD)
|
|
|
|
async function readFile(path) {
|
|
try {
|
|
const content = await fs.readFileSync(path)
|
|
const json = JSON.parse(content)
|
|
const timeDiff = Math.floor(Date.now() / 1000) - json.lastChecked
|
|
return Object.assign({}, json, { timeDiff })
|
|
} catch (e) {
|
|
console.error(e)
|
|
return {
|
|
error: 'please check your worker'
|
|
}
|
|
}
|
|
}
|
|
|
|
async function initV1routes(app) {
|
|
const exposeV1Routes = await isV1Bridge()
|
|
if (exposeV1Routes) {
|
|
app.get('/stuckTransfers', async (req, res, next) => {
|
|
try {
|
|
const results = await readFile('./responses/stuckTransfers.json')
|
|
results.ok = results.total.length === 0
|
|
res.json(results)
|
|
} catch (e) {
|
|
next(e)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
app.get('/', async (req, res, next) => {
|
|
try {
|
|
const results = await readFile('./responses/getBalances.json')
|
|
res.json(results)
|
|
} catch (e) {
|
|
// this will eventually be handled by your error handling middleware
|
|
next(e)
|
|
}
|
|
})
|
|
|
|
app.get('/validators', async (req, res, next) => {
|
|
try {
|
|
const results = await readFile('./responses/validators.json')
|
|
results.homeOk = true
|
|
results.foreignOk = true
|
|
for (const hv in results.home.validators) {
|
|
if (results.home.validators[hv].leftTx < MONITOR_TX_NUMBER_THRESHOLD) {
|
|
results.homeOk = false
|
|
break
|
|
}
|
|
}
|
|
for (const hv in results.foreign.validators) {
|
|
if (results.foreign.validators[hv].leftTx < MONITOR_TX_NUMBER_THRESHOLD) {
|
|
results.foreignOk = false
|
|
break
|
|
}
|
|
}
|
|
results.ok = results.homeOk && results.foreignOk
|
|
res.json(results)
|
|
} catch (e) {
|
|
// this will eventually be handled by your error handling middleware
|
|
next(e)
|
|
}
|
|
})
|
|
|
|
// responses/eventsStats.json
|
|
app.get('/eventsStats', async (req, res, next) => {
|
|
try {
|
|
const results = await readFile('./responses/eventsStats.json')
|
|
results.ok =
|
|
results.onlyInHomeDeposits.length === 0 &&
|
|
results.onlyInForeignDeposits.length === 0 &&
|
|
results.onlyInHomeWithdrawals.length === 0 &&
|
|
results.onlyInForeignWithdrawals.length === 0
|
|
res.json(results)
|
|
} catch (e) {
|
|
// this will eventually be handled by your error handling middleware
|
|
next(e)
|
|
}
|
|
})
|
|
|
|
app.get('/alerts', async (req, res, next) => {
|
|
try {
|
|
const results = await readFile('./responses/alerts.json')
|
|
results.ok = !results.executeAffirmations.mostRecentTxHash && !results.executeSignatures.mostRecentTxHash
|
|
res.json(results)
|
|
} catch (e) {
|
|
next(e)
|
|
}
|
|
})
|
|
|
|
initV1routes(app)
|
|
|
|
const port = process.env.MONITOR_PORT || 3003
|
|
app.set('port', port)
|
|
app.listen(port, () => console.log(`Monitoring app listening on port ${port}!`))
|