lnwire: return more descriptive errors in DecodeFailure for onion errors

This commit is contained in:
Olaoluwa Osuntokun 2017-09-12 17:55:20 +02:00
parent 67aa519480
commit 1e5949cfbb
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21

@ -831,7 +831,7 @@ func DecodeFailure(r io.Reader, pver uint32) (FailureMessage, error) {
// is a 2 byte length followed by the payload itself. // is a 2 byte length followed by the payload itself.
var failureLength uint16 var failureLength uint16
if err := readElement(r, &failureLength); err != nil { if err := readElement(r, &failureLength); err != nil {
return nil, err return nil, fmt.Errorf("unable to read error len: %v", err)
} }
if failureLength > failureMessageLength { if failureLength > failureMessageLength {
return nil, fmt.Errorf("failure message is too "+ return nil, fmt.Errorf("failure message is too "+
@ -839,7 +839,8 @@ func DecodeFailure(r io.Reader, pver uint32) (FailureMessage, error) {
} }
failureData := make([]byte, failureLength) failureData := make([]byte, failureLength)
if _, err := io.ReadFull(r, failureData); err != nil { if _, err := io.ReadFull(r, failureData); err != nil {
return nil, err return nil, fmt.Errorf("unable to full read payload of "+
"%v: %v", failureLength, err)
} }
dataReader := bytes.NewReader(failureData) dataReader := bytes.NewReader(failureData)
@ -848,7 +849,7 @@ func DecodeFailure(r io.Reader, pver uint32) (FailureMessage, error) {
// the first two bytes of the buffer. // the first two bytes of the buffer.
var codeBytes [2]byte var codeBytes [2]byte
if _, err := io.ReadFull(dataReader, codeBytes[:]); err != nil { if _, err := io.ReadFull(dataReader, codeBytes[:]); err != nil {
return nil, err return nil, fmt.Errorf("unable to read failure code: %v", err)
} }
failCode := FailCode(binary.BigEndian.Uint16(codeBytes[:])) failCode := FailCode(binary.BigEndian.Uint16(codeBytes[:]))
@ -856,7 +857,7 @@ func DecodeFailure(r io.Reader, pver uint32) (FailureMessage, error) {
// additional data if needed. // additional data if needed.
failure, err := makeEmptyOnionError(failCode) failure, err := makeEmptyOnionError(failCode)
if err != nil { if err != nil {
return nil, err return nil, fmt.Errorf("unable to make empty error: %v", err)
} }
// Finally, if this failure has a payload, then we'll read that now as // Finally, if this failure has a payload, then we'll read that now as
@ -864,7 +865,8 @@ func DecodeFailure(r io.Reader, pver uint32) (FailureMessage, error) {
switch f := failure.(type) { switch f := failure.(type) {
case Serializable: case Serializable:
if err := f.Decode(dataReader, pver); err != nil { if err := f.Decode(dataReader, pver); err != nil {
return nil, err return nil, fmt.Errorf("unable to decode error "+
"update: %v", err)
} }
} }