aboutsummaryrefslogtreecommitdiffstats
path: root/rpc/api
diff options
context:
space:
mode:
authorJeffrey Wilcke <jeffrey@ethereum.org>2015-08-07 18:08:48 +0800
committerJeffrey Wilcke <jeffrey@ethereum.org>2015-08-07 18:08:48 +0800
commite89536ca0b0e61111affd6cbacf21105bd637394 (patch)
treefb721ea654f5a5245e595e8f63bb7a034d3ddb76 /rpc/api
parentac10c9352e053a06a69fad634e9ec6624ee5808d (diff)
parentc32073b11f12c3735c117b3b3c814505974d5a92 (diff)
downloadgo-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.go10
-rw-r--r--rpc/api/eth_args.go31
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
}