channeldb: store close initiator status
This commit adds two new channel statuses which indicate the party that initatited closing the channel. These statuses are set in conjunction with the existing commit broadcast status so that we do not need to migrate existing logic to handle multiple types of closes. This status is set for locally initiated force closes in this commit because they follow a similar pattern to cooparative closes, marking the commitment broadcast then proceeding with tx broadcast. Remote force closes are added in the following commit, as they are handled differently.
This commit is contained in:
parent
8d632b8022
commit
d3cb6ad869
@ -155,6 +155,9 @@ type channelCloser struct {
|
|||||||
// remoteDeliveryScript is the script that we'll send the remote
|
// remoteDeliveryScript is the script that we'll send the remote
|
||||||
// party's settled channel funds to.
|
// party's settled channel funds to.
|
||||||
remoteDeliveryScript []byte
|
remoteDeliveryScript []byte
|
||||||
|
|
||||||
|
// locallyInitiated is true if we initiated the channel close.
|
||||||
|
locallyInitiated bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// newChannelCloser creates a new instance of the channel closure given the
|
// newChannelCloser creates a new instance of the channel closure given the
|
||||||
@ -162,7 +165,7 @@ type channelCloser struct {
|
|||||||
// only be populated iff, we're the initiator of this closing request.
|
// only be populated iff, we're the initiator of this closing request.
|
||||||
func newChannelCloser(cfg chanCloseCfg, deliveryScript []byte,
|
func newChannelCloser(cfg chanCloseCfg, deliveryScript []byte,
|
||||||
idealFeePerKw chainfee.SatPerKWeight, negotiationHeight uint32,
|
idealFeePerKw chainfee.SatPerKWeight, negotiationHeight uint32,
|
||||||
closeReq *htlcswitch.ChanClose) *channelCloser {
|
closeReq *htlcswitch.ChanClose, locallyInitiated bool) *channelCloser {
|
||||||
|
|
||||||
// Given the target fee-per-kw, we'll compute what our ideal _total_
|
// Given the target fee-per-kw, we'll compute what our ideal _total_
|
||||||
// fee will be starting at for this fee negotiation.
|
// fee will be starting at for this fee negotiation.
|
||||||
@ -198,6 +201,7 @@ func newChannelCloser(cfg chanCloseCfg, deliveryScript []byte,
|
|||||||
idealFeeSat: idealFeeSat,
|
idealFeeSat: idealFeeSat,
|
||||||
localDeliveryScript: deliveryScript,
|
localDeliveryScript: deliveryScript,
|
||||||
priorFeeOffers: make(map[btcutil.Amount]*lnwire.ClosingSigned),
|
priorFeeOffers: make(map[btcutil.Amount]*lnwire.ClosingSigned),
|
||||||
|
locallyInitiated: locallyInitiated,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -224,7 +228,7 @@ func (c *channelCloser) initChanShutdown() (*lnwire.Shutdown, error) {
|
|||||||
// guarantees that our listchannels rpc will be externally consistent,
|
// guarantees that our listchannels rpc will be externally consistent,
|
||||||
// and reflect that the channel is being shutdown by the time the
|
// and reflect that the channel is being shutdown by the time the
|
||||||
// closing request returns.
|
// closing request returns.
|
||||||
err := c.cfg.channel.MarkCoopBroadcasted(nil)
|
err := c.cfg.channel.MarkCoopBroadcasted(nil, c.locallyInitiated)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -511,7 +515,9 @@ func (c *channelCloser) ProcessCloseMsg(msg lnwire.Message) ([]lnwire.Message, b
|
|||||||
// Before publishing the closing tx, we persist it to the
|
// Before publishing the closing tx, we persist it to the
|
||||||
// database, such that it can be republished if something goes
|
// database, such that it can be republished if something goes
|
||||||
// wrong.
|
// wrong.
|
||||||
err = c.cfg.channel.MarkCoopBroadcasted(closeTx)
|
err = c.cfg.channel.MarkCoopBroadcasted(
|
||||||
|
closeTx, c.locallyInitiated,
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, false, err
|
return nil, false, err
|
||||||
}
|
}
|
||||||
|
@ -401,9 +401,22 @@ var (
|
|||||||
// will have.
|
// will have.
|
||||||
ChanStatusRestored ChannelStatus = 1 << 3
|
ChanStatusRestored ChannelStatus = 1 << 3
|
||||||
|
|
||||||
// ChanStatusCoopBroadcasted indicates that a cooperative close for this
|
// ChanStatusCoopBroadcasted indicates that a cooperative close for
|
||||||
// channel has been broadcasted.
|
// this channel has been broadcasted. Older cooperatively closed
|
||||||
|
// channels will only have this status set. Newer ones will also have
|
||||||
|
// close initiator information stored using the local/remote initiator
|
||||||
|
// status. This status is set in conjunction with the initiator status
|
||||||
|
// so that we do not need to check multiple channel statues for
|
||||||
|
// cooperative closes.
|
||||||
ChanStatusCoopBroadcasted ChannelStatus = 1 << 4
|
ChanStatusCoopBroadcasted ChannelStatus = 1 << 4
|
||||||
|
|
||||||
|
// ChanStatusLocalCloseInitiator indicates that we initiated closing
|
||||||
|
// the channel.
|
||||||
|
ChanStatusLocalCloseInitiator ChannelStatus = 1 << 5
|
||||||
|
|
||||||
|
// ChanStatusRemoteCloseInitiator indicates that the remote node
|
||||||
|
// initiated closing the channel.
|
||||||
|
ChanStatusRemoteCloseInitiator ChannelStatus = 1 << 6
|
||||||
)
|
)
|
||||||
|
|
||||||
// chanStatusStrings maps a ChannelStatus to a human friendly string that
|
// chanStatusStrings maps a ChannelStatus to a human friendly string that
|
||||||
@ -415,6 +428,8 @@ var chanStatusStrings = map[ChannelStatus]string{
|
|||||||
ChanStatusLocalDataLoss: "ChanStatusLocalDataLoss",
|
ChanStatusLocalDataLoss: "ChanStatusLocalDataLoss",
|
||||||
ChanStatusRestored: "ChanStatusRestored",
|
ChanStatusRestored: "ChanStatusRestored",
|
||||||
ChanStatusCoopBroadcasted: "ChanStatusCoopBroadcasted",
|
ChanStatusCoopBroadcasted: "ChanStatusCoopBroadcasted",
|
||||||
|
ChanStatusLocalCloseInitiator: "ChanStatusLocalCloseInitiator",
|
||||||
|
ChanStatusRemoteCloseInitiator: "ChanStatusRemoteCloseInitiator",
|
||||||
}
|
}
|
||||||
|
|
||||||
// orderedChanStatusFlags is an in-order list of all that channel status flags.
|
// orderedChanStatusFlags is an in-order list of all that channel status flags.
|
||||||
@ -425,6 +440,8 @@ var orderedChanStatusFlags = []ChannelStatus{
|
|||||||
ChanStatusLocalDataLoss,
|
ChanStatusLocalDataLoss,
|
||||||
ChanStatusRestored,
|
ChanStatusRestored,
|
||||||
ChanStatusCoopBroadcasted,
|
ChanStatusCoopBroadcasted,
|
||||||
|
ChanStatusLocalCloseInitiator,
|
||||||
|
ChanStatusRemoteCloseInitiator,
|
||||||
}
|
}
|
||||||
|
|
||||||
// String returns a human-readable representation of the ChannelStatus.
|
// String returns a human-readable representation of the ChannelStatus.
|
||||||
@ -974,30 +991,37 @@ func (c *OpenChannel) isBorked(chanBucket *bbolt.Bucket) (bool, error) {
|
|||||||
// closing tx _we believe_ will appear in the chain. This is only used to
|
// closing tx _we believe_ will appear in the chain. This is only used to
|
||||||
// republish this tx at startup to ensure propagation, and we should still
|
// republish this tx at startup to ensure propagation, and we should still
|
||||||
// handle the case where a different tx actually hits the chain.
|
// handle the case where a different tx actually hits the chain.
|
||||||
func (c *OpenChannel) MarkCommitmentBroadcasted(closeTx *wire.MsgTx) error {
|
func (c *OpenChannel) MarkCommitmentBroadcasted(closeTx *wire.MsgTx,
|
||||||
|
locallyInitiated bool) error {
|
||||||
|
|
||||||
return c.markBroadcasted(
|
return c.markBroadcasted(
|
||||||
ChanStatusCommitBroadcasted, forceCloseTxKey, closeTx,
|
ChanStatusCommitBroadcasted, forceCloseTxKey, closeTx,
|
||||||
|
locallyInitiated,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarkCoopBroadcasted marks the channel to indicate that a cooperative close
|
// MarkCoopBroadcasted marks the channel to indicate that a cooperative close
|
||||||
// transaction has been broadcast, either our own or the remote, and that we
|
// transaction has been broadcast, either our own or the remote, and that we
|
||||||
// should wach the chain for it to confirm before taking further action. It
|
// should watch the chain for it to confirm before taking further action. It
|
||||||
// takes as argument a cooperative close tx that could appear on chain, and
|
// takes as argument a cooperative close tx that could appear on chain, and
|
||||||
// should be rebroadcast upon startup. This is only used to republish and ensure
|
// should be rebroadcast upon startup. This is only used to republish and
|
||||||
// propagation, and we should still handle the case where a different tx
|
// ensure propagation, and we should still handle the case where a different tx
|
||||||
// actually hits the chain.
|
// actually hits the chain.
|
||||||
func (c *OpenChannel) MarkCoopBroadcasted(closeTx *wire.MsgTx) error {
|
func (c *OpenChannel) MarkCoopBroadcasted(closeTx *wire.MsgTx,
|
||||||
|
locallyInitiated bool) error {
|
||||||
|
|
||||||
return c.markBroadcasted(
|
return c.markBroadcasted(
|
||||||
ChanStatusCoopBroadcasted, coopCloseTxKey, closeTx,
|
ChanStatusCoopBroadcasted, coopCloseTxKey, closeTx,
|
||||||
|
locallyInitiated,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// markBroadcasted is a helper function which modifies the channel status of the
|
// markBroadcasted is a helper function which modifies the channel status of the
|
||||||
// receiving channel and inserts a close transaction under the requested key,
|
// receiving channel and inserts a close transaction under the requested key,
|
||||||
// which should specify either a coop or force close.
|
// which should specify either a coop or force close. It adds a status which
|
||||||
|
// indicates the party that initiated the channel close.
|
||||||
func (c *OpenChannel) markBroadcasted(status ChannelStatus, key []byte,
|
func (c *OpenChannel) markBroadcasted(status ChannelStatus, key []byte,
|
||||||
closeTx *wire.MsgTx) error {
|
closeTx *wire.MsgTx, locallyInitiated bool) error {
|
||||||
|
|
||||||
c.Lock()
|
c.Lock()
|
||||||
defer c.Unlock()
|
defer c.Unlock()
|
||||||
@ -1016,6 +1040,15 @@ func (c *OpenChannel) markBroadcasted(status ChannelStatus, key []byte,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add the initiator status to the status provided. These statuses are
|
||||||
|
// set in addition to the broadcast status so that we do not need to
|
||||||
|
// migrate the original logic which does not store initiator.
|
||||||
|
if locallyInitiated {
|
||||||
|
status |= ChanStatusLocalCloseInitiator
|
||||||
|
} else {
|
||||||
|
status |= ChanStatusRemoteCloseInitiator
|
||||||
|
}
|
||||||
|
|
||||||
return c.putChanStatus(status, putClosingTx)
|
return c.putChanStatus(status, putClosingTx)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1089,13 +1089,13 @@ func TestFetchWaitingCloseChannels(t *testing.T) {
|
|||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
if err := channel.MarkCommitmentBroadcasted(closeTx); err != nil {
|
if err := channel.MarkCommitmentBroadcasted(closeTx, true); err != nil {
|
||||||
t.Fatalf("unable to mark commitment broadcast: %v", err)
|
t.Fatalf("unable to mark commitment broadcast: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now try to marking a coop close with a nil tx. This should
|
// Now try to marking a coop close with a nil tx. This should
|
||||||
// succeed, but it shouldn't exit when queried.
|
// succeed, but it shouldn't exit when queried.
|
||||||
if err = channel.MarkCoopBroadcasted(nil); err != nil {
|
if err = channel.MarkCoopBroadcasted(nil, true); err != nil {
|
||||||
t.Fatalf("unable to mark nil coop broadcast: %v", err)
|
t.Fatalf("unable to mark nil coop broadcast: %v", err)
|
||||||
}
|
}
|
||||||
_, err := channel.BroadcastedCooperative()
|
_, err := channel.BroadcastedCooperative()
|
||||||
@ -1107,7 +1107,7 @@ func TestFetchWaitingCloseChannels(t *testing.T) {
|
|||||||
// it as coop closed. Later we will test that distinct
|
// it as coop closed. Later we will test that distinct
|
||||||
// transactions are returned for both coop and force closes.
|
// transactions are returned for both coop and force closes.
|
||||||
closeTx.TxIn[0].PreviousOutPoint.Index ^= 1
|
closeTx.TxIn[0].PreviousOutPoint.Index ^= 1
|
||||||
if err := channel.MarkCoopBroadcasted(closeTx); err != nil {
|
if err := channel.MarkCoopBroadcasted(closeTx, true); err != nil {
|
||||||
t.Fatalf("unable to mark coop broadcast: %v", err)
|
t.Fatalf("unable to mark coop broadcast: %v", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1255,3 +1255,105 @@ func TestRefreshShortChanID(t *testing.T) {
|
|||||||
t.Fatalf("channel pending state wasn't updated: want false got true")
|
t.Fatalf("channel pending state wasn't updated: want false got true")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TestCloseInitiator tests the setting of close initiator statuses for
|
||||||
|
// cooperative closes and local force closes.
|
||||||
|
func TestCloseInitiator(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
// updateChannel is called to update the channel as broadcast,
|
||||||
|
// cooperatively or not, based on the test's requirements.
|
||||||
|
updateChannel func(c *OpenChannel) error
|
||||||
|
expectedStatuses []ChannelStatus
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "local coop close",
|
||||||
|
// Mark the channel as cooperatively closed, initiated
|
||||||
|
// by the local party.
|
||||||
|
updateChannel: func(c *OpenChannel) error {
|
||||||
|
return c.MarkCoopBroadcasted(
|
||||||
|
&wire.MsgTx{}, true,
|
||||||
|
)
|
||||||
|
},
|
||||||
|
expectedStatuses: []ChannelStatus{
|
||||||
|
ChanStatusLocalCloseInitiator,
|
||||||
|
ChanStatusCoopBroadcasted,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "remote coop close",
|
||||||
|
// Mark the channel as cooperatively closed, initiated
|
||||||
|
// by the remote party.
|
||||||
|
updateChannel: func(c *OpenChannel) error {
|
||||||
|
return c.MarkCoopBroadcasted(
|
||||||
|
&wire.MsgTx{}, false,
|
||||||
|
)
|
||||||
|
},
|
||||||
|
expectedStatuses: []ChannelStatus{
|
||||||
|
ChanStatusRemoteCloseInitiator,
|
||||||
|
ChanStatusCoopBroadcasted,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "local force close",
|
||||||
|
// Mark the channel's commitment as broadcast with
|
||||||
|
// local initiator.
|
||||||
|
updateChannel: func(c *OpenChannel) error {
|
||||||
|
return c.MarkCommitmentBroadcasted(
|
||||||
|
&wire.MsgTx{}, true,
|
||||||
|
)
|
||||||
|
},
|
||||||
|
expectedStatuses: []ChannelStatus{
|
||||||
|
ChanStatusLocalCloseInitiator,
|
||||||
|
ChanStatusCommitBroadcasted,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
test := test
|
||||||
|
|
||||||
|
t.Run(test.name, func(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
cdb, cleanUp, err := makeTestDB()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unable to make test database: %v",
|
||||||
|
err)
|
||||||
|
}
|
||||||
|
defer cleanUp()
|
||||||
|
|
||||||
|
// Create an open channel.
|
||||||
|
channel := createTestChannel(
|
||||||
|
t, cdb, openChannelOption(),
|
||||||
|
)
|
||||||
|
|
||||||
|
err = test.updateChannel(channel)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Lookup open channels in the database.
|
||||||
|
dbChans, err := fetchChannels(
|
||||||
|
cdb, pendingChannelFilter(false),
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unexpected error: %v", err)
|
||||||
|
}
|
||||||
|
if len(dbChans) != 1 {
|
||||||
|
t.Fatalf("expected 1 channel, got: %v",
|
||||||
|
len(dbChans))
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check that the statuses that we expect were written
|
||||||
|
// to disk.
|
||||||
|
for _, status := range test.expectedStatuses {
|
||||||
|
if !dbChans[0].HasChanStatus(status) {
|
||||||
|
t.Fatalf("expected channel to have "+
|
||||||
|
"status: %v, has status: %v",
|
||||||
|
status, dbChans[0].chanStatus)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -647,7 +647,7 @@ func TestFetchChannels(t *testing.T) {
|
|||||||
channelIDOption(pendingWaitingChan),
|
channelIDOption(pendingWaitingChan),
|
||||||
)
|
)
|
||||||
|
|
||||||
err = pendingClosing.MarkCoopBroadcasted(nil)
|
err = pendingClosing.MarkCoopBroadcasted(nil, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unexpected error: %v", err)
|
t.Fatalf("unexpected error: %v", err)
|
||||||
}
|
}
|
||||||
@ -667,7 +667,7 @@ func TestFetchChannels(t *testing.T) {
|
|||||||
channelIDOption(openWaitingChan),
|
channelIDOption(openWaitingChan),
|
||||||
openChannelOption(),
|
openChannelOption(),
|
||||||
)
|
)
|
||||||
err = openClosing.MarkCoopBroadcasted(nil)
|
err = openClosing.MarkCoopBroadcasted(nil, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unexpected error: %v", err)
|
t.Fatalf("unexpected error: %v", err)
|
||||||
}
|
}
|
||||||
|
@ -62,12 +62,12 @@ func TestChainArbitratorRepublishCloses(t *testing.T) {
|
|||||||
for i := 0; i < numChans/2; i++ {
|
for i := 0; i < numChans/2; i++ {
|
||||||
closeTx := channels[i].FundingTxn.Copy()
|
closeTx := channels[i].FundingTxn.Copy()
|
||||||
closeTx.TxIn[0].PreviousOutPoint = channels[i].FundingOutpoint
|
closeTx.TxIn[0].PreviousOutPoint = channels[i].FundingOutpoint
|
||||||
err := channels[i].MarkCommitmentBroadcasted(closeTx)
|
err := channels[i].MarkCommitmentBroadcasted(closeTx, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = channels[i].MarkCoopBroadcasted(closeTx)
|
err = channels[i].MarkCoopBroadcasted(closeTx, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -98,7 +98,7 @@ type ChannelArbitratorConfig struct {
|
|||||||
|
|
||||||
// MarkCommitmentBroadcasted should mark the channel as the commitment
|
// MarkCommitmentBroadcasted should mark the channel as the commitment
|
||||||
// being broadcast, and we are waiting for the commitment to confirm.
|
// being broadcast, and we are waiting for the commitment to confirm.
|
||||||
MarkCommitmentBroadcasted func(*wire.MsgTx) error
|
MarkCommitmentBroadcasted func(*wire.MsgTx, bool) error
|
||||||
|
|
||||||
// MarkChannelClosed marks the channel closed in the database, with the
|
// MarkChannelClosed marks the channel closed in the database, with the
|
||||||
// passed close summary. After this method successfully returns we can
|
// passed close summary. After this method successfully returns we can
|
||||||
@ -797,8 +797,10 @@ func (c *ChannelArbitrator) stateStep(
|
|||||||
|
|
||||||
// Before publishing the transaction, we store it to the
|
// Before publishing the transaction, we store it to the
|
||||||
// database, such that we can re-publish later in case it
|
// database, such that we can re-publish later in case it
|
||||||
// didn't propagate.
|
// didn't propagate. We initiated the force close, so we
|
||||||
if err := c.cfg.MarkCommitmentBroadcasted(closeTx); err != nil {
|
// mark broadcast with local initiator set to true.
|
||||||
|
err = c.cfg.MarkCommitmentBroadcasted(closeTx, true)
|
||||||
|
if err != nil {
|
||||||
log.Errorf("ChannelArbitrator(%v): unable to "+
|
log.Errorf("ChannelArbitrator(%v): unable to "+
|
||||||
"mark commitment broadcasted: %v",
|
"mark commitment broadcasted: %v",
|
||||||
c.cfg.ChanPoint, err)
|
c.cfg.ChanPoint, err)
|
||||||
|
@ -339,7 +339,7 @@ func createTestChannelArbitrator(t *testing.T, log ArbitratorLog) (*chanArbTestC
|
|||||||
}
|
}
|
||||||
return summary, nil
|
return summary, nil
|
||||||
},
|
},
|
||||||
MarkCommitmentBroadcasted: func(_ *wire.MsgTx) error {
|
MarkCommitmentBroadcasted: func(_ *wire.MsgTx, _ bool) error {
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
MarkChannelClosed: func(*channeldb.ChannelCloseSummary) error {
|
MarkChannelClosed: func(*channeldb.ChannelCloseSummary) error {
|
||||||
|
@ -6433,22 +6433,28 @@ func (lc *LightningChannel) MarkBorked() error {
|
|||||||
|
|
||||||
// MarkCommitmentBroadcasted marks the channel as a commitment transaction has
|
// MarkCommitmentBroadcasted marks the channel as a commitment transaction has
|
||||||
// been broadcast, either our own or the remote, and we should watch the chain
|
// been broadcast, either our own or the remote, and we should watch the chain
|
||||||
// for it to confirm before taking any further action.
|
// for it to confirm before taking any further action. It takes a boolean which
|
||||||
func (lc *LightningChannel) MarkCommitmentBroadcasted(tx *wire.MsgTx) error {
|
// indicates whether we initiated the close.
|
||||||
|
func (lc *LightningChannel) MarkCommitmentBroadcasted(tx *wire.MsgTx,
|
||||||
|
locallyInitiated bool) error {
|
||||||
|
|
||||||
lc.Lock()
|
lc.Lock()
|
||||||
defer lc.Unlock()
|
defer lc.Unlock()
|
||||||
|
|
||||||
return lc.channelState.MarkCommitmentBroadcasted(tx)
|
return lc.channelState.MarkCommitmentBroadcasted(tx, locallyInitiated)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarkCoopBroadcasted marks the channel as a cooperative close transaction has
|
// MarkCoopBroadcasted marks the channel as a cooperative close transaction has
|
||||||
// been broadcast, and that we should watch the chain for it to confirm before
|
// been broadcast, and that we should watch the chain for it to confirm before
|
||||||
// taking any further action.
|
// taking any further action. It takes a locally initiated bool which is true
|
||||||
func (lc *LightningChannel) MarkCoopBroadcasted(tx *wire.MsgTx) error {
|
// if we initiated the cooperative close.
|
||||||
|
func (lc *LightningChannel) MarkCoopBroadcasted(tx *wire.MsgTx,
|
||||||
|
localInitiated bool) error {
|
||||||
|
|
||||||
lc.Lock()
|
lc.Lock()
|
||||||
defer lc.Unlock()
|
defer lc.Unlock()
|
||||||
|
|
||||||
return lc.channelState.MarkCoopBroadcasted(tx)
|
return lc.channelState.MarkCoopBroadcasted(tx, localInitiated)
|
||||||
}
|
}
|
||||||
|
|
||||||
// MarkDataLoss marks sets the channel status to LocalDataLoss and stores the
|
// MarkDataLoss marks sets the channel status to LocalDataLoss and stores the
|
||||||
|
2
peer.go
2
peer.go
@ -2119,6 +2119,7 @@ func (p *peer) fetchActiveChanCloser(chanID lnwire.ChannelID) (*channelCloser, e
|
|||||||
feePerKw,
|
feePerKw,
|
||||||
uint32(startingHeight),
|
uint32(startingHeight),
|
||||||
nil,
|
nil,
|
||||||
|
false,
|
||||||
)
|
)
|
||||||
p.activeChanCloses[chanID] = chanCloser
|
p.activeChanCloses[chanID] = chanCloser
|
||||||
}
|
}
|
||||||
@ -2231,6 +2232,7 @@ func (p *peer) handleLocalCloseReq(req *htlcswitch.ChanClose) {
|
|||||||
req.TargetFeePerKw,
|
req.TargetFeePerKw,
|
||||||
uint32(startingHeight),
|
uint32(startingHeight),
|
||||||
req,
|
req,
|
||||||
|
true,
|
||||||
)
|
)
|
||||||
p.activeChanCloses[chanID] = chanCloser
|
p.activeChanCloses[chanID] = chanCloser
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user