diff options
author | kumavis <kumavis@users.noreply.github.com> | 2018-01-17 03:16:06 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-01-17 03:16:06 +0800 |
commit | 727ec73b669c9c496b8b8e0fb00088b864d49373 (patch) | |
tree | 27edbac0dd434666b7081de4e08c7b7b5b0defd2 | |
parent | b046f96d4b0809422ac8e1dbfcbdd7a545e7ff3f (diff) | |
parent | c0cf665b8581df4fe1ea360f28c0d2ed940c21c8 (diff) | |
download | tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.tar tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.tar.gz tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.tar.bz2 tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.tar.lz tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.tar.xz tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.tar.zst tangerine-wallet-browser-727ec73b669c9c496b8b8e0fb00088b864d49373.zip |
Merge pull request #2983 from MetaMask/i2907-NoCodeGasLimit
Set gas limit to 21k for recipients with no code
-rw-r--r-- | CHANGELOG.md | 1 | ||||
-rw-r--r-- | app/scripts/lib/tx-gas-utils.js | 29 |
2 files changed, 24 insertions, 6 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md index ea500fafe..1da6da219 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,7 @@ ## 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. - Fix Firefox scrollbar. - Open metamask popup for transaction confirmation before gas estimation finishes and add a loading screen over transaction confirmation. diff --git a/app/scripts/lib/tx-gas-utils.js b/app/scripts/lib/tx-gas-utils.js index 5e49fdb22..e80e0467e 100644 --- a/app/scripts/lib/tx-gas-utils.js +++ b/app/scripts/lib/tx-gas-utils.js @@ -4,6 +4,7 @@ const { BnMultiplyByFraction, bnToHex, } = require('./util') +const SIMPLE_GAS_COST = '0x5208' // Hex for 21000, cost of a simple send. /* tx-utils are utility methods for Transaction manager @@ -37,14 +38,30 @@ module.exports = class txProvideUtil { async estimateTxGas (txMeta, blockGasLimitHex) { const txParams = txMeta.txParams + // check if gasLimit is already specified txMeta.gasLimitSpecified = Boolean(txParams.gas) - // if not, fallback to block gasLimit - if (!txMeta.gasLimitSpecified) { - const blockGasLimitBN = hexToBn(blockGasLimitHex) - const saferGasLimitBN = BnMultiplyByFraction(blockGasLimitBN, 19, 20) - txParams.gas = bnToHex(saferGasLimitBN) + + // 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 saferGasLimitBN = BnMultiplyByFraction(blockGasLimitBN, 19, 20) + txParams.gas = bnToHex(saferGasLimitBN) + // run tx return await this.query.estimateGas(txParams) } @@ -55,7 +72,7 @@ module.exports = class txProvideUtil { // if gasLimit was specified and doesnt OOG, // use original specified amount - if (txMeta.gasLimitSpecified) { + if (txMeta.gasLimitSpecified || txMeta.simpleSend) { txMeta.estimatedGas = txParams.gas return } |