From e0a18e28b7a05e1bbfe60407d620e416c8a86d2a Mon Sep 17 00:00:00 2001 From: Enzo Cioppettini <48031343+ecioppettini@users.noreply.github.com> Date: Fri, 3 May 2024 16:24:32 -0300 Subject: [PATCH] small refactor --- .../paima-funnel/src/funnels/parallelEvm/funnel.ts | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/packages/engine/paima-funnel/src/funnels/parallelEvm/funnel.ts b/packages/engine/paima-funnel/src/funnels/parallelEvm/funnel.ts index 919345fd..d5f9c7ff 100644 --- a/packages/engine/paima-funnel/src/funnels/parallelEvm/funnel.ts +++ b/packages/engine/paima-funnel/src/funnels/parallelEvm/funnel.ts @@ -15,6 +15,10 @@ import { getLatestProcessedCdeBlockheight } from '@paima/db'; const GET_BLOCK_NUMBER_TIMEOUT = 5000; +function applyDelay(config: OtherEvmConfig, baseTimestamp: number): number { + return Math.min(baseTimestamp - (config.delay ?? 0), 0); +} + export class ParallelEvmFunnel extends BaseFunnel implements ChainFunnel { config: OtherEvmConfig; chainName: string; @@ -52,7 +56,7 @@ export class ParallelEvmFunnel extends BaseFunnel implements ChainFunnel { // filter the data so that we are sure we can get all the blocks in the range for (const data of cachedState.bufferedChainData) { - if (data.timestamp - (this.config.delay ?? 0) <= Number(latestBlock.timestamp)) { + if (applyDelay(this.config, data.timestamp) <= Number(latestBlock.timestamp)) { chainData.push(data); } } @@ -88,7 +92,7 @@ export class ParallelEvmFunnel extends BaseFunnel implements ChainFunnel { const ts = Number(block.timestamp); const earliestParallelChainBlock = await findBlockByTimestamp( this.web3, - ts - (this.config.delay ?? 0), + applyDelay(this.config, ts), this.chainName ); // earliestParallelChainBlock is the earliest block that we might need to include @@ -97,7 +101,7 @@ export class ParallelEvmFunnel extends BaseFunnel implements ChainFunnel { } } - const maxTimestamp = chainData[chainData.length - 1].timestamp - (this.config.delay ?? 0); + const maxTimestamp = applyDelay(this.config, chainData[chainData.length - 1].timestamp); const blocks = []; @@ -210,7 +214,7 @@ export class ParallelEvmFunnel extends BaseFunnel implements ChainFunnel { for (const parallelChainBlock of cachedState.timestampToBlockNumber) { while (currIndex < chainData.length) { - if (chainData[currIndex].timestamp - (this.config.delay ?? 0) >= parallelChainBlock[0]) { + if (applyDelay(this.config, chainData[currIndex].timestamp) >= parallelChainBlock[0]) { sidechainToMainchainBlockHeightMapping[parallelChainBlock[1]] = chainData[currIndex].blockNumber; @@ -481,7 +485,7 @@ export class ParallelEvmFunnel extends BaseFunnel implements ChainFunnel { const startingBlock = await sharedData.web3.eth.getBlock(startingBlockHeight); const mappedStartingBlockHeight = await findBlockByTimestamp( web3, - Number(startingBlock.timestamp) - (config.delay ?? 0), + applyDelay(config, Number(startingBlock.timestamp)), chainName );