diff options
author | Gustav Simonsson <gustav.simonsson@gmail.com> | 2015-04-22 21:29:19 +0800 |
---|---|---|
committer | Gustav Simonsson <gustav.simonsson@gmail.com> | 2015-04-23 05:16:19 +0800 |
commit | 4e0a2c8e8cf418528742500dff8e6916e4fd1bc5 (patch) | |
tree | 9f194fe587d93100dbb28bffa1a4100c2ada0b1e /core | |
parent | ec6acacc539c3392c8dd68c89a2b714ec609ff19 (diff) | |
download | dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.tar dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.tar.gz dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.tar.bz2 dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.tar.lz dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.tar.xz dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.tar.zst dexon-4e0a2c8e8cf418528742500dff8e6916e4fd1bc5.zip |
Validate block header UncleHash against calculated hash
Diffstat (limited to 'core')
-rw-r--r-- | core/block_processor.go | 11 | ||||
-rw-r--r-- | core/types/block.go | 4 |
2 files changed, 13 insertions, 2 deletions
diff --git a/core/block_processor.go b/core/block_processor.go index 28636a725..f33f0d433 100644 --- a/core/block_processor.go +++ b/core/block_processor.go @@ -219,14 +219,21 @@ func (sm *BlockProcessor) processWithParent(block, parent *types.Block) (logs st // can be used by light clients to make sure they've received the correct Txs txSha := types.DeriveSha(block.Transactions()) if txSha != header.TxHash { - err = fmt.Errorf("validating transaction root. received=%x got=%x", header.TxHash, txSha) + err = fmt.Errorf("invalid transaction root hash. received=%x calculated=%x", header.TxHash, txSha) return } // Tre receipt Trie's root (R = (Tr [[H1, R1], ... [Hn, R1]])) receiptSha := types.DeriveSha(receipts) if receiptSha != header.ReceiptHash { - err = fmt.Errorf("validating receipt root. received=%x got=%x", header.ReceiptHash, receiptSha) + err = fmt.Errorf("invalid receipt root hash. received=%x calculated=%x", header.ReceiptHash, receiptSha) + return + } + + // Verify UncleHash before running other uncle validations + unclesSha := block.CalculateUnclesHash() + if unclesSha != header.UncleHash { + err = fmt.Errorf("invalid uncles root hash. received=%x calculated=%x", header.UncleHash, unclesSha) return } diff --git a/core/types/block.go b/core/types/block.go index f9206ec76..fa83fc8e8 100644 --- a/core/types/block.go +++ b/core/types/block.go @@ -209,6 +209,10 @@ func (self *Block) Uncles() []*Header { return self.uncles } +func (self *Block) CalculateUnclesHash() common.Hash { + return rlpHash(self.uncles) +} + func (self *Block) SetUncles(uncleHeaders []*Header) { self.uncles = uncleHeaders self.header.UncleHash = rlpHash(uncleHeaders) |