core: fix Neo.Contract.GetStorageContext security check

This syscall should only work for contracts created by current transaction and
that is what is supposed to be checked here. Do so by looking at the
differences between ic.dao and original lower DAO.
This commit is contained in:
Roman Khimov 2020-05-17 23:58:23 +03:00
parent 4284eaf4ab
commit 8231953842
2 changed files with 8 additions and 2 deletions

View file

@ -27,6 +27,7 @@ type Context struct {
Block *block.Block Block *block.Block
Tx *transaction.Transaction Tx *transaction.Transaction
DAO *dao.Cached DAO *dao.Cached
LowerDAO dao.DAO
Notifications []state.NotificationEvent Notifications []state.NotificationEvent
Log *zap.Logger Log *zap.Logger
} }
@ -42,6 +43,7 @@ func NewContext(trigger trigger.Type, bc blockchainer.Blockchainer, d dao.DAO, n
Block: block, Block: block,
Tx: tx, Tx: tx,
DAO: dao, DAO: dao,
LowerDAO: d,
Notifications: nes, Notifications: nes,
Log: log, Log: log,
} }

View file

@ -537,8 +537,12 @@ func contractGetStorageContext(ic *interop.Context, v *vm.VM) error {
if !ok { if !ok {
return fmt.Errorf("%T is not a contract state", cs) return fmt.Errorf("%T is not a contract state", cs)
} }
contractState, err := ic.DAO.GetContractState(cs.ScriptHash()) _, err := ic.DAO.GetContractState(cs.ScriptHash())
if contractState == nil || err != nil { if err != nil {
return fmt.Errorf("non-existent contract")
}
_, err = ic.LowerDAO.GetContractState(cs.ScriptHash())
if err == nil {
return fmt.Errorf("contract was not created in this transaction") return fmt.Errorf("contract was not created in this transaction")
} }
stc := &StorageContext{ stc := &StorageContext{