Accept number or string for BlockFilterArgs limit/offset

This commit is contained in:
Taylor Gerring 2015-03-26 19:17:25 +01:00
parent 6661bc35ef
commit 3ab9f26943

View File

@ -42,6 +42,24 @@ func blockHeight(raw interface{}, number *int64) error {
return nil return nil
} }
func numString(raw interface{}, number *int64) error {
// Parse as integer
num, ok := raw.(float64)
if ok {
*number = int64(num)
return nil
}
// Parse as string/hexstring
str, ok := raw.(string)
if !ok {
return NewInvalidTypeError("", "not a number or string")
}
*number = common.String2Big(str).Int64()
return nil
}
type GetBlockByHashArgs struct { type GetBlockByHashArgs struct {
BlockHash common.Hash BlockHash common.Hash
IncludeTxs bool IncludeTxs bool
@ -410,8 +428,8 @@ func (args *BlockFilterArgs) UnmarshalJSON(b []byte) (err error) {
var obj []struct { var obj []struct {
FromBlock interface{} `json:"fromBlock"` FromBlock interface{} `json:"fromBlock"`
ToBlock interface{} `json:"toBlock"` ToBlock interface{} `json:"toBlock"`
Limit string `json:"limit"` Limit interface{} `json:"limit"`
Offset string `json:"offset"` Offset interface{} `json:"offset"`
Address string `json:"address"` Address string `json:"address"`
Topics []interface{} `json:"topics"` Topics []interface{} `json:"topics"`
} }
@ -439,22 +457,16 @@ func (args *BlockFilterArgs) UnmarshalJSON(b []byte) (err error) {
} }
args.Latest = num args.Latest = num
tostr, ok := obj[0].ToBlock.(string) if err := numString(obj[0].Limit, &num); err != nil {
if !ok { return err
return NewInvalidTypeError("toBlock", "not a string")
} }
args.Max = int(num)
switch tostr { if err := numString(obj[0].Offset, &num); err != nil {
case "latest": return err
args.Latest = -1
case "pending":
args.Latest = -2
default:
args.Latest = int64(common.Big(obj[0].ToBlock.(string)).Int64())
} }
args.Skip = int(num)
args.Max = int(common.Big(obj[0].Limit).Int64())
args.Skip = int(common.Big(obj[0].Offset).Int64())
args.Address = obj[0].Address args.Address = obj[0].Address
args.Topics = obj[0].Topics args.Topics = obj[0].Topics