Skip to content

Commit

Permalink
lnwallet: log the amounts in the same unit
Browse files Browse the repository at this point in the history
  • Loading branch information
yyforyongyu committed Nov 20, 2024
1 parent 3fd5299 commit c2aeb68
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 25 deletions.
46 changes: 23 additions & 23 deletions lnwallet/channel.go
Original file line number Diff line number Diff line change
Expand Up @@ -3598,11 +3598,13 @@ func (b BufferType) String() string {

// applyCommitFee applies the commitFee including a buffer to the balance amount
// and verifies that it does not become negative. This function returns the new
// balance and the exact buffer amount (excluding the commitment fee).
// balance, the exact buffer amount (excluding the commitment fee) and the
// commitment fee.
func (lc *LightningChannel) applyCommitFee(
balance lnwire.MilliSatoshi, commitWeight lntypes.WeightUnit,
feePerKw chainfee.SatPerKWeight,
buffer BufferType) (lnwire.MilliSatoshi, lnwire.MilliSatoshi, error) {
buffer BufferType) (lnwire.MilliSatoshi, lnwire.MilliSatoshi,
lnwire.MilliSatoshi, error) {

commitFee := feePerKw.FeeForWeight(commitWeight)
commitFeeMsat := lnwire.NewMSatFromSatoshis(commitFee)
Expand All @@ -3617,14 +3619,16 @@ func (lc *LightningChannel) applyCommitFee(
// Make sure that we are the initiator of the channel before we
// apply the FeeBuffer.
if !lc.channelState.IsInitiator {
return 0, 0, ErrFeeBufferNotInitiator
return 0, 0, 0, ErrFeeBufferNotInitiator
}

// The FeeBuffer already includes the commitFee.
bufferAmt = CalcFeeBuffer(feePerKw, commitWeight)
if bufferAmt < balance {
newBalance := balance - bufferAmt
return newBalance, bufferAmt - commitFeeMsat, nil

return newBalance, bufferAmt - commitFeeMsat,
commitFeeMsat, nil
}

// The AdditionalHtlc buffer type does NOT keep a FeeBuffer but solely
Expand All @@ -3638,21 +3642,21 @@ func (lc *LightningChannel) applyCommitFee(
bufferAmt = commitFeeMsat + additionalHtlcFee
newBalance := balance - bufferAmt
if bufferAmt < balance {
return newBalance, additionalHtlcFee, nil
return newBalance, additionalHtlcFee, commitFeeMsat, nil
}

// The default case does not account for any buffer on the local balance
// but just subtracts the commit fee.
default:
if commitFeeMsat < balance {
newBalance := balance - commitFeeMsat
return newBalance, 0, nil
return newBalance, 0, commitFeeMsat, nil
}
}

// We still return the amount and bufferAmt here to log them at a later
// stage.
return balance, bufferAmt, ErrBelowChanReserve
return balance, bufferAmt, commitFeeMsat, ErrBelowChanReserve
}

// validateCommitmentSanity is used to validate the current state of the
Expand Down Expand Up @@ -3710,17 +3714,20 @@ func (lc *LightningChannel) validateCommitmentSanity(theirLogCounter,
// includes also a buffer type. Depending on whether we are the opener
// of the channel we either want to enforce a buffer on the local
// amount.
var bufferAmt lnwire.MilliSatoshi
var (
bufferAmt lnwire.MilliSatoshi
commitFee lnwire.MilliSatoshi
)

if lc.channelState.IsInitiator {
ourBalance, bufferAmt, err = lc.applyCommitFee(
ourBalance, bufferAmt, commitFee, err = lc.applyCommitFee(
ourBalance, commitWeight, feePerKw, buffer)
if err != nil {
commitFee := feePerKw.FeeForWeight(commitWeight)
lc.log.Errorf("Cannot pay for the CommitmentFee of "+
"the ChannelState: ourBalance is negative "+
"after applying the fee: ourBalance=%v, "+
"commitFee=%v, feeBuffer=%v (type=%v) "+
"local_chan_initiator", int64(ourBalance),
"local_chan_initiator", ourBalance,
commitFee, bufferAmt, buffer)

return err
Expand All @@ -3733,17 +3740,15 @@ func (lc *LightningChannel) validateCommitmentSanity(theirLogCounter,
// stuck because locally we will never put another outgoing HTLC
// on the channel state. The FeeBuffer should ONLY be enforced
// if we locally pay for the commitment transaction.
theirBalance, bufferAmt, err = lc.applyCommitFee(
theirBalance, bufferAmt, commitFee, err = lc.applyCommitFee(
theirBalance, commitWeight, feePerKw, NoBuffer)
if err != nil {
commitFee := feePerKw.FeeForWeight(commitWeight)
lc.log.Errorf("Cannot pay for the CommitmentFee "+
"of the ChannelState: theirBalance is "+
"negative after applying the fee: "+
"theiBalance=%v, commitFee=%v, feeBuffer=%v "+
"(type=%v) remote_chan_initiator",
int64(theirBalance), commitFee, bufferAmt,
buffer)
theirBalance, commitFee, bufferAmt, buffer)

return err
}
Expand All @@ -3760,10 +3765,6 @@ func (lc *LightningChannel) validateCommitmentSanity(theirLogCounter,
lc.channelState.RemoteChanCfg.ChanReserve,
)

// Calculate the commitment fee to log the information if needed.
commitFee := feePerKw.FeeForWeight(commitWeight)
commitFeeMsat := lnwire.NewMSatFromSatoshis(commitFee)

switch {
// TODO(ziggie): Allow the peer dip us below the channel reserve when
// our local balance would increase during this commitment dance or
Expand All @@ -3777,7 +3778,7 @@ func (lc *LightningChannel) validateCommitmentSanity(theirLogCounter,
lc.log.Debugf("Funds below chan reserve: ourBalance=%v, "+
"ourReserve=%v, commitFee=%v, feeBuffer=%v "+
"chan_initiator=%v", ourBalance, ourReserve,
commitFeeMsat, bufferAmt, lc.channelState.IsInitiator)
commitFee, bufferAmt, lc.channelState.IsInitiator)

return fmt.Errorf("%w: our balance below chan reserve",
ErrBelowChanReserve)
Expand Down Expand Up @@ -8751,7 +8752,7 @@ func (lc *LightningChannel) availableCommitmentBalance(view *HtlcView,
// Make sure we do not overwrite `ourBalance` that's why we
// declare bufferAmt beforehand.
var bufferAmt lnwire.MilliSatoshi
ourBalance, bufferAmt, err = lc.applyCommitFee(
ourBalance, bufferAmt, commitFee, err = lc.applyCommitFee(
ourBalance, futureCommitWeight, feePerKw, buffer,
)
if err != nil {
Expand All @@ -8761,8 +8762,7 @@ func (lc *LightningChannel) availableCommitmentBalance(view *HtlcView,
"after applying the fee: ourBalance=%v, "+
"current commitFee(w/o additional htlc)=%v, "+
"feeBuffer=%v (type=%v) local_chan_initiator",
int64(ourBalance), commitFee,
bufferAmt, buffer)
ourBalance, commitFee, bufferAmt, buffer)

return 0, commitWeight
}
Expand Down
7 changes: 5 additions & 2 deletions lnwallet/channel_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -10341,12 +10341,15 @@ func TestApplyCommitmentFee(t *testing.T) {
for _, tc := range testCases {
tc := tc
t.Run(tc.name, func(t *testing.T) {
balance, bufferAmt, err := tc.channel.applyCommitFee(
tc.balance, commitWeight, feePerKw, tc.buffer)
//nolint:lll
balance, bufferAmt, fee, err := tc.channel.applyCommitFee(
tc.balance, commitWeight, feePerKw, tc.buffer,
)

require.ErrorIs(t, err, tc.expectedErr)
require.Equal(t, tc.expectedBalance, balance)
require.Equal(t, tc.expectedBufferAmt, bufferAmt)
require.Equal(t, commitFee, fee)
})
}
}
Expand Down

0 comments on commit c2aeb68

Please sign in to comment.