mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Merge pull request #2983 from MetaMask/i2907-NoCodeGasLimit
Set gas limit to 21k for recipients with no code
This commit is contained in:
commit
727ec73b66
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
## Current Master
|
## Current Master
|
||||||
|
|
||||||
|
- Estimating gas limit for simple ether sends now faster & cheaper, by avoiding VM usage on recipients with no code.
|
||||||
- Add an extra px to address for Firefox clipping.
|
- Add an extra px to address for Firefox clipping.
|
||||||
- Fix Firefox scrollbar.
|
- Fix Firefox scrollbar.
|
||||||
- Open metamask popup for transaction confirmation before gas estimation finishes and add a loading screen over transaction confirmation.
|
- Open metamask popup for transaction confirmation before gas estimation finishes and add a loading screen over transaction confirmation.
|
||||||
|
@ -4,6 +4,7 @@ const {
|
|||||||
BnMultiplyByFraction,
|
BnMultiplyByFraction,
|
||||||
bnToHex,
|
bnToHex,
|
||||||
} = require('./util')
|
} = require('./util')
|
||||||
|
const SIMPLE_GAS_COST = '0x5208' // Hex for 21000, cost of a simple send.
|
||||||
|
|
||||||
/*
|
/*
|
||||||
tx-utils are utility methods for Transaction manager
|
tx-utils are utility methods for Transaction manager
|
||||||
@ -37,14 +38,30 @@ module.exports = class txProvideUtil {
|
|||||||
|
|
||||||
async estimateTxGas (txMeta, blockGasLimitHex) {
|
async estimateTxGas (txMeta, blockGasLimitHex) {
|
||||||
const txParams = txMeta.txParams
|
const txParams = txMeta.txParams
|
||||||
|
|
||||||
// check if gasLimit is already specified
|
// check if gasLimit is already specified
|
||||||
txMeta.gasLimitSpecified = Boolean(txParams.gas)
|
txMeta.gasLimitSpecified = Boolean(txParams.gas)
|
||||||
// if not, fallback to block gasLimit
|
|
||||||
if (!txMeta.gasLimitSpecified) {
|
// if it is, use that value
|
||||||
|
if (txMeta.gasLimitSpecified) {
|
||||||
|
return txParams.gas
|
||||||
|
}
|
||||||
|
|
||||||
|
// if recipient has no code, gas is 21k max:
|
||||||
|
const recipient = txParams.to
|
||||||
|
const hasRecipient = Boolean(recipient)
|
||||||
|
const code = await this.query.getCode(recipient)
|
||||||
|
if (hasRecipient && (!code || code === '0x')) {
|
||||||
|
txParams.gas = SIMPLE_GAS_COST
|
||||||
|
txMeta.simpleSend = true // Prevents buffer addition
|
||||||
|
return SIMPLE_GAS_COST
|
||||||
|
}
|
||||||
|
|
||||||
|
// if not, fall back to block gasLimit
|
||||||
const blockGasLimitBN = hexToBn(blockGasLimitHex)
|
const blockGasLimitBN = hexToBn(blockGasLimitHex)
|
||||||
const saferGasLimitBN = BnMultiplyByFraction(blockGasLimitBN, 19, 20)
|
const saferGasLimitBN = BnMultiplyByFraction(blockGasLimitBN, 19, 20)
|
||||||
txParams.gas = bnToHex(saferGasLimitBN)
|
txParams.gas = bnToHex(saferGasLimitBN)
|
||||||
}
|
|
||||||
// run tx
|
// run tx
|
||||||
return await this.query.estimateGas(txParams)
|
return await this.query.estimateGas(txParams)
|
||||||
}
|
}
|
||||||
@ -55,7 +72,7 @@ module.exports = class txProvideUtil {
|
|||||||
|
|
||||||
// if gasLimit was specified and doesnt OOG,
|
// if gasLimit was specified and doesnt OOG,
|
||||||
// use original specified amount
|
// use original specified amount
|
||||||
if (txMeta.gasLimitSpecified) {
|
if (txMeta.gasLimitSpecified || txMeta.simpleSend) {
|
||||||
txMeta.estimatedGas = txParams.gas
|
txMeta.estimatedGas = txParams.gas
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user