• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

lightningnetwork / lnd / 12199391122

06 Dec 2024 01:10PM UTC coverage: 49.807% (-9.1%) from 58.933%
12199391122

push

github

web-flow
Merge pull request #9337 from Guayaba221/patch-1

chore: fix typo in ruby.md

100137 of 201051 relevant lines covered (49.81%)

2.07 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

73.58
/lnwire/closing_signed.go
1
package lnwire
2

3
import (
4
        "bytes"
5
        "io"
6

7
        "github.com/btcsuite/btcd/btcutil"
8
        "github.com/lightningnetwork/lnd/tlv"
9
)
10

11
// ClosingSigned is sent by both parties to a channel once the channel is clear
12
// of HTLCs, and is primarily concerned with negotiating fees for the close
13
// transaction. Each party provides a signature for a transaction with a fee
14
// that they believe is fair. The process terminates when both sides agree on
15
// the same fee, or when one side force closes the channel.
16
//
17
// NOTE: The responder is able to send a signature without any additional
18
// messages as all transactions are assembled observing BIP 69 which defines a
19
// canonical ordering for input/outputs. Therefore, both sides are able to
20
// arrive at an identical closure transaction as they know the order of the
21
// inputs/outputs.
22
type ClosingSigned struct {
23
        // ChannelID serves to identify which channel is to be closed.
24
        ChannelID ChannelID
25

26
        // FeeSatoshis is the total fee in satoshis that the party to the
27
        // channel would like to propose for the close transaction.
28
        FeeSatoshis btcutil.Amount
29

30
        // Signature is for the proposed channel close transaction.
31
        Signature Sig
32

33
        // PartialSig is used to transmit a musig2 extended partial signature
34
        // that signs the latest fee offer. The nonce isn't sent along side, as
35
        // that has already been sent in the initial shutdown message.
36
        //
37
        // NOTE: This field is only populated if a musig2 taproot channel is
38
        // being signed for. In this case, the above Sig type MUST be blank.
39
        PartialSig OptPartialSigTLV
40

41
        // ExtraData is the set of data that was appended to this message to
42
        // fill out the full maximum transport message size. These fields can
43
        // be used to specify optional data such as custom TLV fields.
44
        ExtraData ExtraOpaqueData
45
}
46

47
// NewClosingSigned creates a new empty ClosingSigned message.
48
func NewClosingSigned(cid ChannelID, fs btcutil.Amount,
49
        sig Sig) *ClosingSigned {
4✔
50

4✔
51
        return &ClosingSigned{
4✔
52
                ChannelID:   cid,
4✔
53
                FeeSatoshis: fs,
4✔
54
                Signature:   sig,
4✔
55
        }
4✔
56
}
4✔
57

58
// A compile time check to ensure ClosingSigned implements the lnwire.Message
59
// interface.
60
var _ Message = (*ClosingSigned)(nil)
61

62
// Decode deserializes a serialized ClosingSigned message stored in the passed
63
// io.Reader observing the specified protocol version.
64
//
65
// This is part of the lnwire.Message interface.
66
func (c *ClosingSigned) Decode(r io.Reader, pver uint32) error {
4✔
67
        err := ReadElements(
4✔
68
                r, &c.ChannelID, &c.FeeSatoshis, &c.Signature,
4✔
69
        )
4✔
70
        if err != nil {
4✔
71
                return err
×
72
        }
×
73

74
        var tlvRecords ExtraOpaqueData
4✔
75
        if err := ReadElements(r, &tlvRecords); err != nil {
4✔
76
                return err
×
77
        }
×
78

79
        partialSig := c.PartialSig.Zero()
4✔
80
        typeMap, err := tlvRecords.ExtractRecords(&partialSig)
4✔
81
        if err != nil {
4✔
82
                return err
×
83
        }
×
84

85
        // Set the corresponding TLV types if they were included in the stream.
86
        if val, ok := typeMap[c.PartialSig.TlvType()]; ok && val == nil {
8✔
87
                c.PartialSig = tlv.SomeRecordT(partialSig)
4✔
88
        }
4✔
89

90
        if len(tlvRecords) != 0 {
8✔
91
                c.ExtraData = tlvRecords
4✔
92
        }
4✔
93

94
        return nil
4✔
95
}
96

97
// Encode serializes the target ClosingSigned into the passed io.Writer
98
// observing the protocol version specified.
99
//
100
// This is part of the lnwire.Message interface.
101
func (c *ClosingSigned) Encode(w *bytes.Buffer, pver uint32) error {
4✔
102
        recordProducers := make([]tlv.RecordProducer, 0, 1)
4✔
103
        c.PartialSig.WhenSome(func(sig PartialSigTLV) {
8✔
104
                recordProducers = append(recordProducers, &sig)
4✔
105
        })
4✔
106
        err := EncodeMessageExtraData(&c.ExtraData, recordProducers...)
4✔
107
        if err != nil {
4✔
108
                return err
×
109
        }
×
110

111
        if err := WriteChannelID(w, c.ChannelID); err != nil {
4✔
112
                return err
×
113
        }
×
114

115
        if err := WriteSatoshi(w, c.FeeSatoshis); err != nil {
4✔
116
                return err
×
117
        }
×
118

119
        if err := WriteSig(w, c.Signature); err != nil {
4✔
120
                return err
×
121
        }
×
122

123
        return WriteBytes(w, c.ExtraData)
4✔
124
}
125

126
// MsgType returns the integer uniquely identifying this message type on the
127
// wire.
128
//
129
// This is part of the lnwire.Message interface.
130
func (c *ClosingSigned) MsgType() MessageType {
4✔
131
        return MsgClosingSigned
4✔
132
}
4✔
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc