diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-05-22 19:08:51 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-05-22 19:08:51 +0800 |
commit | f7415c0bbc9d95141a0b2d95b936f4eed90c0616 (patch) | |
tree | 248d21513fb02407b153c7790d15f8a99218fe97 | |
parent | 01ddaf567068b4c70a76e6b0152fc4e1b167dbe6 (diff) | |
parent | 6539ccae7cc34ed164fd7e6d6750804fa3378261 (diff) | |
download | dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.tar dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.tar.gz dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.tar.bz2 dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.tar.lz dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.tar.xz dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.tar.zst dexon-f7415c0bbc9d95141a0b2d95b936f4eed90c0616.zip |
Merge pull request #1076 from obscuren/rpc_sign
core: added RPC sign back in
-rw-r--r-- | rpc/api.go | 20 | ||||
-rw-r--r-- | rpc/args.go | 64 |
2 files changed, 42 insertions, 42 deletions
diff --git a/rpc/api.go b/rpc/api.go index b6f6ac3f9..a9a0ae609 100644 --- a/rpc/api.go +++ b/rpc/api.go @@ -158,16 +158,16 @@ func (api *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) err v := api.xethAtStateNum(args.BlockNumber).CodeAtBytes(args.Address) *reply = newHexData(v) - // case "eth_sign": - // args := new(NewSigArgs) - // if err := json.Unmarshal(req.Params, &args); err != nil { - // return err - // } - // v, err := api.xeth().Sign(args.From, args.Data, false) - // if err != nil { - // return err - // } - // *reply = v + case "eth_sign": + args := new(NewSigArgs) + if err := json.Unmarshal(req.Params, &args); err != nil { + return err + } + v, err := api.xeth().Sign(args.From, args.Data, false) + if err != nil { + return err + } + *reply = v case "eth_sendTransaction", "eth_transact": args := new(NewTxArgs) diff --git a/rpc/args.go b/rpc/args.go index 27824f12c..686872a59 100644 --- a/rpc/args.go +++ b/rpc/args.go @@ -166,45 +166,45 @@ type NewTxArgs struct { BlockNumber int64 } -// type NewSigArgs struct { -// From string -// Data string -// } +type NewSigArgs struct { + From string + Data string +} -// func (args *NewSigArgs) UnmarshalJSON(b []byte) (err error) { -// var obj []json.RawMessage -// var ext struct { -// From string -// Data string -// } +func (args *NewSigArgs) UnmarshalJSON(b []byte) (err error) { + var obj []json.RawMessage + var ext struct { + From string + Data string + } -// // Decode byte slice to array of RawMessages -// if err := json.Unmarshal(b, &obj); err != nil { -// return NewDecodeParamError(err.Error()) -// } + // Decode byte slice to array of RawMessages + if err := json.Unmarshal(b, &obj); err != nil { + return NewDecodeParamError(err.Error()) + } -// // Check for sufficient params -// if len(obj) < 1 { -// return NewInsufficientParamsError(len(obj), 1) -// } + // 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()) -// } + // Decode 0th RawMessage to temporary struct + if err := json.Unmarshal(obj[0], &ext); err != nil { + return NewDecodeParamError(err.Error()) + } -// if len(ext.From) == 0 { -// return NewValidationError("from", "is required") -// } + if len(ext.From) == 0 { + return NewValidationError("from", "is required") + } -// if len(ext.Data) == 0 { -// return NewValidationError("data", "is required") -// } + if len(ext.Data) == 0 { + return NewValidationError("data", "is required") + } -// args.From = ext.From -// args.Data = ext.Data -// return nil -// } + args.From = ext.From + args.Data = ext.Data + return nil +} func (args *NewTxArgs) UnmarshalJSON(b []byte) (err error) { var obj []json.RawMessage |