diff options
author | Péter Szilágyi <peterke@gmail.com> | 2018-01-31 18:46:38 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-31 18:46:38 +0800 |
commit | fdb34b7a7c87142cde48a2ec092f77a56d66f773 (patch) | |
tree | 6608a33f95d5067d23f01c6951eca3f983c3566d /les/handler.go | |
parent | 07d4a022573444eac0db2f5da500cc5ee1e940bb (diff) | |
parent | 566d5c0777c2c5ee1a8fe3c0aee1e5c8c69053e2 (diff) | |
download | go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.tar go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.tar.gz go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.tar.bz2 go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.tar.lz go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.tar.xz go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.tar.zst go-tangerine-fdb34b7a7c87142cde48a2ec092f77a56d66f773.zip |
Merge pull request #15996 from karalabe/drop-redundant-methods
core, eth, les, light: get rid of redundant methods
Diffstat (limited to 'les/handler.go')
-rw-r--r-- | les/handler.go | 22 |
1 files changed, 14 insertions, 8 deletions
diff --git a/les/handler.go b/les/handler.go index 57657e84f..ad2e8058f 100644 --- a/les/handler.go +++ b/les/handler.go @@ -77,13 +77,11 @@ type BlockChain interface { GetHeader(hash common.Hash, number uint64) *types.Header GetHeaderByHash(hash common.Hash) *types.Header CurrentHeader() *types.Header - GetTdByHash(hash common.Hash) *big.Int + GetTd(hash common.Hash, number uint64) *big.Int InsertHeaderChain(chain []*types.Header, checkFreq int) (int, error) Rollback(chain []common.Hash) - Status() (td *big.Int, currentBlock common.Hash, genesisBlock common.Hash) GetHeaderByNumber(number uint64) *types.Header GetBlockHashesFromHash(hash common.Hash, max uint64) []common.Hash - LastBlockHash() common.Hash Genesis() *types.Block SubscribeChainHeadEvent(ch chan<- core.ChainHeadEvent) event.Subscription } @@ -262,9 +260,14 @@ func (pm *ProtocolManager) handle(p *peer) error { p.Log().Debug("Light Ethereum peer connected", "name", p.Name()) // Execute the LES handshake - td, head, genesis := pm.blockchain.Status() - headNum := core.GetBlockNumber(pm.chainDb, head) - if err := p.Handshake(td, head, headNum, genesis, pm.server); err != nil { + var ( + genesis = pm.blockchain.Genesis() + head = pm.blockchain.CurrentHeader() + hash = head.Hash() + number = head.Number.Uint64() + td = pm.blockchain.GetTd(hash, number) + ) + if err := p.Handshake(td, hash, number, genesis.Hash(), pm.server); err != nil { p.Log().Debug("Light Ethereum handshake failed", "err", err) return err } @@ -1135,12 +1138,15 @@ type NodeInfo struct { // NodeInfo retrieves some protocol metadata about the running host node. func (self *ProtocolManager) NodeInfo() *NodeInfo { + head := self.blockchain.CurrentHeader() + hash := head.Hash() + return &NodeInfo{ Network: self.networkId, - Difficulty: self.blockchain.GetTdByHash(self.blockchain.LastBlockHash()), + Difficulty: self.blockchain.GetTd(hash, head.Number.Uint64()), Genesis: self.blockchain.Genesis().Hash(), Config: self.blockchain.Config(), - Head: self.blockchain.LastBlockHash(), + Head: hash, } } |