2015-01-20 13:57:51 -06:00
|
|
|
package rpc
|
|
|
|
|
2015-03-04 08:22:59 -06:00
|
|
|
import (
|
2015-03-05 21:37:45 -06:00
|
|
|
"bytes"
|
2015-03-04 08:22:59 -06:00
|
|
|
"encoding/json"
|
|
|
|
"math/big"
|
2015-02-17 07:19:05 -06:00
|
|
|
|
2015-03-16 05:27:38 -05:00
|
|
|
"github.com/ethereum/go-ethereum/common"
|
2015-03-04 08:22:59 -06:00
|
|
|
)
|
2015-01-20 13:57:51 -06:00
|
|
|
|
2015-03-26 05:59:16 -05:00
|
|
|
func blockHeightFromJson(msg json.RawMessage, number *int64) error {
|
|
|
|
var raw interface{}
|
|
|
|
if err := json.Unmarshal(msg, &raw); err != nil {
|
|
|
|
return NewDecodeParamError(err.Error())
|
|
|
|
}
|
|
|
|
return blockHeight(raw, number)
|
|
|
|
}
|
|
|
|
|
|
|
|
func blockHeight(raw interface{}, number *int64) error {
|
2015-03-18 14:42:57 -05:00
|
|
|
// Parse as integer
|
2015-03-18 14:48:34 -05:00
|
|
|
num, ok := raw.(float64)
|
2015-03-18 14:42:57 -05:00
|
|
|
if ok {
|
2015-03-18 14:48:34 -05:00
|
|
|
*number = int64(num)
|
2015-03-18 14:42:57 -05:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Parse as string/hexstring
|
|
|
|
str, ok := raw.(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("blockNumber", "not a number or string")
|
2015-03-10 07:40:49 -05:00
|
|
|
}
|
|
|
|
|
2015-03-10 14:14:38 -05:00
|
|
|
switch str {
|
|
|
|
case "latest":
|
|
|
|
*number = -1
|
|
|
|
case "pending":
|
2015-03-23 10:36:12 -05:00
|
|
|
*number = -2
|
2015-03-10 14:14:38 -05:00
|
|
|
default:
|
2015-03-16 05:27:38 -05:00
|
|
|
*number = common.String2Big(str).Int64()
|
2015-03-10 07:40:49 -05:00
|
|
|
}
|
2015-03-18 14:42:57 -05:00
|
|
|
|
2015-03-10 07:40:49 -05:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
type GetBlockByHashArgs struct {
|
2015-03-26 04:14:52 -05:00
|
|
|
BlockHash common.Hash
|
2015-03-19 22:20:54 -05:00
|
|
|
IncludeTxs bool
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetBlockByHashArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
2015-03-11 10:27:24 -05:00
|
|
|
|
|
|
|
argstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("blockHash", "not a string")
|
2015-03-11 10:27:24 -05:00
|
|
|
}
|
2015-03-26 04:14:52 -05:00
|
|
|
args.BlockHash = common.HexToHash(argstr)
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
if len(obj) > 1 {
|
2015-03-19 22:20:54 -05:00
|
|
|
args.IncludeTxs = obj[1].(bool)
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
return nil
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
type GetBlockByNumberArgs struct {
|
2015-03-19 22:20:54 -05:00
|
|
|
BlockNumber int64
|
|
|
|
IncludeTxs bool
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetBlockByNumberArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-02-17 15:20:47 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
2015-03-09 20:38:37 -05:00
|
|
|
|
|
|
|
if v, ok := obj[0].(float64); ok {
|
|
|
|
args.BlockNumber = int64(v)
|
2015-03-26 05:07:14 -05:00
|
|
|
} else if v, ok := obj[0].(string); ok {
|
|
|
|
args.BlockNumber = common.Big(v).Int64()
|
2015-03-09 20:38:37 -05:00
|
|
|
} else {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("blockNumber", "not a number or string")
|
2015-03-09 20:38:37 -05:00
|
|
|
}
|
2015-02-17 15:20:47 -06:00
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
if len(obj) > 1 {
|
2015-03-19 22:20:54 -05:00
|
|
|
args.IncludeTxs = obj[1].(bool)
|
2015-02-17 15:20:47 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
return nil
|
2015-02-17 15:20:47 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
type NewTxArgs struct {
|
2015-03-26 04:34:21 -05:00
|
|
|
From common.Address
|
|
|
|
To common.Address
|
2015-03-05 21:37:45 -06:00
|
|
|
Value *big.Int
|
|
|
|
Gas *big.Int
|
|
|
|
GasPrice *big.Int
|
|
|
|
Data string
|
2015-03-10 07:40:49 -05:00
|
|
|
|
2015-03-10 14:14:38 -05:00
|
|
|
BlockNumber int64
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *NewTxArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-18 14:42:57 -05:00
|
|
|
var obj []json.RawMessage
|
|
|
|
var ext struct{ From, To, Value, Gas, GasPrice, Data string }
|
|
|
|
|
|
|
|
// Decode byte slice to array of RawMessages
|
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
2015-03-18 14:42:57 -05:00
|
|
|
// Check for sufficient params
|
|
|
|
if len(obj) < 1 {
|
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Decode 0th RawMessage to temporary struct
|
|
|
|
if err := json.Unmarshal(obj[0], &ext); err != nil {
|
|
|
|
return NewDecodeParamError(err.Error())
|
|
|
|
}
|
|
|
|
|
2015-03-26 04:34:21 -05:00
|
|
|
if len(ext.From) == 0 {
|
|
|
|
return NewValidationError("from", "is required")
|
|
|
|
}
|
|
|
|
|
|
|
|
args.From = common.HexToAddress(ext.From)
|
|
|
|
args.To = common.HexToAddress(ext.To)
|
2015-03-18 14:42:57 -05:00
|
|
|
args.Value = common.String2Big(ext.Value)
|
|
|
|
args.Gas = common.String2Big(ext.Gas)
|
|
|
|
args.GasPrice = common.String2Big(ext.GasPrice)
|
|
|
|
args.Data = ext.Data
|
|
|
|
|
|
|
|
// Check for optional BlockNumber param
|
|
|
|
if len(obj) > 1 {
|
2015-03-26 05:59:35 -05:00
|
|
|
if err := blockHeightFromJson(obj[1], &args.BlockNumber); err != nil {
|
2015-03-18 14:42:57 -05:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
2015-03-05 21:37:45 -06:00
|
|
|
|
2015-01-20 13:57:51 -06:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type GetStorageArgs struct {
|
2015-03-26 04:52:32 -05:00
|
|
|
Address common.Address
|
2015-03-06 09:54:08 -06:00
|
|
|
BlockNumber int64
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetStorageArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-18 14:42:57 -05:00
|
|
|
var obj []interface{}
|
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-01-29 13:39:26 -06:00
|
|
|
}
|
2015-03-05 21:37:45 -06:00
|
|
|
|
2015-03-18 14:42:57 -05:00
|
|
|
if len(obj) < 1 {
|
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
addstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("address", "not a string")
|
2015-03-18 14:42:57 -05:00
|
|
|
}
|
2015-03-26 04:52:32 -05:00
|
|
|
args.Address = common.HexToAddress(addstr)
|
2015-03-18 14:42:57 -05:00
|
|
|
|
|
|
|
if len(obj) > 1 {
|
2015-03-23 10:34:50 -05:00
|
|
|
if err := blockHeight(obj[1], &args.BlockNumber); err != nil {
|
2015-03-18 14:42:57 -05:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
return nil
|
2015-01-29 13:39:26 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 12:26:21 -06:00
|
|
|
type GetStorageAtArgs struct {
|
2015-03-26 06:11:28 -05:00
|
|
|
Address common.Address
|
|
|
|
Key common.Hash
|
2015-03-06 09:54:08 -06:00
|
|
|
BlockNumber int64
|
2015-01-29 13:39:26 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetStorageAtArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-18 14:42:57 -05:00
|
|
|
var obj []interface{}
|
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
2015-03-18 14:42:57 -05:00
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
if len(obj) < 2 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 2)
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
2015-03-05 21:37:45 -06:00
|
|
|
|
2015-03-18 14:42:57 -05:00
|
|
|
addstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("address", "not a string")
|
2015-03-18 14:42:57 -05:00
|
|
|
}
|
2015-03-26 06:11:28 -05:00
|
|
|
args.Address = common.HexToAddress(addstr)
|
2015-03-18 14:42:57 -05:00
|
|
|
|
|
|
|
keystr, ok := obj[1].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("key", "not a string")
|
2015-03-18 14:42:57 -05:00
|
|
|
}
|
2015-03-26 06:11:28 -05:00
|
|
|
args.Key = common.HexToHash(keystr)
|
2015-03-18 14:42:57 -05:00
|
|
|
|
|
|
|
if len(obj) > 2 {
|
2015-03-23 10:34:50 -05:00
|
|
|
if err := blockHeight(obj[2], &args.BlockNumber); err != nil {
|
2015-03-18 14:42:57 -05:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
2015-03-10 14:14:38 -05:00
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
return nil
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
type GetTxCountArgs struct {
|
2015-03-26 06:47:00 -05:00
|
|
|
Address common.Address
|
2015-03-06 09:54:08 -06:00
|
|
|
BlockNumber int64
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetTxCountArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-18 14:42:57 -05:00
|
|
|
var obj []interface{}
|
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
2015-03-18 14:42:57 -05:00
|
|
|
if len(obj) < 1 {
|
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
addstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("address", "not a string")
|
2015-03-18 14:42:57 -05:00
|
|
|
}
|
2015-03-26 06:47:00 -05:00
|
|
|
args.Address = common.HexToAddress(addstr)
|
2015-03-18 14:42:57 -05:00
|
|
|
|
|
|
|
if len(obj) > 1 {
|
2015-03-23 10:34:50 -05:00
|
|
|
if err := blockHeight(obj[1], &args.BlockNumber); err != nil {
|
2015-03-18 14:42:57 -05:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
return nil
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
type GetBalanceArgs struct {
|
2015-03-26 07:10:31 -05:00
|
|
|
Address common.Address
|
2015-03-06 09:54:08 -06:00
|
|
|
BlockNumber int64
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetBalanceArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-12 08:42:31 -05:00
|
|
|
var obj []interface{}
|
2015-03-18 14:42:57 -05:00
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-12 08:42:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-12 08:42:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
addstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("address", "not a string")
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
2015-03-26 07:10:31 -05:00
|
|
|
args.Address = common.HexToAddress(addstr)
|
2015-03-12 08:42:31 -05:00
|
|
|
|
|
|
|
if len(obj) > 1 {
|
2015-03-23 10:34:50 -05:00
|
|
|
if err := blockHeight(obj[1], &args.BlockNumber); err != nil {
|
2015-03-18 14:42:57 -05:00
|
|
|
return err
|
2015-03-12 08:42:31 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
return nil
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
type GetDataArgs struct {
|
|
|
|
Address string
|
2015-03-06 09:54:08 -06:00
|
|
|
BlockNumber int64
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetDataArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-18 14:42:57 -05:00
|
|
|
var obj []interface{}
|
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
2015-03-18 14:42:57 -05:00
|
|
|
if len(obj) < 1 {
|
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
|
|
|
}
|
|
|
|
|
|
|
|
addstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("address", "not a string")
|
2015-03-18 14:42:57 -05:00
|
|
|
}
|
|
|
|
args.Address = addstr
|
|
|
|
|
|
|
|
if len(obj) > 1 {
|
2015-03-23 10:34:50 -05:00
|
|
|
if err := blockHeight(obj[1], &args.BlockNumber); err != nil {
|
2015-03-18 14:42:57 -05:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
return nil
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *GetDataArgs) requirements() error {
|
|
|
|
if len(args.Address) == 0 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewValidationError("Address", "cannot be blank")
|
2015-01-20 13:57:51 -06:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2015-01-28 17:24:00 -06:00
|
|
|
|
2015-03-10 22:25:07 -05:00
|
|
|
type BlockNumIndexArgs struct {
|
|
|
|
BlockNumber int64
|
2015-03-11 10:25:15 -05:00
|
|
|
Index int64
|
2015-03-10 22:25:07 -05:00
|
|
|
}
|
|
|
|
|
2015-03-11 15:26:28 -05:00
|
|
|
func (args *BlockNumIndexArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
arg0, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("blockNumber", "not a string")
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
2015-03-16 05:27:38 -05:00
|
|
|
args.BlockNumber = common.Big(arg0).Int64()
|
2015-03-11 15:26:28 -05:00
|
|
|
|
|
|
|
if len(obj) > 1 {
|
|
|
|
arg1, ok := obj[1].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("index", "not a string")
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
2015-03-16 05:27:38 -05:00
|
|
|
args.Index = common.Big(arg1).Int64()
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-03-10 22:25:07 -05:00
|
|
|
type HashIndexArgs struct {
|
2015-03-12 09:59:07 -05:00
|
|
|
Hash string
|
|
|
|
Index int64
|
2015-03-10 22:25:07 -05:00
|
|
|
}
|
|
|
|
|
2015-03-11 15:26:28 -05:00
|
|
|
func (args *HashIndexArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
arg0, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("hash", "not a string")
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
2015-03-12 09:59:07 -05:00
|
|
|
args.Hash = arg0
|
2015-03-11 15:26:28 -05:00
|
|
|
|
|
|
|
if len(obj) > 1 {
|
|
|
|
arg1, ok := obj[1].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("index", "not a string")
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
2015-03-16 05:27:38 -05:00
|
|
|
args.Index = common.Big(arg1).Int64()
|
2015-03-11 15:26:28 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-01-28 17:24:00 -06:00
|
|
|
type Sha3Args struct {
|
|
|
|
Data string
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *Sha3Args) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
args.Data = obj[0].(string)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-03-19 22:55:17 -05:00
|
|
|
type BlockFilterArgs struct {
|
2015-01-29 09:52:00 -06:00
|
|
|
Earliest int64
|
|
|
|
Latest int64
|
2015-02-17 07:19:05 -06:00
|
|
|
Address interface{}
|
2015-03-09 12:19:35 -05:00
|
|
|
Topics []interface{}
|
2015-01-29 09:52:00 -06:00
|
|
|
Skip int
|
|
|
|
Max int
|
|
|
|
}
|
|
|
|
|
2015-03-19 22:55:17 -05:00
|
|
|
func (args *BlockFilterArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-05 21:37:45 -06:00
|
|
|
var obj []struct {
|
2015-03-16 09:38:57 -05:00
|
|
|
FromBlock interface{} `json:"fromBlock"`
|
|
|
|
ToBlock interface{} `json:"toBlock"`
|
2015-03-09 11:55:01 -05:00
|
|
|
Limit string `json:"limit"`
|
|
|
|
Offset string `json:"offset"`
|
|
|
|
Address string `json:"address"`
|
|
|
|
Topics []interface{} `json:"topics"`
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if err = json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
2015-03-12 19:07:03 -05:00
|
|
|
|
2015-03-16 09:38:57 -05:00
|
|
|
fromstr, ok := obj[0].FromBlock.(string)
|
2015-03-16 14:30:31 -05:00
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("fromBlock", "is not a string")
|
2015-03-16 14:30:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
switch fromstr {
|
|
|
|
case "latest":
|
2015-03-23 11:33:01 -05:00
|
|
|
args.Earliest = -1
|
2015-03-16 14:30:31 -05:00
|
|
|
default:
|
|
|
|
args.Earliest = int64(common.Big(obj[0].FromBlock.(string)).Int64())
|
2015-03-16 09:38:57 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
tostr, ok := obj[0].ToBlock.(string)
|
2015-03-16 14:30:31 -05:00
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("toBlock", "not a string")
|
2015-03-16 14:30:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
switch tostr {
|
|
|
|
case "latest":
|
|
|
|
args.Latest = -1
|
2015-03-23 11:33:01 -05:00
|
|
|
case "pending":
|
|
|
|
args.Latest = -2
|
2015-03-16 14:30:31 -05:00
|
|
|
default:
|
|
|
|
args.Latest = int64(common.Big(obj[0].ToBlock.(string)).Int64())
|
2015-03-16 09:38:57 -05:00
|
|
|
}
|
|
|
|
|
2015-03-16 05:27:38 -05:00
|
|
|
args.Max = int(common.Big(obj[0].Limit).Int64())
|
|
|
|
args.Skip = int(common.Big(obj[0].Offset).Int64())
|
2015-03-05 21:37:45 -06:00
|
|
|
args.Address = obj[0].Address
|
2015-03-09 12:19:35 -05:00
|
|
|
args.Topics = obj[0].Topics
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-01-29 13:39:26 -06:00
|
|
|
type DbArgs struct {
|
|
|
|
Database string
|
|
|
|
Key string
|
2015-03-23 10:04:21 -05:00
|
|
|
Value []byte
|
2015-01-29 13:39:26 -06:00
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
func (args *DbArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
2015-03-23 10:04:21 -05:00
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 2 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 2)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
2015-03-23 10:04:21 -05:00
|
|
|
|
|
|
|
var objstr string
|
|
|
|
var ok bool
|
|
|
|
|
|
|
|
if objstr, ok = obj[0].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("database", "not a string")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
args.Database = objstr
|
|
|
|
|
|
|
|
if objstr, ok = obj[1].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("key", "not a string")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
args.Key = objstr
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
if len(obj) > 2 {
|
2015-03-23 10:04:21 -05:00
|
|
|
objstr, ok = obj[2].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("value", "not a string")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
args.Value = []byte(objstr)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-01-29 13:39:26 -06:00
|
|
|
func (a *DbArgs) requirements() error {
|
|
|
|
if len(a.Database) == 0 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewValidationError("Database", "cannot be blank")
|
2015-01-29 13:39:26 -06:00
|
|
|
}
|
|
|
|
if len(a.Key) == 0 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewValidationError("Key", "cannot be blank")
|
2015-01-29 13:39:26 -06:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2015-01-30 06:25:12 -06:00
|
|
|
|
2015-03-23 10:04:21 -05:00
|
|
|
type DbHexArgs struct {
|
|
|
|
Database string
|
|
|
|
Key string
|
|
|
|
Value []byte
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *DbHexArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
if err := json.Unmarshal(b, &obj); err != nil {
|
|
|
|
return NewDecodeParamError(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 2 {
|
|
|
|
return NewInsufficientParamsError(len(obj), 2)
|
|
|
|
}
|
|
|
|
|
|
|
|
var objstr string
|
|
|
|
var ok bool
|
|
|
|
|
|
|
|
if objstr, ok = obj[0].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("database", "not a string")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
args.Database = objstr
|
|
|
|
|
|
|
|
if objstr, ok = obj[1].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("key", "not a string")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
args.Key = objstr
|
|
|
|
|
|
|
|
if len(obj) > 2 {
|
|
|
|
objstr, ok = obj[2].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("value", "not a string")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
args.Value = common.FromHex(objstr)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *DbHexArgs) requirements() error {
|
|
|
|
if len(a.Database) == 0 {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("Database", "cannot be blank")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
if len(a.Key) == 0 {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("Key", "cannot be blank")
|
2015-03-23 10:04:21 -05:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-01-30 06:25:12 -06:00
|
|
|
type WhisperMessageArgs struct {
|
|
|
|
Payload string
|
|
|
|
To string
|
|
|
|
From string
|
2015-03-11 10:56:44 -05:00
|
|
|
Topics []string
|
2015-01-30 06:25:12 -06:00
|
|
|
Priority uint32
|
|
|
|
Ttl uint32
|
|
|
|
}
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
func (args *WhisperMessageArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []struct {
|
|
|
|
Payload string
|
|
|
|
To string
|
|
|
|
From string
|
2015-03-11 10:56:44 -05:00
|
|
|
Topics []string
|
2015-03-05 21:37:45 -06:00
|
|
|
Priority string
|
|
|
|
Ttl string
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
args.Payload = obj[0].Payload
|
|
|
|
args.To = obj[0].To
|
|
|
|
args.From = obj[0].From
|
2015-03-11 10:56:44 -05:00
|
|
|
args.Topics = obj[0].Topics
|
2015-03-16 05:27:38 -05:00
|
|
|
args.Priority = uint32(common.Big(obj[0].Priority).Int64())
|
|
|
|
args.Ttl = uint32(common.Big(obj[0].Ttl).Int64())
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type CompileArgs struct {
|
|
|
|
Source string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *CompileArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) > 0 {
|
|
|
|
args.Source = obj[0].(string)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type FilterStringArgs struct {
|
|
|
|
Word string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *FilterStringArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-13 09:03:19 -05:00
|
|
|
var obj []interface{}
|
2015-03-05 21:37:45 -06:00
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
2015-03-13 09:03:19 -05:00
|
|
|
var argstr string
|
|
|
|
argstr, ok := obj[0].(string)
|
|
|
|
if !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("filter", "not a string")
|
2015-03-13 09:03:19 -05:00
|
|
|
}
|
|
|
|
args.Word = argstr
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-03-19 21:58:07 -05:00
|
|
|
func (args *FilterStringArgs) requirements() error {
|
|
|
|
switch args.Word {
|
|
|
|
case "latest", "pending":
|
|
|
|
break
|
|
|
|
default:
|
|
|
|
return NewValidationError("Word", "Must be `latest` or `pending`")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2015-03-05 21:37:45 -06:00
|
|
|
type FilterIdArgs struct {
|
|
|
|
Id int
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *FilterIdArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []string
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
2015-03-16 05:27:38 -05:00
|
|
|
args.Id = int(common.Big(obj[0]).Int64())
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type WhisperIdentityArgs struct {
|
|
|
|
Identity string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *WhisperIdentityArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []string
|
|
|
|
r := bytes.NewReader(b)
|
|
|
|
if err := json.NewDecoder(r).Decode(&obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
args.Identity = obj[0]
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type WhisperFilterArgs struct {
|
2015-03-06 09:54:08 -06:00
|
|
|
To string `json:"to"`
|
2015-03-05 21:37:45 -06:00
|
|
|
From string
|
|
|
|
Topics []string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *WhisperFilterArgs) UnmarshalJSON(b []byte) (err error) {
|
2015-03-06 09:54:08 -06:00
|
|
|
var obj []struct {
|
|
|
|
To string
|
|
|
|
From string
|
|
|
|
Topics []string
|
|
|
|
}
|
2015-03-05 21:37:45 -06:00
|
|
|
|
|
|
|
if err = json.Unmarshal(b, &obj); err != nil {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewDecodeParamError(err.Error())
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 1 {
|
2015-03-12 19:07:03 -05:00
|
|
|
return NewInsufficientParamsError(len(obj), 1)
|
2015-03-05 21:37:45 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
args.To = obj[0].To
|
|
|
|
args.From = obj[0].From
|
|
|
|
args.Topics = obj[0].Topics
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2015-03-23 02:28:54 -05:00
|
|
|
|
|
|
|
type SubmitWorkArgs struct {
|
|
|
|
Nonce uint64
|
|
|
|
Header common.Hash
|
|
|
|
Digest common.Hash
|
|
|
|
}
|
|
|
|
|
|
|
|
func (args *SubmitWorkArgs) UnmarshalJSON(b []byte) (err error) {
|
|
|
|
var obj []interface{}
|
|
|
|
if err = json.Unmarshal(b, &obj); err != nil {
|
|
|
|
return NewDecodeParamError(err.Error())
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(obj) < 3 {
|
|
|
|
return NewInsufficientParamsError(len(obj), 3)
|
|
|
|
}
|
|
|
|
|
|
|
|
var objstr string
|
|
|
|
var ok bool
|
|
|
|
if objstr, ok = obj[0].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("nonce", "not a string")
|
2015-03-23 02:28:54 -05:00
|
|
|
}
|
|
|
|
|
2015-03-23 11:33:01 -05:00
|
|
|
args.Nonce = common.String2Big(objstr).Uint64()
|
2015-03-23 02:28:54 -05:00
|
|
|
if objstr, ok = obj[1].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("header", "not a string")
|
2015-03-23 02:28:54 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
args.Header = common.HexToHash(objstr)
|
|
|
|
|
|
|
|
if objstr, ok = obj[2].(string); !ok {
|
2015-03-26 07:45:06 -05:00
|
|
|
return NewInvalidTypeError("digest", "not a string")
|
2015-03-23 02:28:54 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
args.Digest = common.HexToHash(objstr)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|