lnwire: only check payload for proper size if encoding type is sorted plain
In this commit, we fix a slight bug in the parsing of encoded short channel ID's. Before this commit, we would always assume that the remote peer was sending us the sorted+encoded variant of the short channel ID's. In the case that they weren't (as there isn't yet a feature bit), we would assert this check and fail early as atm we don't support any sort of compression.
This commit is contained in:
parent
2fa2644aec
commit
1c8c1cba96
@ -109,14 +109,6 @@ func decodeShortChanIDs(r io.Reader) (ShortChanIDEncoding, []ShortChannelID, err
|
|||||||
// as that was just the encoding type.
|
// as that was just the encoding type.
|
||||||
queryBody = queryBody[1:]
|
queryBody = queryBody[1:]
|
||||||
|
|
||||||
// If after extracting the encoding type, then number of remaining
|
|
||||||
// bytes instead a whole multiple of the size of an encoded short
|
|
||||||
// channel ID (8 bytes), then we'll return a parsing error.
|
|
||||||
if len(queryBody)%8 != 0 {
|
|
||||||
return 0, nil, fmt.Errorf("whole number of short chan ID's "+
|
|
||||||
"cannot be encoded in len=%v", len(queryBody))
|
|
||||||
}
|
|
||||||
|
|
||||||
// Otherwise, depending on the encoding type, we'll decode the encode
|
// Otherwise, depending on the encoding type, we'll decode the encode
|
||||||
// short channel ID's in a different manner.
|
// short channel ID's in a different manner.
|
||||||
switch encodingType {
|
switch encodingType {
|
||||||
@ -124,6 +116,16 @@ func decodeShortChanIDs(r io.Reader) (ShortChanIDEncoding, []ShortChannelID, err
|
|||||||
// In this encoding, we'll simply read a sort array of encoded short
|
// In this encoding, we'll simply read a sort array of encoded short
|
||||||
// channel ID's from the buffer.
|
// channel ID's from the buffer.
|
||||||
case EncodingSortedPlain:
|
case EncodingSortedPlain:
|
||||||
|
// If after extracting the encoding type, then number of
|
||||||
|
// remaining bytes instead a whole multiple of the size of an
|
||||||
|
// encoded short channel ID (8 bytes), then we'll return a
|
||||||
|
// parsing error.
|
||||||
|
if len(queryBody)%8 != 0 {
|
||||||
|
return 0, nil, fmt.Errorf("whole number of short "+
|
||||||
|
"chan ID's cannot be encoded in len=%v",
|
||||||
|
len(queryBody))
|
||||||
|
}
|
||||||
|
|
||||||
// As each short channel ID is encoded as 8 bytes, we can
|
// As each short channel ID is encoded as 8 bytes, we can
|
||||||
// compute the number of bytes encoded based on the size of the
|
// compute the number of bytes encoded based on the size of the
|
||||||
// query body.
|
// query body.
|
||||||
|
Loading…
Reference in New Issue
Block a user