From ee2841582d5cfb8fc06ae499c51b14544aafd483 Mon Sep 17 00:00:00 2001 From: Paul <108695806+pxrl@users.noreply.github.com> Date: Fri, 10 May 2024 15:37:28 +0200 Subject: [PATCH] fix(Monitor): Be robust to whacky output tokens (#1503) Dong-Ha identified that a deposit on Arbitrum incorrectly used the Arbitrum USDC.e address as the outputToken for a fill on Arbitrum. In case the outputToken can't be resolved, fall back to using the address and log the raw amount. --- src/monitor/Monitor.ts | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/src/monitor/Monitor.ts b/src/monitor/Monitor.ts index 0289b9e0f..17e121887 100644 --- a/src/monitor/Monitor.ts +++ b/src/monitor/Monitor.ts @@ -192,9 +192,18 @@ export class Monitor { const chainId = parseInt(chainIdStr); mrkdwn += `*Destination: ${getNetworkName(chainId)}*\n`; for (const tokenAddress of Object.keys(amountByToken)) { - const { symbol, decimals } = this.clients.hubPoolClient.getTokenInfoForAddress(tokenAddress, chainId); + let symbol: string; + let unfilledAmount: string; + try { + let decimals: number; + ({ symbol, decimals } = this.clients.hubPoolClient.getTokenInfoForAddress(tokenAddress, chainId)); + unfilledAmount = convertFromWei(amountByToken[tokenAddress].toString(), decimals); + } catch { + symbol = tokenAddress; // Using the address helps investigation. + unfilledAmount = amountByToken[tokenAddress].toString(); + } + // Convert to number of tokens for readability. - const unfilledAmount = convertFromWei(amountByToken[tokenAddress].toString(), decimals); mrkdwn += `${symbol}: ${unfilledAmount}\n`; } }