core: deal with bad transaction Inputs

They may not really have a reference. Fixes #671.
This commit is contained in:
Roman Khimov 2020-02-13 20:59:03 +03:00
parent 2aaeb7f515
commit 0fceaf12d2

View file

@ -965,14 +965,15 @@ func (bc *Blockchain) References(t *transaction.Transaction) map[transaction.Inp
references := make(map[transaction.Input]*transaction.Output) references := make(map[transaction.Input]*transaction.Output)
for prevHash, inputs := range t.GroupInputsByPrevHash() { for prevHash, inputs := range t.GroupInputsByPrevHash() {
if tx, _, err := bc.dao.GetTransaction(prevHash); err != nil { tx, _, err := bc.dao.GetTransaction(prevHash)
tx = nil if err != nil {
} else if tx != nil { return nil
for _, in := range inputs { }
references[*in] = &tx.Outputs[in.PrevIndex] for _, in := range inputs {
if int(in.PrevIndex) > len(tx.Outputs)-1 {
return nil
} }
} else { references[*in] = &tx.Outputs[in.PrevIndex]
references = nil
} }
} }
return references return references
@ -1450,7 +1451,7 @@ func (bc *Blockchain) GetScriptHashesForVerifying(t *transaction.Transaction) ([
} }
references := bc.References(t) references := bc.References(t)
if references == nil { if references == nil {
return nil, errors.New("Invalid operation") return nil, errors.New("invalid inputs")
} }
hashes := make(map[util.Uint160]bool) hashes := make(map[util.Uint160]bool)
for _, i := range t.Inputs { for _, i := range t.Inputs {