multi: remove ErrDoubleSpend check for PublishTransaction

In this commit, we address a lingering issue within some subsystems that
are responsible for broadcasting transactions. Previously,
ErrDoubleSpend indicated that a transaction was already included in the
mempool/chain. This error was then modified to actually be returned for
conflicting transactions, but its callers were not modified accordingly.
This would lead to conflicting transactions to be interpreted as valid,
when they shouldn't be.
This commit is contained in:
Wilmer Paulino 2019-02-20 15:06:57 -08:00
parent 5c5c542f94
commit 7946d0a256
No known key found for this signature in database
GPG Key ID: 6DF57B9F9514972F
4 changed files with 5 additions and 7 deletions

@ -7,7 +7,6 @@ import (
"github.com/btcsuite/btcd/wire" "github.com/btcsuite/btcd/wire"
"github.com/davecgh/go-spew/spew" "github.com/davecgh/go-spew/spew"
"github.com/lightningnetwork/lnd/channeldb" "github.com/lightningnetwork/lnd/channeldb"
"github.com/lightningnetwork/lnd/input" "github.com/lightningnetwork/lnd/input"
"github.com/lightningnetwork/lnd/lntypes" "github.com/lightningnetwork/lnd/lntypes"
@ -148,7 +147,7 @@ func (h *htlcSuccessResolver) Resolve() (ContractResolver, error) {
// constructed, we'll broadcast the sweep transaction to the // constructed, we'll broadcast the sweep transaction to the
// network. // network.
err := h.PublishTx(h.sweepTx) err := h.PublishTx(h.sweepTx)
if err != nil && err != lnwallet.ErrDoubleSpend { if err != nil {
log.Infof("%T(%x): unable to publish tx: %v", log.Infof("%T(%x): unable to publish tx: %v",
h, h.payHash[:], err) h, h.payHash[:], err)
return nil, err return nil, err
@ -200,7 +199,7 @@ func (h *htlcSuccessResolver) Resolve() (ContractResolver, error) {
// //
// TODO(roasbeef): after changing sighashes send to tx bundler // TODO(roasbeef): after changing sighashes send to tx bundler
err := h.PublishTx(h.htlcResolution.SignedSuccessTx) err := h.PublishTx(h.htlcResolution.SignedSuccessTx)
if err != nil && err != lnwallet.ErrDoubleSpend { if err != nil {
return nil, err return nil, err
} }

@ -508,7 +508,7 @@ func (f *fundingManager) Start() error {
channel.IsInitiator { channel.IsInitiator {
err := f.cfg.PublishTransaction(channel.FundingTxn) err := f.cfg.PublishTransaction(channel.FundingTxn)
if err != nil && err != lnwallet.ErrDoubleSpend { if err != nil {
fndgLog.Errorf("Unable to rebroadcast funding "+ fndgLog.Errorf("Unable to rebroadcast funding "+
"tx for ChannelPoint(%v): %v", "tx for ChannelPoint(%v): %v",
channel.FundingOutpoint, err) channel.FundingOutpoint, err)

@ -894,7 +894,7 @@ func (u *utxoNursery) sweepCribOutput(classHeight uint32, baby *babyOutput) erro
// We'll now broadcast the HTLC transaction, then wait for it to be // We'll now broadcast the HTLC transaction, then wait for it to be
// confirmed before transitioning it to kindergarten. // confirmed before transitioning it to kindergarten.
err := u.cfg.PublishTransaction(baby.timeoutTx) err := u.cfg.PublishTransaction(baby.timeoutTx)
if err != nil && err != lnwallet.ErrDoubleSpend { if err != nil {
utxnLog.Errorf("Unable to broadcast baby tx: "+ utxnLog.Errorf("Unable to broadcast baby tx: "+
"%v, %v", err, spew.Sdump(baby.timeoutTx)) "%v, %v", err, spew.Sdump(baby.timeoutTx))
return err return err

@ -2,7 +2,6 @@ package lookout
import ( import (
"github.com/btcsuite/btcd/wire" "github.com/btcsuite/btcd/wire"
"github.com/lightningnetwork/lnd/lnwallet"
) )
// PunisherConfig houses the resources required by the Punisher. // PunisherConfig houses the resources required by the Punisher.
@ -44,7 +43,7 @@ func (p *BreachPunisher) Punish(desc *JusticeDescriptor, quit <-chan struct{}) e
desc.SessionInfo.ID, justiceTxn.TxHash()) desc.SessionInfo.ID, justiceTxn.TxHash())
err = p.cfg.PublishTx(justiceTxn) err = p.cfg.PublishTx(justiceTxn)
if err != nil && err != lnwallet.ErrDoubleSpend { if err != nil {
log.Errorf("Unable to publish justice txn for client=%s"+ log.Errorf("Unable to publish justice txn for client=%s"+
"with breach-txid=%s: %v", "with breach-txid=%s: %v",
desc.SessionInfo.ID, desc.BreachedCommitTx.TxHash(), err) desc.SessionInfo.ID, desc.BreachedCommitTx.TxHash(), err)