[lbry] mining: calculate claimtrie root hash for generate RPC

This commit is contained in:
Brannon King 2021-08-19 14:41:48 -04:00 committed by Roy Lee
parent d19bcd60db
commit fe1ce376d8
2 changed files with 26 additions and 1 deletions

View file

@ -15,6 +15,26 @@ import (
"github.com/btcsuite/btcd/claimtrie/node" "github.com/btcsuite/btcd/claimtrie/node"
) )
func (b *BlockChain) SetClaimtrieHeader(block *btcutil.Block, view *UtxoViewpoint) error {
b.chainLock.Lock()
defer b.chainLock.Unlock()
err := b.ParseClaimScripts(block, nil, view, false, false)
if err != nil {
return errors.Wrapf(err, "in parse claim scripts")
}
err = b.claimTrie.AppendBlock()
if err != nil {
return errors.Wrapf(err, "in append block")
}
block.MsgBlock().Header.ClaimTrie = *b.claimTrie.MerkleHash()
err = b.claimTrie.ResetHeight(b.claimTrie.Height() - 1)
return errors.Wrapf(err, "in reset height")
}
func (b *BlockChain) ParseClaimScripts(block *btcutil.Block, bn *blockNode, view *UtxoViewpoint, func (b *BlockChain) ParseClaimScripts(block *btcutil.Block, bn *blockNode, view *UtxoViewpoint,
failOnHashMiss bool, shouldFlush bool) error { failOnHashMiss bool, shouldFlush bool) error {
ht := block.Height() ht := block.Height()
@ -39,7 +59,7 @@ func (b *BlockChain) ParseClaimScripts(block *btcutil.Block, bn *blockNode, view
} }
hash := b.claimTrie.MerkleHash() hash := b.claimTrie.MerkleHash()
if bn.claimTrie != *hash { if bn != nil && bn.claimTrie != *hash {
if failOnHashMiss { if failOnHashMiss {
return errors.Errorf("height: %d, ct.MerkleHash: %s != node.ClaimTrie: %s", ht, *hash, bn.claimTrie) return errors.Errorf("height: %d, ct.MerkleHash: %s != node.ClaimTrie: %s", ht, *hash, bn.claimTrie)
} }

View file

@ -843,6 +843,11 @@ mempoolLoop:
// chain with no issues. // chain with no issues.
block := btcutil.NewBlock(&msgBlock) block := btcutil.NewBlock(&msgBlock)
block.SetHeight(nextBlockHeight) block.SetHeight(nextBlockHeight)
if err := g.chain.SetClaimtrieHeader(block, blockUtxos); err != nil {
return nil, err
}
if err := g.chain.CheckConnectBlockTemplate(block); err != nil { if err := g.chain.CheckConnectBlockTemplate(block); err != nil {
return nil, err return nil, err
} }