From 9b97e4e203a0493251c500123fcfa3be0f1a94d0 Mon Sep 17 00:00:00 2001 From: ffranr Date: Wed, 19 Jun 2024 15:54:40 +0100 Subject: [PATCH] tapchannelmsg: add max read size argument This commit introduces a `max read size` argument to the `ReadOpenChannel` and `ReadCommitment` functions. Testing showed that with large but valid asset amounts, the channel custom records buffer size exceeded `tlv.MaxRecordSize`. To address this, we have two options: increase the max record size for channel data or dynamically set the max read size. Given that the data is already in memory, the latter approach is more robust. --- tapchannelmsg/custom_channel_data.go | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/tapchannelmsg/custom_channel_data.go b/tapchannelmsg/custom_channel_data.go index c1dbf00aa..ea2684c9d 100644 --- a/tapchannelmsg/custom_channel_data.go +++ b/tapchannelmsg/custom_channel_data.go @@ -10,15 +10,12 @@ import ( "github.com/btcsuite/btcd/wire" "github.com/lightninglabs/taproot-assets/rfqmsg" "github.com/lightningnetwork/lnd/lnrpc" - "github.com/lightningnetwork/lnd/tlv" "google.golang.org/protobuf/proto" ) // ReadOpenChannel reads the content of an OpenChannel struct from a reader. -func ReadOpenChannel(r io.Reader) (*OpenChannel, error) { - openChanData, err := wire.ReadVarBytes( - r, 0, tlv.MaxRecordSize, "chan data", - ) +func ReadOpenChannel(r io.Reader, maxReadSize uint32) (*OpenChannel, error) { + openChanData, err := wire.ReadVarBytes(r, 0, maxReadSize, "chan data") if err != nil { return nil, fmt.Errorf("unable to read open chan data: %w", err) } @@ -34,9 +31,9 @@ func ReadOpenChannel(r io.Reader) (*OpenChannel, error) { } // ReadCommitment reads the content of a Commitment struct from a reader. -func ReadCommitment(r io.Reader) (*Commitment, error) { +func ReadCommitment(r io.Reader, maxReadSize uint32) (*Commitment, error) { localCommitData, err := wire.ReadVarBytes( - r, 0, tlv.MaxRecordSize, "commit data", + r, 0, maxReadSize, "commit data", ) if err != nil { return nil, fmt.Errorf("unable to read open chan data: %w", err) @@ -104,12 +101,16 @@ func ReadChannelCustomData(chanData []byte) (*ChannelCustomData, error) { // The custom channel data is encoded as two var byte blobs. One for // the static funding data, one for the state of our current local // commitment. - openChannel, err := ReadOpenChannel(chanDataReader) + openChannel, err := ReadOpenChannel( + chanDataReader, uint32(len(chanData)), + ) if err != nil { return nil, fmt.Errorf("unable to read open channel: %w", err) } - localCommit, err := ReadCommitment(chanDataReader) + localCommit, err := ReadCommitment( + chanDataReader, uint32(len(chanData)), + ) if err != nil { return nil, fmt.Errorf("unable to read local commitment: %w", err) @@ -233,7 +234,9 @@ func ReadBalanceCustomData(balanceData []byte) (*BalanceCustomData, error) { OpenChannels: make([]*Commitment, numOpenChannels), } for i := uint64(0); i < numOpenChannels; i++ { - result.OpenChannels[i], err = ReadCommitment(balanceDataReader) + result.OpenChannels[i], err = ReadCommitment( + balanceDataReader, uint32(len(balanceData)), + ) if err != nil { return nil, fmt.Errorf("unable to read open channel: "+ "%w", err) @@ -250,7 +253,7 @@ func ReadBalanceCustomData(balanceData []byte) (*BalanceCustomData, error) { result.PendingChannels = make([]*Commitment, numPendingChannels) for i := uint64(0); i < numPendingChannels; i++ { result.PendingChannels[i], err = ReadCommitment( - balanceDataReader, + balanceDataReader, uint32(len(balanceData)), ) if err != nil { return nil, fmt.Errorf("unable to read pending "+