Skip to content

Commit

Permalink
eth, miner: verify PoW in the remote agent to notify submitter (ether…
Browse files Browse the repository at this point in the history
  • Loading branch information
karalabe authored and fjl committed Dec 20, 2016
1 parent 1fe67c1 commit 0ee7966
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 13 deletions.
2 changes: 1 addition & 1 deletion eth/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -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}
Expand Down
33 changes: 21 additions & 12 deletions miner/remote_agent.go
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand All @@ -41,6 +42,7 @@ type RemoteAgent struct {
workCh chan *Work
returnCh chan<- *Result

pow pow.PoW
currentWork *Work
work map[common.Hash]*Work

Expand All @@ -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),
}
Expand Down Expand Up @@ -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
Expand Down

0 comments on commit 0ee7966

Please sign in to comment.