From 25fb06f7631d3dad14fe93c9dd39a59cb51fd013 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?T=C3=ADghearn=C3=A1n=20Carroll?= Date: Tue, 5 Apr 2022 09:42:52 +0100 Subject: [PATCH] fix fee verification for spv --- spv/ancestors_binary.go | 33 ++++++++++++--------------------- 1 file changed, 12 insertions(+), 21 deletions(-) diff --git a/spv/ancestors_binary.go b/spv/ancestors_binary.go index 7c30855..c86da3a 100644 --- a/spv/ancestors_binary.go +++ b/spv/ancestors_binary.go @@ -149,6 +149,18 @@ func VerifyAncestors(ctx context.Context, ancestry *Ancestry, mpv MerkleProofVer ancestors[paymentTxID] = &Ancestor{ Tx: ancestry.PaymentTx, } + if opts.fees { + if opts.feeQuote == nil { + return ErrNoFeeQuoteSupplied + } + ok, err := ancestry.PaymentTx.IsFeePaidEnough(opts.feeQuote) + if err != nil { + return err + } + if !ok { + return ErrFeePaidNotEnough + } + } for _, ancestor := range ancestors { inputsToCheck := make(map[[32]byte]*extendedInput) if len(ancestor.Tx.Inputs) == 0 { @@ -206,27 +218,6 @@ func VerifyAncestors(ctx context.Context, ancestry *Ancestry, mpv MerkleProofVer } } } - if opts.fees { - if opts.feeQuote == nil { - return ErrNoFeeQuoteSupplied - } - // no need to check fees for transactions we have proofs for - if ancestor.Proof == nil { - // add satoshi amounts to all inputs which correspond to outputs we have - for inputID, extendedInput := range inputsToCheck { - if ancestry.Ancestors[inputID] == nil { - return ErrCannotCalculateFeePaid - } - sats := ancestry.Ancestors[inputID].Tx.Outputs[extendedInput.input.PreviousTxOutIndex].Satoshis - ancestor.Tx.Inputs[extendedInput.vin].PreviousTxSatoshis = sats - } - // check the fees - ok, err := ancestor.Tx.IsFeePaidEnough(opts.feeQuote) - if err != nil || !ok { - return ErrFeePaidNotEnough - } - } - } } return nil }