aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBojie Wu <bojie@dexon.org>2018-10-11 17:54:53 +0800
committerWei-Ning Huang <w@dexon.org>2019-04-09 13:49:52 +0800
commit5e2bc92a31f551effac515e6533d767cdea69d28 (patch)
tree9cb89a60ecddcbda324a3b6f36337743f3e8c6a3
parent67415fa1080c4189c997d063942cc0cdc60bf3b6 (diff)
downloaddexon-5e2bc92a31f551effac515e6533d767cdea69d28.tar
dexon-5e2bc92a31f551effac515e6533d767cdea69d28.tar.gz
dexon-5e2bc92a31f551effac515e6533d767cdea69d28.tar.bz2
dexon-5e2bc92a31f551effac515e6533d767cdea69d28.tar.lz
dexon-5e2bc92a31f551effac515e6533d767cdea69d28.tar.xz
dexon-5e2bc92a31f551effac515e6533d767cdea69d28.tar.zst
dexon-5e2bc92a31f551effac515e6533d767cdea69d28.zip
app: correct validation logic
-rw-r--r--dex/app.go14
1 files changed, 10 insertions, 4 deletions
diff --git a/dex/app.go b/dex/app.go
index 80384ddc9..cdbcdbda6 100644
--- a/dex/app.go
+++ b/dex/app.go
@@ -19,6 +19,7 @@ package dex
import (
"bytes"
+ "github.com/dexon-foundation/dexon/core/rawdb"
"math/big"
"sync"
"time"
@@ -27,7 +28,6 @@ import (
"github.com/dexon-foundation/dexon/common"
"github.com/dexon-foundation/dexon/core"
- "github.com/dexon-foundation/dexon/core/rawdb"
"github.com/dexon-foundation/dexon/core/state"
"github.com/dexon-foundation/dexon/core/types"
"github.com/dexon-foundation/dexon/core/vm"
@@ -179,8 +179,7 @@ func (d *DexconApp) VerifyBlock(block *coreTypes.Block) bool {
// verify transactions
for _, transaction := range transactions {
- tx, _, _, _ := rawdb.ReadTransaction(d.chainDB, transaction.Hash())
- if tx == nil || d.txPool.ValidateTx(transaction, false) != nil {
+ if d.txPool.ValidateTx(transaction, false) != nil {
return false
}
}
@@ -218,11 +217,18 @@ func (d *DexconApp) VerifyBlock(block *coreTypes.Block) bool {
} else if witnessBlock.ReceiptHash() != witnessData.ReceiptHash {
// invalid receipt root of witness data
return false
- } else if witnessBlock.TxHash() != witnessData.ReceiptHash {
+ } else if witnessBlock.TxHash() != witnessData.TxHash {
// invalid tx root of witness data
return false
}
+ for _, transaction := range witnessBlock.Transactions() {
+ tx, _, _, _ := rawdb.ReadTransaction(d.chainDB, transaction.Hash())
+ if tx == nil {
+ return false
+ }
+ }
+
return true
}