From 28eb8474f4a13664afebf9664fc3ca67450ec52a Mon Sep 17 00:00:00 2001 From: Olaoluwa Osuntokun Date: Thu, 22 Nov 2018 15:58:58 -0600 Subject: [PATCH] chainntnfs: modify all historical rescans to scan backwards In this commit, we modify all existing historical rescans for ChainNotifier backends to scan backwards rather than forwards. If we know that a transaction has been confirmed, or outpoint spent, the it's likely that the event has recently transpired assuming we've been offline for a short period of time. Therefore, if we scan backwards rather than forwards, then we can save potentially hundreds or thousands of block fetches if the event recently happened close to the tip of the chain. We bound this search at the genesis block, to ensure we don't underflow the uint32 used throughout the package in the main loop. --- chainntnfs/bitcoindnotify/bitcoind.go | 4 ++-- chainntnfs/btcdnotify/btcd.go | 2 +- chainntnfs/neutrinonotify/neutrino.go | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/chainntnfs/bitcoindnotify/bitcoind.go b/chainntnfs/bitcoindnotify/bitcoind.go index 8c235213..36f7ce19 100644 --- a/chainntnfs/bitcoindnotify/bitcoind.go +++ b/chainntnfs/bitcoindnotify/bitcoind.go @@ -521,7 +521,7 @@ func (b *BitcoindNotifier) confDetailsManually(txid *chainhash.Hash, // Begin scanning blocks at every height to determine where the // transaction was included in. - for height := heightHint; height <= currentHeight; height++ { + for height := currentHeight; height >= heightHint && height > 0; height-- { // Ensure we haven't been requested to shut down before // processing the next height. select { @@ -749,7 +749,7 @@ func (b *BitcoindNotifier) dispatchSpendDetailsManually( // Begin scanning blocks at every height to determine if the outpoint // was spent. - for height := startHeight; height <= endHeight; height++ { + for height := endHeight; height >= startHeight && height > 0; height-- { // Ensure we haven't been requested to shut down before // processing the next height. select { diff --git a/chainntnfs/btcdnotify/btcd.go b/chainntnfs/btcdnotify/btcd.go index bb5e55a4..30b790dd 100644 --- a/chainntnfs/btcdnotify/btcd.go +++ b/chainntnfs/btcdnotify/btcd.go @@ -572,7 +572,7 @@ func (b *BtcdNotifier) confDetailsManually(txid *chainhash.Hash, startHeight, // Begin scanning blocks at every height to determine where the // transaction was included in. - for height := startHeight; height <= endHeight; height++ { + for height := endHeight; height >= startHeight && height > 0; height-- { // Ensure we haven't been requested to shut down before // processing the next height. select { diff --git a/chainntnfs/neutrinonotify/neutrino.go b/chainntnfs/neutrinonotify/neutrino.go index 34b8285f..abc21671 100644 --- a/chainntnfs/neutrinonotify/neutrino.go +++ b/chainntnfs/neutrinonotify/neutrino.go @@ -467,7 +467,7 @@ func (n *NeutrinoNotifier) historicalConfDetails(targetHash *chainhash.Hash, // Starting from the height hint, we'll walk forwards in the chain to // see if this transaction has already been confirmed. - for scanHeight := startHeight; scanHeight <= endHeight; scanHeight++ { + for scanHeight := endHeight; scanHeight >= startHeight && scanHeight > 0; scanHeight-- { // Ensure we haven't been requested to shut down before // processing the next height. select {