diff options
author | Péter Szilágyi <peterke@gmail.com> | 2016-12-20 09:14:36 +0800 |
---|---|---|
committer | Felix Lange <fjl@users.noreply.github.com> | 2016-12-20 09:14:36 +0800 |
commit | 0ee796632a9c0f5e098cdced6c4f9033c00cd149 (patch) | |
tree | ec545d723b5c3b3275403357561779e3c43ced2e | |
parent | 1fe67c125d85881cf8c23cd0f08c4a06946793bd (diff) | |
download | dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.tar dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.tar.gz dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.tar.bz2 dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.tar.lz dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.tar.xz dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.tar.zst dexon-0ee796632a9c0f5e098cdced6c4f9033c00cd149.zip |
eth, miner: verify PoW in the remote agent to notify submitter (#3438)
-rw-r--r-- | eth/api.go | 2 | ||||
-rw-r--r-- | miner/remote_agent.go | 33 |
2 files changed, 22 insertions, 13 deletions
diff --git a/eth/api.go b/eth/api.go index 0a1d097e3..2cc9c843d 100644 --- a/eth/api.go +++ b/eth/api.go @@ -82,7 +82,7 @@ type PublicMinerAPI struct { // NewPublicMinerAPI create a new PublicMinerAPI instance. func NewPublicMinerAPI(e *Ethereum) *PublicMinerAPI { - agent := miner.NewRemoteAgent() + agent := miner.NewRemoteAgent(e.Pow()) e.Miner().Register(agent) return &PublicMinerAPI{e, agent} diff --git a/miner/remote_agent.go b/miner/remote_agent.go index 1a27a1312..f99f38b36 100644 --- a/miner/remote_agent.go +++ b/miner/remote_agent.go @@ -27,6 +27,7 @@ import ( "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/logger" "github.com/ethereum/go-ethereum/logger/glog" + "github.com/ethereum/go-ethereum/pow" ) type hashrate struct { @@ -41,6 +42,7 @@ type RemoteAgent struct { workCh chan *Work returnCh chan<- *Result + pow pow.PoW currentWork *Work work map[common.Hash]*Work @@ -50,8 +52,9 @@ type RemoteAgent struct { running int32 // running indicates whether the agent is active. Call atomically } -func NewRemoteAgent() *RemoteAgent { +func NewRemoteAgent(pow pow.PoW) *RemoteAgent { return &RemoteAgent{ + pow: pow, work: make(map[common.Hash]*Work), hashrate: make(map[common.Hash]hashrate), } @@ -126,24 +129,30 @@ func (a *RemoteAgent) GetWork() ([3]string, error) { return res, errors.New("No work available yet, don't panic.") } -// Returns true or false, but does not indicate if the PoW was correct +// SubmitWork tries to inject a PoW solution tinto the remote agent, returning +// whether the solution was acceted or not (not can be both a bad PoW as well as +// any other error, like no work pending). func (a *RemoteAgent) SubmitWork(nonce uint64, mixDigest, hash common.Hash) bool { a.mu.Lock() defer a.mu.Unlock() // Make sure the work submitted is present - if a.work[hash] != nil { - block := a.work[hash].Block.WithMiningResult(nonce, mixDigest) - a.returnCh <- &Result{a.work[hash], block} - - delete(a.work, hash) - - return true - } else { - glog.V(logger.Info).Infof("Work was submitted for %x but no pending work found\n", hash) + work := a.work[hash] + if work == nil { + glog.V(logger.Info).Infof("Work was submitted for %x but no pending work found", hash) + return false + } + // Make sure the PoW solutions is indeed valid + block := work.Block.WithMiningResult(nonce, mixDigest) + if !a.pow.Verify(block) { + glog.V(logger.Warn).Infof("Invalid PoW submitted for %x", hash) + return false } + // Solutions seems to be valid, return to the miner and notify acceptance + a.returnCh <- &Result{work, block} + delete(a.work, hash) - return false + return true } // loop monitors mining events on the work and quit channels, updating the internal |