aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2015-05-21 17:57:00 +0800
committerobscuren <geffobscura@gmail.com>2015-05-21 17:57:00 +0800
commit907848997bbf79382a98b0c82e4aa61ca2eecd16 (patch)
tree0a33c44b7bd589c278f9eda3dabd3e719ad43be2
parent207bd5575161fa2bc61a7ccf659c11878575dd32 (diff)
downloaddexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar
dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.gz
dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.bz2
dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.lz
dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.xz
dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.zst
dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.zip
miner: one-shot update loop
-rw-r--r--miner/miner.go6
1 files changed, 6 insertions, 0 deletions
diff --git a/miner/miner.go b/miner/miner.go
index 3f87e8151..c9427f302 100644
--- a/miner/miner.go
+++ b/miner/miner.go
@@ -39,6 +39,10 @@ func New(eth core.Backend, mux *event.TypeMux, pow pow.PoW) *Miner {
return miner
}
+// update keeps track of the downloader events. Please be aware that this is a one shot type of update loop.
+// It's entered once and as soon as `Done` or `Failed` has been broadcasted the events are unregistered and
+// the loop is exited. This to prevent a major security vuln where external parties can DOS you with blocks
+// and halt your mining operation for as long as the DOS continues.
func (self *Miner) update() {
events := self.mux.Subscribe(downloader.StartEvent{}, downloader.DoneEvent{}, downloader.FailedEvent{})
for ev := range events.Chan() {
@@ -59,6 +63,8 @@ func (self *Miner) update() {
self.Start(self.coinbase, self.threads)
}
}
+ // unsubscribe. we're only interested in this event once
+ events.Unsubscribe()
}
}