diff options
author | Jimmy Hu <jimmy.hu@dexon.org> | 2019-02-25 18:27:34 +0800 |
---|---|---|
committer | Wei-Ning Huang <w@dexon.org> | 2019-04-09 13:50:03 +0800 |
commit | 9455dcc150df0030306a38f83b6cea52aacb9a8c (patch) | |
tree | 1cc86d3759b66e360a1e2ac2afcce9a4241678b2 /dex/app.go | |
parent | 0d55d2efabf0c75967c3d1e16885e33c40a2e54d (diff) | |
download | dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.tar dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.tar.gz dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.tar.bz2 dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.tar.lz dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.tar.xz dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.tar.zst dexon-9455dcc150df0030306a38f83b6cea52aacb9a8c.zip |
core: Fixed gas price (#205)
* core/vm: update abi
* core/vm: add MinGasPrice to gov
* params: Add MinGasPrice to Config
* dex: SuggestPrice from Governance
* test: add minGasPrice to genesis.json
* core: check underpriced tx
* dex: verify with gas price
Diffstat (limited to 'dex/app.go')
-rw-r--r-- | dex/app.go | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/dex/app.go b/dex/app.go index d2bd02f0c..ab4e80058 100644 --- a/dex/app.go +++ b/dex/app.go @@ -124,6 +124,18 @@ func (d *DexconApp) validateNonce(txs types.Transactions) (map[common.Address]ui return addressFirstNonce, nil } +// validateGasPrice checks if no gas price is lower than minGasPrice defined in +// governance contract. +func (d *DexconApp) validateGasPrice(txs types.Transactions, round uint64) bool { + minGasPrice := d.gov.MinGasPrice(round) + for _, tx := range txs { + if minGasPrice.Cmp(tx.GasPrice()) > 0 { + return false + } + } + return true +} + // PreparePayload is called when consensus core is preparing payload for block. func (d *DexconApp) PreparePayload(position coreTypes.Position) (payload []byte, err error) { // softLimit limits the runtime of inner call to preparePayload. @@ -410,6 +422,10 @@ func (d *DexconApp) VerifyBlock(block *coreTypes.Block) coreTypes.BlockVerifySta log.Error("Validate nonce failed", "error", err) return coreTypes.VerifyInvalidBlock } + if !d.validateGasPrice(transactions, block.Position.Round) { + log.Error("Validate gas price failed") + return coreTypes.VerifyInvalidBlock + } // Check if nonce is strictly increasing for every address. chainID := big.NewInt(int64(block.Position.ChainID)) |