Merge pull request #9 from openrelayxyz/bugfix/unmarshal-panic

Appending unmarshalJSON methods to avoid panic if mal-formed arguments are passed.
This commit is contained in:
Philip Morlier 2022-01-27 14:14:40 -05:00 committed by GitHub
commit 393e2167a2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,10 +1,10 @@
package core package core
import ( import (
"strings"
"bytes" "bytes"
"fmt"
"encoding/hex" "encoding/hex"
"fmt"
"strings"
) )
type Hash [32]byte type Hash [32]byte
@ -15,7 +15,10 @@ func (h Hash) MarshalJSON() ([]byte, error) {
func (h *Hash) UnmarshalJSON(data []byte) error { func (h *Hash) UnmarshalJSON(data []byte) error {
d := bytes.TrimPrefix(bytes.Trim(data, `"`), []byte("0x")) d := bytes.TrimPrefix(bytes.Trim(data, `"`), []byte("0x"))
_, err := hex.Decode(h[(64 - len(d)) / 2:], d) if len(d) > 64 {
return fmt.Errorf("argument of invalid length")
}
_, err := hex.Decode(h[(64-len(d))/2:], d)
return err return err
} }
@ -30,7 +33,7 @@ func (h Hash) String() string {
func HexToHash(data string) Hash { func HexToHash(data string) Hash {
h := Hash{} h := Hash{}
b, _ := hex.DecodeString(strings.TrimPrefix(strings.Trim(data, `"`), "0x")) b, _ := hex.DecodeString(strings.TrimPrefix(strings.Trim(data, `"`), "0x"))
copy(h[32 - len(b):], b) copy(h[32-len(b):], b)
return h return h
} }
@ -48,7 +51,10 @@ func (h Address) MarshalJSON() ([]byte, error) {
func (h *Address) UnmarshalJSON(data []byte) error { func (h *Address) UnmarshalJSON(data []byte) error {
d := bytes.TrimPrefix(bytes.Trim(data, `"`), []byte("0x")) d := bytes.TrimPrefix(bytes.Trim(data, `"`), []byte("0x"))
_, err := hex.Decode(h[(40 - len(d))/2:], d) if len(d) > 40 {
return fmt.Errorf("argument of invalid length")
}
_, err := hex.Decode(h[(40-len(d))/2:], d)
return err return err
} }
@ -56,11 +62,10 @@ func (h Address) String() string {
return fmt.Sprintf("%#x", h[:]) return fmt.Sprintf("%#x", h[:])
} }
func HexToAddress(data string) Address { func HexToAddress(data string) Address {
h := Address{} h := Address{}
b, _ := hex.DecodeString(strings.TrimPrefix(strings.Trim(data, `"`), "0x")) b, _ := hex.DecodeString(strings.TrimPrefix(strings.Trim(data, `"`), "0x"))
copy(h[20 - len(b):], b) copy(h[20-len(b):], b)
return h return h
} }
@ -70,7 +75,6 @@ func BytesToAddress(b []byte) Address {
return h return h
} }
type ChainEvent struct { type ChainEvent struct {
Block []byte // RLP Encoded block Block []byte // RLP Encoded block
Hash Hash Hash Hash
@ -81,12 +85,12 @@ type ChainSideEvent struct {
Block []byte // RLP Encoded block Block []byte // RLP Encoded block
} }
type ChainHeadEvent struct{ type ChainHeadEvent struct {
Block []byte // RLP Encoded block Block []byte // RLP Encoded block
} }
type NewTxsEvent struct{ type NewTxsEvent struct {
Txs [][]byte // []RLP encoded transaction Txs [][]byte // []RLP encoded transaction
} }
type API struct { type API struct {
@ -96,7 +100,6 @@ type API struct {
Public bool Public bool
} }
func CopyBytes(a []byte) []byte { func CopyBytes(a []byte) []byte {
b := make([]byte, len(a)) b := make([]byte, len(a))
copy(b[:], a[:]) copy(b[:], a[:])