diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-08-07 18:08:48 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-08-07 18:08:48 +0800 |
commit | e89536ca0b0e61111affd6cbacf21105bd637394 (patch) | |
tree | fb721ea654f5a5245e595e8f63bb7a034d3ddb76 /rpc/api | |
parent | ac10c9352e053a06a69fad634e9ec6624ee5808d (diff) | |
parent | c32073b11f12c3735c117b3b3c814505974d5a92 (diff) | |
download | go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.gz go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.bz2 go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.lz go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.xz go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.zst go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.zip |
Merge pull request #1596 from obscuren/submit-hashrate
miner, rpc: added submit hashrate for remote agents
Diffstat (limited to 'rpc/api')
-rw-r--r-- | rpc/api/eth.go | 10 | ||||
-rw-r--r-- | rpc/api/eth_args.go | 31 |
2 files changed, 41 insertions, 0 deletions
diff --git a/rpc/api/eth.go b/rpc/api/eth.go index 4041811f0..820ea761b 100644 --- a/rpc/api/eth.go +++ b/rpc/api/eth.go @@ -92,6 +92,7 @@ var ( "eth_hashrate": (*ethApi).Hashrate, "eth_getWork": (*ethApi).GetWork, "eth_submitWork": (*ethApi).SubmitWork, + "eth_submitHashrate": (*ethApi).SubmitHashrate, "eth_resend": (*ethApi).Resend, "eth_pendingTransactions": (*ethApi).PendingTransactions, "eth_getTransactionReceipt": (*ethApi).GetTransactionReceipt, @@ -573,6 +574,15 @@ func (self *ethApi) SubmitWork(req *shared.Request) (interface{}, error) { return self.xeth.RemoteMining().SubmitWork(args.Nonce, common.HexToHash(args.Digest), common.HexToHash(args.Header)), nil } +func (self *ethApi) SubmitHashrate(req *shared.Request) (interface{}, error) { + args := new(SubmitHashRateArgs) + if err := self.codec.Decode(req.Params, &args); err != nil { + return nil, shared.NewDecodeParamError(err.Error()) + } + self.xeth.RemoteMining().SubmitHashrate(common.HexToHash(args.Id), args.Rate) + return nil, nil +} + func (self *ethApi) Resend(req *shared.Request) (interface{}, error) { args := new(ResendArgs) if err := self.codec.Decode(req.Params, &args); err != nil { diff --git a/rpc/api/eth_args.go b/rpc/api/eth_args.go index 1218bd625..5a1841cbe 100644 --- a/rpc/api/eth_args.go +++ b/rpc/api/eth_args.go @@ -169,6 +169,37 @@ func (args *GetTxCountArgs) UnmarshalJSON(b []byte) (err error) { return nil } +type SubmitHashRateArgs struct { + Id string + Rate uint64 +} + +func (args *SubmitHashRateArgs) UnmarshalJSON(b []byte) (err error) { + var obj []interface{} + if err := json.Unmarshal(b, &obj); err != nil { + return shared.NewDecodeParamError(err.Error()) + } + + if len(obj) < 2 { + return shared.NewInsufficientParamsError(len(obj), 2) + } + + arg0, ok := obj[0].(string) + if !ok { + return shared.NewInvalidTypeError("hash", "not a string") + } + args.Id = arg0 + + arg1, ok := obj[1].(string) + if !ok { + return shared.NewInvalidTypeError("rate", "not a string") + } + + args.Rate = common.String2Big(arg1).Uint64() + + return nil +} + type HashArgs struct { Hash string } |