From 65e1f43539634c830d8e44571156e98bdd0ef224 Mon Sep 17 00:00:00 2001 From: Sameer Date: Tue, 30 Jan 2024 21:25:24 +0530 Subject: [PATCH] :bug: Consider locked balances for top accounts (#2019) --- .../shared/indexer/accountBalanceIndex.js | 18 +++++++++++++----- .../shared/indexer/genesisBlock.js | 12 ++++++++++-- 2 files changed, 23 insertions(+), 7 deletions(-) diff --git a/services/blockchain-indexer/shared/indexer/accountBalanceIndex.js b/services/blockchain-indexer/shared/indexer/accountBalanceIndex.js index 81bb7b1a06..da30feacb1 100644 --- a/services/blockchain-indexer/shared/indexer/accountBalanceIndex.js +++ b/services/blockchain-indexer/shared/indexer/accountBalanceIndex.js @@ -38,11 +38,19 @@ const updateAccountBalances = async address => { const accountBalancesTable = await getAccountBalancesTable(); const { data: balanceInfos } = await getTokenBalances({ address }); - const updatedTokenBalances = balanceInfos.map(balanceInfo => ({ - address, - tokenID: balanceInfo.tokenID, - balance: balanceInfo.availableBalance, - })); + const updatedTokenBalances = balanceInfos.map(balanceInfo => { + const { tokenID, availableBalance, lockedBalances } = balanceInfo; + const totalLockedBalance = lockedBalances.reduce( + (acc, entry) => BigInt(acc) + BigInt(entry.amount), + BigInt('0'), + ); + + return { + address, + tokenID, + balance: BigInt(availableBalance) + BigInt(totalLockedBalance), + }; + }); // Update all token balances of the address await accountBalancesTable.upsert(updatedTokenBalances); diff --git a/services/blockchain-indexer/shared/indexer/genesisBlock.js b/services/blockchain-indexer/shared/indexer/genesisBlock.js index 717c79fe12..1d5c0e2e4a 100644 --- a/services/blockchain-indexer/shared/indexer/genesisBlock.js +++ b/services/blockchain-indexer/shared/indexer/genesisBlock.js @@ -70,10 +70,18 @@ const indexTokenModuleAssets = async dbTrx => { // eslint-disable-next-line no-restricted-syntax for (const userInfo of userSubStoreInfos) { - const { address, availableBalance: balance, tokenID } = userInfo; + const { address, tokenID, availableBalance, lockedBalances } = userInfo; + const totalLockedBalance = lockedBalances.reduce( + (acc, entry) => BigInt(acc) + BigInt(entry.amount), + BigInt('0'), + ); // Add entry to index the genesis account balances - const accountBalanceEntry = { address, tokenID, balance }; + const accountBalanceEntry = { + address, + tokenID, + balance: BigInt(availableBalance) + BigInt(totalLockedBalance), + }; genesisAccountBalances.push(accountBalanceEntry); // eslint-disable-next-line no-restricted-syntax