From 155e6d2010d733370b2f9458036143dbafd155fa Mon Sep 17 00:00:00 2001 From: prathamesh0 Date: Mon, 25 Jul 2022 11:07:40 +0530 Subject: [PATCH] Avoid using indexer object when direct indexing is off --- statediff/service.go | 55 +++++++++++++++++++++++++++----------------- 1 file changed, 34 insertions(+), 21 deletions(-) diff --git a/statediff/service.go b/statediff/service.go index 39e47c779..bc9336f6e 100644 --- a/statediff/service.go +++ b/statediff/service.go @@ -170,7 +170,8 @@ func New(stack *node.Node, ethServ *eth.Ethereum, cfg *ethconfig.Config, params var db sql.Database var err error quitCh := make(chan bool) - if params.IndexerConfig != nil { + indexerConfigAvailable := params.IndexerConfig != nil + if indexerConfigAvailable { info := nodeinfo.Info{ GenesisBlock: blockChain.Genesis().Hash().Hex(), NetworkID: strconv.FormatUint(cfg.NetworkId, 10), @@ -201,11 +202,13 @@ func New(stack *node.Node, ethServ *eth.Ethereum, cfg *ethconfig.Config, params statediffMetrics: statediffMetrics, sqlFileWaitingForWrite: false, } - if params.IndexerConfig.Type() == shared.POSTGRES { - knownGaps.checkForGaps = true - } else { - log.Info("We are not going to check for gaps on start up since we are not connected to Postgres!") - knownGaps.checkForGaps = false + if indexerConfigAvailable { + if params.IndexerConfig.Type() == shared.POSTGRES { + knownGaps.checkForGaps = true + } else { + log.Info("We are not going to check for gaps on start up since we are not connected to Postgres!") + knownGaps.checkForGaps = false + } } sds := &Service{ Mutex: sync.Mutex{}, @@ -226,9 +229,11 @@ func New(stack *node.Node, ethServ *eth.Ethereum, cfg *ethconfig.Config, params stack.RegisterLifecycle(sds) stack.RegisterAPIs(sds.APIs()) - err = loadWatchedAddresses(indexer) - if err != nil { - return err + if indexerConfigAvailable { + err = loadWatchedAddresses(indexer) + if err != nil { + return err + } } return nil @@ -927,9 +932,11 @@ func (sds *Service) WatchAddress(operation types2.OperationType, args []types2.W } // update the db - err = sds.indexer.InsertWatchedAddresses(filteredArgs, currentBlockNumber) - if err != nil { - return err + if sds.indexer != nil { + err = sds.indexer.InsertWatchedAddresses(filteredArgs, currentBlockNumber) + if err != nil { + return err + } } // update in-memory params @@ -949,9 +956,11 @@ func (sds *Service) WatchAddress(operation types2.OperationType, args []types2.W } // update the db - err = sds.indexer.RemoveWatchedAddresses(args) - if err != nil { - return err + if sds.indexer != nil { + err = sds.indexer.RemoveWatchedAddresses(args) + if err != nil { + return err + } } // update in-memory params @@ -965,9 +974,11 @@ func (sds *Service) WatchAddress(operation types2.OperationType, args []types2.W } // update the db - err = sds.indexer.SetWatchedAddresses(args, currentBlockNumber) - if err != nil { - return err + if sds.indexer != nil { + err = sds.indexer.SetWatchedAddresses(args, currentBlockNumber) + if err != nil { + return err + } } // update in-memory params @@ -975,9 +986,11 @@ func (sds *Service) WatchAddress(operation types2.OperationType, args []types2.W writeLoopParams.ComputeWatchedAddressesLeafPaths() case types2.Clear: // update the db - err := sds.indexer.ClearWatchedAddresses() - if err != nil { - return err + if sds.indexer != nil { + err := sds.indexer.ClearWatchedAddresses() + if err != nil { + return err + } } // update in-memory params