Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

types: Fix (*V2Transaction).DeepCopy mutating V2StorageProof #172

Merged
merged 1 commit into from
Jun 21, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion consensus/validation.go
Original file line number Diff line number Diff line change
Expand Up @@ -834,7 +834,7 @@ func validateV2FileContracts(ms *MidState, txn types.V2Transaction) error {
} else if sp.ProofIndex.ChainIndex.Height != fc.ProofHeight {
// see note on this field in types.StorageProof
return fmt.Errorf("file contract storage proof %v has ProofIndex height (%v) that does not match contract ProofHeight (%v)", i, sp.ProofIndex.ChainIndex.Height, fc.ProofHeight)
} else if ms.base.Elements.containsChainIndex(sp.ProofIndex) {
} else if !ms.base.Elements.containsChainIndex(sp.ProofIndex) {
return fmt.Errorf("file contract storage proof %v has invalid history proof", i)
}
leafIndex := ms.base.StorageProofLeafIndex(fc.Filesize, sp.ProofIndex.ChainIndex.ID, types.FileContractID(fcr.Parent.ID))
Expand Down
12 changes: 8 additions & 4 deletions consensus/validation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -688,7 +688,7 @@ func TestValidateBlock(t *testing.T) {
}
}

func updateProofs(au ApplyUpdate, sces []types.SiacoinElement, sfes []types.SiafundElement, fces []types.V2FileContractElement) {
func updateProofs(au ApplyUpdate, sces []types.SiacoinElement, sfes []types.SiafundElement, fces []types.V2FileContractElement, cies []types.ChainIndexElement) {
for i := range sces {
au.UpdateElementProof(&sces[i].StateElement)
}
Expand All @@ -698,6 +698,9 @@ func updateProofs(au ApplyUpdate, sces []types.SiacoinElement, sfes []types.Siaf
for i := range fces {
au.UpdateElementProof(&fces[i].StateElement)
}
for i := range cies {
au.UpdateElementProof(&cies[i].StateElement)
}
}

func TestValidateV2Block(t *testing.T) {
Expand Down Expand Up @@ -1171,7 +1174,7 @@ func TestValidateV2Block(t *testing.T) {

cs, testAU := ApplyBlock(cs, validBlock, db.supplementTipBlock(validBlock), time.Now())
db.applyBlock(testAU)
updateProofs(testAU, sces, sfes, fces)
updateProofs(testAU, sces, sfes, fces, cies)

var testSces []types.SiacoinElement
testAU.ForEachSiacoinElement(func(sce types.SiacoinElement, spent bool) {
Expand Down Expand Up @@ -1209,8 +1212,8 @@ func TestValidateV2Block(t *testing.T) {
}
cs, au = ApplyBlock(cs, b, db.supplementTipBlock(validBlock), time.Now())
db.applyBlock(au)
updateProofs(au, sces, sfes, fces)
updateProofs(au, testSces, testSfes, testFces)
updateProofs(au, sces, sfes, fces, cies)
updateProofs(au, testSces, testSfes, testFces, nil)
cies = append(cies, au.ChainIndexElement())

blockID = b.ID()
Expand Down Expand Up @@ -1246,6 +1249,7 @@ func TestValidateV2Block(t *testing.T) {
Proof: []types.Hash256{cs.StorageProofLeafHash([]byte{1})},
}
}

signTxn(cs, &b.V2.Transactions[0])
b.V2.Commitment = cs.Commitment(cs.TransactionsCommitment(b.Transactions, b.V2Transactions()), b.MinerPayouts[0].Address)
findBlockNonce(cs, &validBlock)
Expand Down
4 changes: 3 additions & 1 deletion types/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -736,9 +736,11 @@ func (txn *V2Transaction) DeepCopy() V2Transaction {
c.FileContractResolutions = append([]V2FileContractResolution(nil), c.FileContractResolutions...)
for i := range c.FileContractResolutions {
c.FileContractResolutions[i].Parent.MerkleProof = append([]Hash256(nil), c.FileContractResolutions[i].Parent.MerkleProof...)
if sp, ok := c.FileContractResolutions[i].Resolution.(*V2StorageProof); ok {
if res, ok := c.FileContractResolutions[i].Resolution.(*V2StorageProof); ok {
sp := *res
sp.ProofIndex.MerkleProof = append([]Hash256(nil), sp.ProofIndex.MerkleProof...)
sp.Proof = append([]Hash256(nil), sp.Proof...)
c.FileContractResolutions[i].Resolution = &sp
}
}
c.Attestations = append([]Attestation(nil), c.Attestations...)
Expand Down
Loading