Reject integers w/ appended zero's
This commit is contained in:
parent
c39484bc4b
commit
59597d23a5
@ -99,6 +99,8 @@ func (err *decodeError) Error() string {
|
|||||||
|
|
||||||
func wrapStreamError(err error, typ reflect.Type) error {
|
func wrapStreamError(err error, typ reflect.Type) error {
|
||||||
switch err {
|
switch err {
|
||||||
|
case ErrCanonInt:
|
||||||
|
return &decodeError{msg: "canon int error appends zero's", typ: typ}
|
||||||
case ErrExpectedList:
|
case ErrExpectedList:
|
||||||
return &decodeError{msg: "expected input list", typ: typ}
|
return &decodeError{msg: "expected input list", typ: typ}
|
||||||
case ErrExpectedString:
|
case ErrExpectedString:
|
||||||
@ -184,6 +186,12 @@ func decodeBigInt(s *Stream, val reflect.Value) error {
|
|||||||
i = new(big.Int)
|
i = new(big.Int)
|
||||||
val.Set(reflect.ValueOf(i))
|
val.Set(reflect.ValueOf(i))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Reject big integers which are zero appended
|
||||||
|
if len(b) > 0 && b[0] == 0 {
|
||||||
|
return wrapStreamError(ErrCanonInt, val.Type())
|
||||||
|
}
|
||||||
|
|
||||||
i.SetBytes(b)
|
i.SetBytes(b)
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -460,6 +468,7 @@ var (
|
|||||||
// Other errors
|
// Other errors
|
||||||
ErrExpectedString = errors.New("rlp: expected String or Byte")
|
ErrExpectedString = errors.New("rlp: expected String or Byte")
|
||||||
ErrExpectedList = errors.New("rlp: expected List")
|
ErrExpectedList = errors.New("rlp: expected List")
|
||||||
|
ErrCanonInt = errors.New("rlp: expected Int")
|
||||||
ErrElemTooLarge = errors.New("rlp: element is larger than containing list")
|
ErrElemTooLarge = errors.New("rlp: element is larger than containing list")
|
||||||
|
|
||||||
// internal errors
|
// internal errors
|
||||||
|
@ -312,6 +312,7 @@ var decodeTests = []decodeTest{
|
|||||||
// big ints
|
// big ints
|
||||||
{input: "01", ptr: new(*big.Int), value: big.NewInt(1)},
|
{input: "01", ptr: new(*big.Int), value: big.NewInt(1)},
|
||||||
{input: "89FFFFFFFFFFFFFFFFFF", ptr: new(*big.Int), value: veryBigInt},
|
{input: "89FFFFFFFFFFFFFFFFFF", ptr: new(*big.Int), value: veryBigInt},
|
||||||
|
{input: "820001", ptr: new(big.Int), error: "rlp: canon int error appends zero's for *big.Int"},
|
||||||
{input: "10", ptr: new(big.Int), value: *big.NewInt(16)}, // non-pointer also works
|
{input: "10", ptr: new(big.Int), value: *big.NewInt(16)}, // non-pointer also works
|
||||||
{input: "C0", ptr: new(*big.Int), error: "rlp: expected input string or byte for *big.Int"},
|
{input: "C0", ptr: new(*big.Int), error: "rlp: expected input string or byte for *big.Int"},
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user