From 6233dfd417f944173a4f779f613a018d94252961 Mon Sep 17 00:00:00 2001 From: Jeffery Walsh Date: Fri, 1 Mar 2024 13:13:06 -0800 Subject: [PATCH] only wait for confirmations when not crawling past blocks --- packages/relayer/indexer/handle_event.go | 30 ++++++++++++++---------- 1 file changed, 17 insertions(+), 13 deletions(-) diff --git a/packages/relayer/indexer/handle_event.go b/packages/relayer/indexer/handle_event.go index 7227bd967d9..c07be55bf8e 100644 --- a/packages/relayer/indexer/handle_event.go +++ b/packages/relayer/indexer/handle_event.go @@ -58,19 +58,23 @@ func (i *Indexer) handleEvent( return nil } - // we need to wait for confirmations to confirm this event is not being reverted, - // removed, or reorged now. - confCtx, confCtxCancel := context.WithTimeout(ctx, defaultCtxTimeout) - - defer confCtxCancel() - - if err := relayer.WaitConfirmations( - confCtx, - i.srcEthClient, - uint64(defaultConfirmations), - event.Raw.TxHash, - ); err != nil { - return err + // only wait for confirmations when not crawling past blocks. + // these are guaranteed to be confirmed since the blocks are old. + if i.watchMode != CrawlPastBlocks { + // we need to wait for confirmations to confirm this event is not being reverted, + // removed, or reorged now. + confCtx, confCtxCancel := context.WithTimeout(ctx, defaultCtxTimeout) + + defer confCtxCancel() + + if err := relayer.WaitConfirmations( + confCtx, + i.srcEthClient, + uint64(defaultConfirmations), + event.Raw.TxHash, + ); err != nil { + return err + } } // get event status from msgHash on chain