lnwallet: modify populateHtlcIndexes to use info in commitment
It wasn’t necessary to pass in the dust limit, or the commitment itself as it is already contained within the commitment struct.
This commit is contained in:
parent
60b814b4aa
commit
51618f2ae3
@ -400,9 +400,7 @@ func locateOutputIndex(p *PaymentDescriptor, tx *wire.MsgTx, ourCommit bool,
|
|||||||
// we need to keep track of the indexes of each HTLC in order to properly write
|
// we need to keep track of the indexes of each HTLC in order to properly write
|
||||||
// the current state to disk, and also to locate the PaymentDescriptor
|
// the current state to disk, and also to locate the PaymentDescriptor
|
||||||
// corresponding to HTLC outputs in the commitment transaction.
|
// corresponding to HTLC outputs in the commitment transaction.
|
||||||
func (c *commitment) populateHtlcIndexes(ourCommitTx bool,
|
func (c *commitment) populateHtlcIndexes() error {
|
||||||
dustLimit btcutil.Amount) error {
|
|
||||||
|
|
||||||
// First, we'll set up some state to allow us to locate the output
|
// First, we'll set up some state to allow us to locate the output
|
||||||
// index of the all the HTLC's within the commitment transaction. We
|
// index of the all the HTLC's within the commitment transaction. We
|
||||||
// must keep this index so we can validate the HTLC signatures sent to
|
// must keep this index so we can validate the HTLC signatures sent to
|
||||||
@ -414,29 +412,30 @@ func (c *commitment) populateHtlcIndexes(ourCommitTx bool,
|
|||||||
// populateIndex is a helper function that populates the necessary
|
// populateIndex is a helper function that populates the necessary
|
||||||
// indexes within the commitment view for a particular HTLC.
|
// indexes within the commitment view for a particular HTLC.
|
||||||
populateIndex := func(htlc *PaymentDescriptor, incoming bool) error {
|
populateIndex := func(htlc *PaymentDescriptor, incoming bool) error {
|
||||||
isDust := htlcIsDust(incoming, ourCommitTx, c.feePerKw,
|
isDust := htlcIsDust(incoming, c.isOurs, c.feePerKw,
|
||||||
htlc.Amount.ToSatoshis(), dustLimit)
|
htlc.Amount.ToSatoshis(), c.dustLimit)
|
||||||
|
|
||||||
var err error
|
var err error
|
||||||
switch {
|
switch {
|
||||||
|
|
||||||
// If this is our commitment transaction, and this is a dust
|
// If this is our commitment transaction, and this is a dust
|
||||||
// output then we mark it as such using a -1 index.
|
// output then we mark it as such using a -1 index.
|
||||||
case ourCommitTx && isDust:
|
case c.isOurs && isDust:
|
||||||
htlc.localOutputIndex = -1
|
htlc.localOutputIndex = -1
|
||||||
|
|
||||||
// If this is the commitment transaction of the remote party,
|
// If this is the commitment transaction of the remote party,
|
||||||
// and this is a dust output then we mark it as such using a -1
|
// and this is a dust output then we mark it as such using a -1
|
||||||
// index.
|
// index.
|
||||||
case !ourCommitTx && isDust:
|
case !c.isOurs && isDust:
|
||||||
htlc.remoteOutputIndex = -1
|
htlc.remoteOutputIndex = -1
|
||||||
|
|
||||||
// If this is our commitment transaction, then we'll need to
|
// If this is our commitment transaction, then we'll need to
|
||||||
// locate the output and the index so we can verify an HTLC
|
// locate the output and the index so we can verify an HTLC
|
||||||
// signatures.
|
// signatures.
|
||||||
case ourCommitTx:
|
case c.isOurs:
|
||||||
htlc.localOutputIndex, err = locateOutputIndex(htlc, c.txn,
|
htlc.localOutputIndex, err = locateOutputIndex(
|
||||||
ourCommitTx, dups)
|
htlc, c.txn, c.isOurs, dups,
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -454,9 +453,10 @@ func (c *commitment) populateHtlcIndexes(ourCommitTx bool,
|
|||||||
// Otherwise, this is there remote party's commitment
|
// Otherwise, this is there remote party's commitment
|
||||||
// transaction and we only need to populate the remote output
|
// transaction and we only need to populate the remote output
|
||||||
// index within the HTLC index.
|
// index within the HTLC index.
|
||||||
case !ourCommitTx:
|
case !c.isOurs:
|
||||||
htlc.remoteOutputIndex, err = locateOutputIndex(htlc, c.txn,
|
htlc.remoteOutputIndex, err = locateOutputIndex(
|
||||||
ourCommitTx, dups)
|
htlc, c.txn, c.isOurs, dups,
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -1973,7 +1973,7 @@ func (lc *LightningChannel) fetchCommitmentView(remoteChain bool,
|
|||||||
|
|
||||||
// Finally, we'll populate all the HTLC indexes so we can track the
|
// Finally, we'll populate all the HTLC indexes so we can track the
|
||||||
// locations of each HTLC in the commitment state.
|
// locations of each HTLC in the commitment state.
|
||||||
if err := c.populateHtlcIndexes(ourCommitTx, dustLimit); err != nil {
|
if err := c.populateHtlcIndexes(); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user