diff options
author | obscuren <geffobscura@gmail.com> | 2015-05-21 17:57:00 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2015-05-21 17:57:00 +0800 |
commit | 907848997bbf79382a98b0c82e4aa61ca2eecd16 (patch) | |
tree | 0a33c44b7bd589c278f9eda3dabd3e719ad43be2 /miner/miner.go | |
parent | 207bd5575161fa2bc61a7ccf659c11878575dd32 (diff) | |
download | dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.gz dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.tar.zst dexon-907848997bbf79382a98b0c82e4aa61ca2eecd16.zip |
miner: one-shot update loop
Diffstat (limited to 'miner/miner.go')
-rw-r--r-- | miner/miner.go | 6 |
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() } } |