aboutsummaryrefslogtreecommitdiffstats
path: root/rlp
diff options
context:
space:
mode:
authorFelix Lange <fjl@twurst.com>2015-07-18 07:47:17 +0800
committerJeffrey Wilcke <geffobscura@gmail.com>2015-07-22 19:34:16 +0800
commit7b99278eb017fd406a83841a8b935f93f6840010 (patch)
tree51d90a7412399d5731e95e51d1b8ea1d92113e9d /rlp
parentaaf8ae1d0b780d8a51c011eae778f57055c93e96 (diff)
downloadgo-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.tar
go-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.tar.gz
go-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.tar.bz2
go-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.tar.lz
go-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.tar.xz
go-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.tar.zst
go-tangerine-7b99278eb017fd406a83841a8b935f93f6840010.zip
rlp: reject trailing data when using DecodeBytes
Diffstat (limited to 'rlp')
-rw-r--r--rlp/decode.go14
1 files changed, 13 insertions, 1 deletions
diff --git a/rlp/decode.go b/rlp/decode.go
index 4462d4be4..f17690522 100644
--- a/rlp/decode.go
+++ b/rlp/decode.go
@@ -110,9 +110,17 @@ func Decode(r io.Reader, val interface{}) error {
// DecodeBytes parses RLP data from b into val.
// Please see the documentation of Decode for the decoding rules.
+// The input must contain exactly one value and no trailing data.
func DecodeBytes(b []byte, val interface{}) error {
// TODO: this could use a Stream from a pool.
- return NewStream(bytes.NewReader(b), uint64(len(b))).Decode(val)
+ r := bytes.NewReader(b)
+ if err := NewStream(r, uint64(len(b))).Decode(val); err != nil {
+ return err
+ }
+ if r.Len() > 0 {
+ return ErrMoreThanOneValue
+ }
+ return nil
}
type decodeError struct {
@@ -517,6 +525,10 @@ var (
ErrElemTooLarge = errors.New("rlp: element is larger than containing list")
ErrValueTooLarge = errors.New("rlp: value size exceeds available input length")
+ // This error is reported by DecodeBytes if the slice contains
+ // additional data after the first RLP value.
+ ErrMoreThanOneValue = errors.New("rlp: input contains more than one value")
+
// internal errors
errNotInList = errors.New("rlp: call of ListEnd outside of any list")
errNotAtEOL = errors.New("rlp: call of ListEnd not positioned at EOL")