Skip to content

Commit

Permalink
Reject blocks which emit Qi UTXOs to inactive chains
Browse files Browse the repository at this point in the history
  • Loading branch information
wizeguyy committed Dec 4, 2024
1 parent c9b884f commit 64359a3
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions core/block_validator.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,9 +94,23 @@ func (v *BlockValidator) ValidateBody(block *types.WorkObject) error {
if hash := types.CalcUncleHash(block.Uncles()); hash != header.UncleHash() {
return fmt.Errorf("uncle root hash mismatch: have %x, want %x", hash, header.UncleHash())
}
if v.hc.ProcessingState() {
if hash := types.DeriveSha(block.Transactions(), trie.NewStackTrie(nil)); hash != header.TxHash() {
return fmt.Errorf("transaction root hash mismatch: have %x, want %x", hash, header.TxHash())
if hash := types.DeriveSha(block.Transactions(), trie.NewStackTrie(nil)); hash != header.TxHash() {
return fmt.Errorf("transaction root hash mismatch: have %x, want %x", hash, header.TxHash())
}
activeLocations := common.NewChainsAdded(v.hc.currentExpansionNumber)
for _, tx := range block.Transactions() {
if types.QiTxType == tx.Type() {
for _, txo := range tx.TxOut() {
found := false
for _, activeLoc := range activeLocations {
if common.IsInChainScope(txo.Address, activeLoc) {
found = true
}
}
if !found {
return fmt.Errorf("Qi TXO emitted to an inactive chain")
}
}
}
}
// The header view should have the etxs populated
Expand Down

0 comments on commit 64359a3

Please sign in to comment.