2016-12-07 16:46:22 +01:00
|
|
|
package lnwire
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"io"
|
2016-12-22 21:17:24 +01:00
|
|
|
|
|
|
|
"github.com/roasbeef/btcd/btcec"
|
2016-12-07 16:46:22 +01:00
|
|
|
)
|
|
|
|
|
2017-04-18 01:20:15 +02:00
|
|
|
// ChannelUpdate message is used after channel has been initially announced.
|
|
|
|
// Each side independently announces its fees and minimum expiry for HTLCs and
|
|
|
|
// other parameters. Also this message is used to redeclare initially setted
|
|
|
|
// channel parameters.
|
|
|
|
type ChannelUpdate struct {
|
2016-12-07 16:46:22 +01:00
|
|
|
// Signature is used to validate the announced data and prove the
|
|
|
|
// ownership of node id.
|
|
|
|
Signature *btcec.Signature
|
|
|
|
|
2017-03-27 17:22:37 +02:00
|
|
|
// ShortChannelID is the unique description of the funding transaction.
|
|
|
|
ShortChannelID ShortChannelID
|
2016-12-07 16:46:22 +01:00
|
|
|
|
|
|
|
// Timestamp allows ordering in the case of multiple announcements.
|
|
|
|
// We should ignore the message if timestamp is not greater than
|
|
|
|
// the last-received.
|
|
|
|
Timestamp uint32
|
|
|
|
|
|
|
|
// Flags least-significant bit must be set to 0 if the creating node
|
2017-03-06 05:43:34 +01:00
|
|
|
// corresponds to the first node in the previously sent channel
|
2016-12-07 16:46:22 +01:00
|
|
|
// announcement and 1 otherwise.
|
|
|
|
Flags uint16
|
|
|
|
|
2017-03-06 05:43:34 +01:00
|
|
|
// TimeLockDelta is the minimum number of blocks this node requires to
|
|
|
|
// be added to the expiry of HTLCs. This is a security parameter
|
|
|
|
// determined by the node operator. This value represents the required
|
|
|
|
// gap between the time locks of the incoming and outgoing HTLC's set
|
|
|
|
// to this node.
|
|
|
|
TimeLockDelta uint16
|
2016-12-07 16:46:22 +01:00
|
|
|
|
2017-03-08 23:20:00 +01:00
|
|
|
// HtlcMinimumMsat is the minimum HTLC value which will be accepted.
|
|
|
|
HtlcMinimumMsat uint32
|
2016-12-07 16:46:22 +01:00
|
|
|
|
|
|
|
// FeeBaseMstat...
|
2017-03-08 23:20:00 +01:00
|
|
|
FeeBaseMsat uint32
|
2016-12-07 16:46:22 +01:00
|
|
|
|
|
|
|
// FeeProportionalMillionths...
|
|
|
|
FeeProportionalMillionths uint32
|
|
|
|
}
|
|
|
|
|
2017-04-18 01:20:15 +02:00
|
|
|
// A compile time check to ensure ChannelUpdate implements the lnwire.Message
|
|
|
|
// interface.
|
|
|
|
var _ Message = (*ChannelUpdate)(nil)
|
2016-12-07 16:46:22 +01:00
|
|
|
|
2017-04-18 01:20:15 +02:00
|
|
|
// Decode deserializes a serialized ChannelUpdate stored in the passed
|
|
|
|
// io.Reader observing the specified protocol version.
|
2016-12-07 16:46:22 +01:00
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
2017-04-18 01:20:15 +02:00
|
|
|
func (a *ChannelUpdate) Decode(r io.Reader, pver uint32) error {
|
2017-02-23 19:59:50 +01:00
|
|
|
return readElements(r,
|
2017-02-23 20:56:47 +01:00
|
|
|
&a.Signature,
|
2017-03-27 17:22:37 +02:00
|
|
|
&a.ShortChannelID,
|
2017-02-23 20:56:47 +01:00
|
|
|
&a.Timestamp,
|
|
|
|
&a.Flags,
|
|
|
|
&a.TimeLockDelta,
|
|
|
|
&a.HtlcMinimumMsat,
|
|
|
|
&a.FeeBaseMsat,
|
|
|
|
&a.FeeProportionalMillionths,
|
2016-12-07 16:46:22 +01:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-04-18 01:20:15 +02:00
|
|
|
// Encode serializes the target ChannelUpdate into the passed io.Writer
|
|
|
|
// observing the protocol version specified.
|
2016-12-07 16:46:22 +01:00
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
2017-04-18 01:20:15 +02:00
|
|
|
func (a *ChannelUpdate) Encode(w io.Writer, pver uint32) error {
|
2017-02-23 19:59:50 +01:00
|
|
|
return writeElements(w,
|
2017-02-23 20:56:47 +01:00
|
|
|
a.Signature,
|
2017-03-27 17:22:37 +02:00
|
|
|
a.ShortChannelID,
|
2017-02-23 20:56:47 +01:00
|
|
|
a.Timestamp,
|
|
|
|
a.Flags,
|
|
|
|
a.TimeLockDelta,
|
|
|
|
a.HtlcMinimumMsat,
|
|
|
|
a.FeeBaseMsat,
|
|
|
|
a.FeeProportionalMillionths,
|
2016-12-07 16:46:22 +01:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Command returns the integer uniquely identifying this message type on the
|
|
|
|
// wire.
|
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
2017-04-18 01:20:15 +02:00
|
|
|
func (a *ChannelUpdate) Command() uint32 {
|
|
|
|
return CmdChannelUpdate
|
2016-12-07 16:46:22 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// MaxPayloadLength returns the maximum allowed payload size for this message
|
|
|
|
// observing the specified protocol version.
|
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
2017-04-18 01:20:15 +02:00
|
|
|
func (a *ChannelUpdate) MaxPayloadLength(pver uint32) uint32 {
|
2016-12-07 16:46:22 +01:00
|
|
|
var length uint32
|
|
|
|
|
|
|
|
// Signature - 64 bytes
|
|
|
|
length += 64
|
|
|
|
|
2017-03-27 17:22:37 +02:00
|
|
|
// ShortChannelID - 8 bytes
|
2016-12-07 16:46:22 +01:00
|
|
|
length += 8
|
|
|
|
|
|
|
|
// Timestamp - 4 bytes
|
|
|
|
length += 4
|
|
|
|
|
|
|
|
// Flags - 2 bytes
|
|
|
|
length += 2
|
|
|
|
|
|
|
|
// Expiry - 2 bytes
|
|
|
|
length += 2
|
|
|
|
|
|
|
|
// HtlcMinimumMstat - 4 bytes
|
|
|
|
length += 4
|
|
|
|
|
|
|
|
// FeeBaseMstat - 4 bytes
|
|
|
|
length += 4
|
|
|
|
|
|
|
|
// FeeProportionalMillionths - 4 bytes
|
|
|
|
length += 4
|
|
|
|
|
|
|
|
return length
|
|
|
|
}
|
|
|
|
|
2017-04-18 01:20:15 +02:00
|
|
|
// DataToSign is used to retrieve part of the announcement message which should
|
|
|
|
// be signed.
|
|
|
|
func (a *ChannelUpdate) DataToSign() ([]byte, error) {
|
2016-12-07 16:46:22 +01:00
|
|
|
|
|
|
|
// We should not include the signatures itself.
|
|
|
|
var w bytes.Buffer
|
|
|
|
err := writeElements(&w,
|
2017-03-27 17:22:37 +02:00
|
|
|
a.ShortChannelID,
|
2017-02-23 20:56:47 +01:00
|
|
|
a.Timestamp,
|
|
|
|
a.Flags,
|
|
|
|
a.TimeLockDelta,
|
|
|
|
a.HtlcMinimumMsat,
|
|
|
|
a.FeeBaseMsat,
|
|
|
|
a.FeeProportionalMillionths,
|
2016-12-07 16:46:22 +01:00
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return w.Bytes(), nil
|
|
|
|
}
|