2017-06-28 18:22:23 +03:00
|
|
|
package lnwire
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/sha256"
|
|
|
|
"io"
|
|
|
|
)
|
|
|
|
|
2017-09-12 18:58:42 +03:00
|
|
|
// UpdateFailMalformedHTLC is sent by either the payment forwarder or by
|
|
|
|
// payment receiver to the payment sender in order to notify it that the onion
|
|
|
|
// blob can't be parsed. For that reason we send this message instead of
|
|
|
|
// obfuscate the onion failure.
|
2017-06-28 18:22:23 +03:00
|
|
|
type UpdateFailMalformedHTLC struct {
|
|
|
|
// ChanID is the particular active channel that this
|
|
|
|
// UpdateFailMalformedHTLC is bound to.
|
|
|
|
ChanID ChannelID
|
|
|
|
|
|
|
|
// ID references which HTLC on the remote node's commitment transaction
|
|
|
|
// has timed out.
|
|
|
|
ID uint64
|
|
|
|
|
|
|
|
// ShaOnionBlob hash of the onion blob on which can't be parsed by the
|
|
|
|
// node in the payment path.
|
|
|
|
ShaOnionBlob [sha256.Size]byte
|
|
|
|
|
|
|
|
// FailureCode the exact reason why onion blob haven't been parsed.
|
|
|
|
FailureCode FailCode
|
2020-01-28 04:25:36 +03:00
|
|
|
|
|
|
|
// ExtraData is the set of data that was appended to this message to
|
|
|
|
// fill out the full maximum transport message size. These fields can
|
|
|
|
// be used to specify optional data such as custom TLV fields.
|
|
|
|
ExtraData ExtraOpaqueData
|
2017-06-28 18:22:23 +03:00
|
|
|
}
|
|
|
|
|
2017-09-12 18:58:42 +03:00
|
|
|
// A compile time check to ensure UpdateFailMalformedHTLC implements the
|
|
|
|
// lnwire.Message interface.
|
2017-06-28 18:22:23 +03:00
|
|
|
var _ Message = (*UpdateFailMalformedHTLC)(nil)
|
|
|
|
|
|
|
|
// Decode deserializes a serialized UpdateFailMalformedHTLC message stored in the passed
|
|
|
|
// io.Reader observing the specified protocol version.
|
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
|
|
|
func (c *UpdateFailMalformedHTLC) Decode(r io.Reader, pver uint32) error {
|
2018-12-10 05:27:41 +03:00
|
|
|
return ReadElements(r,
|
2017-06-28 18:22:23 +03:00
|
|
|
&c.ChanID,
|
|
|
|
&c.ID,
|
|
|
|
c.ShaOnionBlob[:],
|
|
|
|
&c.FailureCode,
|
2020-01-28 04:25:36 +03:00
|
|
|
&c.ExtraData,
|
2017-06-28 18:22:23 +03:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2017-09-12 18:58:42 +03:00
|
|
|
// Encode serializes the target UpdateFailMalformedHTLC into the passed
|
|
|
|
// io.Writer observing the protocol version specified.
|
2017-06-28 18:22:23 +03:00
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
|
|
|
func (c *UpdateFailMalformedHTLC) Encode(w io.Writer, pver uint32) error {
|
2018-12-10 05:27:41 +03:00
|
|
|
return WriteElements(w,
|
2017-06-28 18:22:23 +03:00
|
|
|
c.ChanID,
|
|
|
|
c.ID,
|
|
|
|
c.ShaOnionBlob[:],
|
|
|
|
c.FailureCode,
|
2020-01-28 04:25:36 +03:00
|
|
|
c.ExtraData,
|
2017-06-28 18:22:23 +03:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// MsgType returns the integer uniquely identifying this message type on the
|
|
|
|
// wire.
|
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
|
|
|
func (c *UpdateFailMalformedHTLC) MsgType() MessageType {
|
|
|
|
return MsgUpdateFailMalformedHTLC
|
|
|
|
}
|
|
|
|
|
2017-09-12 18:58:42 +03:00
|
|
|
// MaxPayloadLength returns the maximum allowed payload size for a
|
|
|
|
// UpdateFailMalformedHTLC complete message observing the specified protocol
|
|
|
|
// version.
|
2017-06-28 18:22:23 +03:00
|
|
|
//
|
|
|
|
// This is part of the lnwire.Message interface.
|
|
|
|
func (c *UpdateFailMalformedHTLC) MaxPayloadLength(uint32) uint32 {
|
2020-01-28 04:25:36 +03:00
|
|
|
return MaxMsgBody
|
2017-06-28 18:22:23 +03:00
|
|
|
}
|
2019-09-25 22:00:59 +03:00
|
|
|
|
|
|
|
// TargetChanID returns the channel id of the link for which this message is
|
|
|
|
// intended.
|
|
|
|
//
|
2020-07-03 00:46:06 +03:00
|
|
|
// NOTE: Part of peer.LinkUpdater interface.
|
2019-09-25 22:00:59 +03:00
|
|
|
func (c *UpdateFailMalformedHTLC) TargetChanID() ChannelID {
|
|
|
|
return c.ChanID
|
|
|
|
}
|