lnwallet/channel: reuse derived SingleTweak on local force close
When creating the keyring, the tweak is already calculated in the remote commitment case. We add the calculation also for our own commitment, so we can use it in all cases without deriving the tweak.
This commit is contained in:
parent
3711597fef
commit
9c3218c51e
@ -5436,9 +5436,6 @@ func NewLocalForceCloseSummary(chanState *channeldb.OpenChannel, signer input.Si
|
|||||||
// nil.
|
// nil.
|
||||||
var commitResolution *CommitOutputResolution
|
var commitResolution *CommitOutputResolution
|
||||||
if len(delayScript) != 0 {
|
if len(delayScript) != 0 {
|
||||||
singleTweak := input.SingleTweakBytes(
|
|
||||||
commitPoint, chanState.LocalChanCfg.DelayBasePoint.PubKey,
|
|
||||||
)
|
|
||||||
localBalance := localCommit.LocalBalance
|
localBalance := localCommit.LocalBalance
|
||||||
commitResolution = &CommitOutputResolution{
|
commitResolution = &CommitOutputResolution{
|
||||||
SelfOutPoint: wire.OutPoint{
|
SelfOutPoint: wire.OutPoint{
|
||||||
@ -5447,7 +5444,7 @@ func NewLocalForceCloseSummary(chanState *channeldb.OpenChannel, signer input.Si
|
|||||||
},
|
},
|
||||||
SelfOutputSignDesc: input.SignDescriptor{
|
SelfOutputSignDesc: input.SignDescriptor{
|
||||||
KeyDesc: chanState.LocalChanCfg.DelayBasePoint,
|
KeyDesc: chanState.LocalChanCfg.DelayBasePoint,
|
||||||
SingleTweak: singleTweak,
|
SingleTweak: keyRing.LocalCommitKeyTweak,
|
||||||
WitnessScript: selfScript,
|
WitnessScript: selfScript,
|
||||||
Output: &wire.TxOut{
|
Output: &wire.TxOut{
|
||||||
PkScript: delayScript,
|
PkScript: delayScript,
|
||||||
|
@ -96,13 +96,20 @@ func DeriveCommitmentKeys(commitPoint *btcec.PublicKey,
|
|||||||
|
|
||||||
tweaklessCommit := chanType.IsTweakless()
|
tweaklessCommit := chanType.IsTweakless()
|
||||||
|
|
||||||
|
// Depending on if this is our commit or not, we'll choose the correct
|
||||||
|
// base point.
|
||||||
|
localBasePoint := localChanCfg.PaymentBasePoint
|
||||||
|
if isOurCommit {
|
||||||
|
localBasePoint = localChanCfg.DelayBasePoint
|
||||||
|
}
|
||||||
|
|
||||||
// First, we'll derive all the keys that don't depend on the context of
|
// First, we'll derive all the keys that don't depend on the context of
|
||||||
// whose commitment transaction this is.
|
// whose commitment transaction this is.
|
||||||
keyRing := &CommitmentKeyRing{
|
keyRing := &CommitmentKeyRing{
|
||||||
CommitPoint: commitPoint,
|
CommitPoint: commitPoint,
|
||||||
|
|
||||||
LocalCommitKeyTweak: input.SingleTweakBytes(
|
LocalCommitKeyTweak: input.SingleTweakBytes(
|
||||||
commitPoint, localChanCfg.PaymentBasePoint.PubKey,
|
commitPoint, localBasePoint.PubKey,
|
||||||
),
|
),
|
||||||
LocalHtlcKeyTweak: input.SingleTweakBytes(
|
LocalHtlcKeyTweak: input.SingleTweakBytes(
|
||||||
commitPoint, localChanCfg.HtlcBasePoint.PubKey,
|
commitPoint, localChanCfg.HtlcBasePoint.PubKey,
|
||||||
|
Loading…
Reference in New Issue
Block a user