Cleanup get/submitWork
getWork needs to return additional values
This commit is contained in:
parent
8affdf96e2
commit
372e1cad5b
18
rpc/api.go
18
rpc/api.go
|
@ -348,13 +348,14 @@ func (p *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) error
|
||||||
opts := toFilterOptions(args)
|
opts := toFilterOptions(args)
|
||||||
*reply = NewLogsRes(p.xeth().AllLogs(opts))
|
*reply = NewLogsRes(p.xeth().AllLogs(opts))
|
||||||
case "eth_getWork":
|
case "eth_getWork":
|
||||||
*reply = p.getWork()
|
p.xeth().SetMining(true)
|
||||||
|
*reply = p.agent.GetWork().Hex()
|
||||||
case "eth_submitWork":
|
case "eth_submitWork":
|
||||||
// TODO what is the reply here?
|
args := new(SubmitWorkArgs)
|
||||||
// TODO what are the arguments?
|
if err := json.Unmarshal(req.Params, &args); err != nil {
|
||||||
p.agent.SetResult(0, common.Hash{}, common.Hash{})
|
return err
|
||||||
|
}
|
||||||
return NewNotImplementedError(req.Method)
|
*reply = p.agent.SetResult(args.Nonce, args.Digest, args.Header)
|
||||||
case "db_putString":
|
case "db_putString":
|
||||||
args := new(DbArgs)
|
args := new(DbArgs)
|
||||||
if err := json.Unmarshal(req.Params, &args); err != nil {
|
if err := json.Unmarshal(req.Params, &args); err != nil {
|
||||||
|
@ -466,11 +467,6 @@ func (p *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) error
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *EthereumApi) getWork() string {
|
|
||||||
p.xeth().SetMining(true)
|
|
||||||
return p.agent.GetWork().Hex()
|
|
||||||
}
|
|
||||||
|
|
||||||
func toFilterOptions(options *BlockFilterArgs) *core.FilterOptions {
|
func toFilterOptions(options *BlockFilterArgs) *core.FilterOptions {
|
||||||
var opts core.FilterOptions
|
var opts core.FilterOptions
|
||||||
|
|
||||||
|
|
39
rpc/args.go
39
rpc/args.go
|
@ -686,3 +686,42 @@ func (args *WhisperFilterArgs) UnmarshalJSON(b []byte) (err error) {
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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 {
|
||||||
|
return NewDecodeParamError("Nonce is not a string")
|
||||||
|
}
|
||||||
|
|
||||||
|
args.Nonce = common.BytesToNumber(common.Hex2Bytes(objstr))
|
||||||
|
|
||||||
|
if objstr, ok = obj[1].(string); !ok {
|
||||||
|
return NewDecodeParamError("Header is not a string")
|
||||||
|
}
|
||||||
|
|
||||||
|
args.Header = common.HexToHash(objstr)
|
||||||
|
|
||||||
|
if objstr, ok = obj[2].(string); !ok {
|
||||||
|
return NewDecodeParamError("Digest is not a string")
|
||||||
|
}
|
||||||
|
|
||||||
|
args.Digest = common.HexToHash(objstr)
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -55,6 +55,8 @@ out:
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Agent) GetWork() common.Hash {
|
func (a *Agent) GetWork() common.Hash {
|
||||||
|
// TODO return HashNoNonce, DAGSeedHash, Difficulty
|
||||||
|
|
||||||
// XXX Wait here untill work != nil ?.
|
// XXX Wait here untill work != nil ?.
|
||||||
if a.work != nil {
|
if a.work != nil {
|
||||||
return a.work.HashNoNonce()
|
return a.work.HashNoNonce()
|
||||||
|
@ -62,9 +64,14 @@ func (a *Agent) GetWork() common.Hash {
|
||||||
return common.Hash{}
|
return common.Hash{}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *Agent) SetResult(nonce uint64, mixDigest, seedHash common.Hash) {
|
func (a *Agent) SetResult(nonce uint64, mixDigest, seedHash common.Hash) bool {
|
||||||
|
// Return true or false, but does not indicate if the PoW was correct
|
||||||
|
|
||||||
// Make sure the external miner was working on the right hash
|
// Make sure the external miner was working on the right hash
|
||||||
if a.currentWork != nil && a.work != nil && a.currentWork.Hash() == a.work.Hash() {
|
if a.currentWork != nil && a.work != nil && a.currentWork.Hash() == a.work.Hash() {
|
||||||
a.returnCh <- miner.Work{a.currentWork.Number().Uint64(), nonce, mixDigest.Bytes(), seedHash.Bytes()}
|
a.returnCh <- miner.Work{a.currentWork.Number().Uint64(), nonce, mixDigest.Bytes(), seedHash.Bytes()}
|
||||||
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue