chainntnfs/btcdnotify: fix historical confirmation dispatch bugs
This commit fixes to distinct bugs in the way we previously dipatched notifications for transactions which needed a historical dispatch. Previously we would compare transactions when scanning the block using the `tx.Hash` field. This was incorrect has the `Hash` field is actually the wtxid, not the txid which should be the item being compared. We fix this within the second bug fix by actually using the txid to find the proper transaction. The second fix has to due with a slight race condition which led to an off-by-one error when dispatching the historical confirmation. If while we were dispatching the confirmation, a new block was found, then we could calculate the wrong block height (off by one) as we were using the ‘currentHeight’ instead the height of the block which included the transaction.
This commit is contained in:
parent
cc19695dad
commit
dfd9f6d1ca
@ -431,24 +431,18 @@ func (b *BtcdNotifier) attemptHistoricalDispatch(msg *confirmationsNotification,
|
|||||||
"historical dispatch: %v", tx.BlockHash, err)
|
"historical dispatch: %v", tx.BlockHash, err)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
block, err := b.chainConn.GetBlock(blockHash)
|
block, err := b.chainConn.GetBlockVerbose(blockHash)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
chainntnfs.Log.Errorf("unable to get block hash: %v", err)
|
chainntnfs.Log.Errorf("unable to get block hash: %v", err)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
txHash, err := chainhash.NewHashFromStr(tx.Hash)
|
|
||||||
if err != nil {
|
|
||||||
chainntnfs.Log.Errorf("unable to convert to hash: %v", err)
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the block obtained, locate the transaction's index within the
|
// If the block obtained, locate the transaction's index within the
|
||||||
// block so we can give the subscriber full confirmation details.
|
// block so we can give the subscriber full confirmation details.
|
||||||
var txIndex uint32
|
var txIndex uint32
|
||||||
for i, t := range block.Transactions {
|
targetTxidStr := msg.txid.String()
|
||||||
h := t.TxHash()
|
for i, txHash := range block.Tx {
|
||||||
if txHash.IsEqual(&h) {
|
if txHash == targetTxidStr {
|
||||||
txIndex = uint32(i)
|
txIndex = uint32(i)
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
@ -456,7 +450,7 @@ func (b *BtcdNotifier) attemptHistoricalDispatch(msg *confirmationsNotification,
|
|||||||
|
|
||||||
confDetails := &chainntnfs.TxConfirmation{
|
confDetails := &chainntnfs.TxConfirmation{
|
||||||
BlockHash: blockHash,
|
BlockHash: blockHash,
|
||||||
BlockHeight: uint32(currentHeight) - uint32(tx.Confirmations) + 1,
|
BlockHeight: uint32(block.Height),
|
||||||
TxIndex: txIndex,
|
TxIndex: txIndex,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user