lnwire: add new HtlcPoint to OpenChannel and AcceptChannel

In this commit, we begin implementing the latest spec change to reduce
the attack surface on online channels. In this commit, we introduce a
distinct HTLC base point which will be used to sign the second-level
HTLC transactions for each active HLTC on the commitment transaction of
the remote node. With this, we allow the commitment key to remain
offline, as it isn’t needed in routine channel updates, unless we need
to go to chain.
This commit is contained in:
Olaoluwa Osuntokun 2017-11-14 20:26:51 -08:00
parent caec23a236
commit a14a15641b
3 changed files with 30 additions and 4 deletions

@ -75,6 +75,12 @@ type AcceptChannel struct {
// where they claim funds. // where they claim funds.
DelayedPaymentPoint *btcec.PublicKey DelayedPaymentPoint *btcec.PublicKey
// HtlcPoint is the base point used to derive the set of keys for this
// party that will be used within the HTLC public key scripts. This
// value is combined with the receiver's revocation base point in order
// to derive the keys that are used within HTLC scripts.
HtlcPoint *btcec.PublicKey
// FirstCommitmentPoint is the first commitment point for the sending // FirstCommitmentPoint is the first commitment point for the sending
// party. This value should be combined with the receiver's revocation // party. This value should be combined with the receiver's revocation
// base point in order to derive the revocation keys that are placed // base point in order to derive the revocation keys that are placed
@ -105,6 +111,7 @@ func (a *AcceptChannel) Encode(w io.Writer, pver uint32) error {
a.RevocationPoint, a.RevocationPoint,
a.PaymentPoint, a.PaymentPoint,
a.DelayedPaymentPoint, a.DelayedPaymentPoint,
a.HtlcPoint,
a.FirstCommitmentPoint, a.FirstCommitmentPoint,
) )
} }
@ -128,6 +135,7 @@ func (a *AcceptChannel) Decode(r io.Reader, pver uint32) error {
&a.RevocationPoint, &a.RevocationPoint,
&a.PaymentPoint, &a.PaymentPoint,
&a.DelayedPaymentPoint, &a.DelayedPaymentPoint,
&a.HtlcPoint,
&a.FirstCommitmentPoint, &a.FirstCommitmentPoint,
) )
} }
@ -145,6 +153,6 @@ func (a *AcceptChannel) MsgType() MessageType {
// //
// This is part of the lnwire.Message interface. // This is part of the lnwire.Message interface.
func (a *AcceptChannel) MaxPayloadLength(uint32) uint32 { func (a *AcceptChannel) MaxPayloadLength(uint32) uint32 {
// 32 + (8 * 4) + (4 * 1) + (2 * 2) + (33 * 5) // 32 + (8 * 4) + (4 * 1) + (2 * 2) + (33 * 6)
return 237 return 270
} }

@ -188,6 +188,11 @@ func TestLightningWireProtocol(t *testing.T) {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
} }
req.HtlcPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.FirstCommitmentPoint, err = randPubKey() req.FirstCommitmentPoint, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
@ -233,6 +238,11 @@ func TestLightningWireProtocol(t *testing.T) {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
} }
req.HtlcPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.FirstCommitmentPoint, err = randPubKey() req.FirstCommitmentPoint, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)

@ -102,6 +102,12 @@ type OpenChannel struct {
// where they claim funds. // where they claim funds.
DelayedPaymentPoint *btcec.PublicKey DelayedPaymentPoint *btcec.PublicKey
// HtlcPoint is the base point used to derive the set of keys for this
// party that will be used within the HTLC public key scripts. This
// value is combined with the receiver's revocation base point in order
// to derive the keys that are used within HTLC scripts.
HtlcPoint *btcec.PublicKey
// FirstCommitmentPoint is the first commitment point for the sending // FirstCommitmentPoint is the first commitment point for the sending
// party. This value should be combined with the receiver's revocation // party. This value should be combined with the receiver's revocation
// base point in order to derive the revocation keys that are placed // base point in order to derive the revocation keys that are placed
@ -141,6 +147,7 @@ func (o *OpenChannel) Encode(w io.Writer, pver uint32) error {
o.RevocationPoint, o.RevocationPoint,
o.PaymentPoint, o.PaymentPoint,
o.DelayedPaymentPoint, o.DelayedPaymentPoint,
o.HtlcPoint,
o.FirstCommitmentPoint, o.FirstCommitmentPoint,
o.ChannelFlags, o.ChannelFlags,
) )
@ -168,6 +175,7 @@ func (o *OpenChannel) Decode(r io.Reader, pver uint32) error {
&o.RevocationPoint, &o.RevocationPoint,
&o.PaymentPoint, &o.PaymentPoint,
&o.DelayedPaymentPoint, &o.DelayedPaymentPoint,
&o.HtlcPoint,
&o.FirstCommitmentPoint, &o.FirstCommitmentPoint,
&o.ChannelFlags, &o.ChannelFlags,
) )
@ -186,6 +194,6 @@ func (o *OpenChannel) MsgType() MessageType {
// //
// This is part of the lnwire.Message interface. // This is part of the lnwire.Message interface.
func (o *OpenChannel) MaxPayloadLength(uint32) uint32 { func (o *OpenChannel) MaxPayloadLength(uint32) uint32 {
// (32 * 2) + (8 * 6) + (4 * 1) + (2 * 2) + (33 * 5) + 1 // (32 * 2) + (8 * 6) + (4 * 1) + (2 * 2) + (33 * 6) + 1
return 286 return 319
} }