diff options
author | kumavis <kumavis@users.noreply.github.com> | 2017-12-08 07:34:56 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-08 07:34:56 +0800 |
commit | d39eb370423e2a2cdd41c47b92796c0d4c829b3b (patch) | |
tree | 06ec6c8b8e1cbaa4c5767399c4d65b1f5935799f /app/scripts/controllers/transactions.js | |
parent | 6553ba132d6f1aa889d9052dac021cefcd708cad (diff) | |
parent | a91200fd08b429c81d4096de17cdd9066a632ade (diff) | |
download | tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.tar tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.tar.gz tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.tar.bz2 tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.tar.lz tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.tar.xz tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.tar.zst tangerine-wallet-browser-d39eb370423e2a2cdd41c47b92796c0d4c829b3b.zip |
Merge pull request #2699 from MetaMask/patch-2v3.13.1
Allow Dapps to Specify Nonce
Diffstat (limited to 'app/scripts/controllers/transactions.js')
-rw-r--r-- | app/scripts/controllers/transactions.js | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/app/scripts/controllers/transactions.js b/app/scripts/controllers/transactions.js index 685db6269..f95b5e39a 100644 --- a/app/scripts/controllers/transactions.js +++ b/app/scripts/controllers/transactions.js @@ -138,18 +138,20 @@ module.exports = class TransactionController extends EventEmitter { async newUnapprovedTransaction (txParams) { log.debug(`MetaMaskController newUnapprovedTransaction ${JSON.stringify(txParams)}`) - const txMeta = await this.addUnapprovedTransaction(txParams) - this.emit('newUnapprovedTx', txMeta) + const initialTxMeta = await this.addUnapprovedTransaction(txParams) + this.emit('newUnapprovedTx', initialTxMeta) // listen for tx completion (success, fail) return new Promise((resolve, reject) => { - this.txStateManager.once(`${txMeta.id}:finished`, (completedTx) => { - switch (completedTx.status) { + this.txStateManager.once(`${initialTxMeta.id}:finished`, (finishedTxMeta) => { + switch (finishedTxMeta.status) { case 'submitted': - return resolve(completedTx.hash) + return resolve(finishedTxMeta.hash) case 'rejected': return reject(new Error('MetaMask Tx Signature: User denied transaction signature.')) + case 'failed': + return reject(new Error(finishedTxMeta.err.message)) default: - return reject(new Error(`MetaMask Tx Signature: Unknown problem: ${JSON.stringify(completedTx.txParams)}`)) + return reject(new Error(`MetaMask Tx Signature: Unknown problem: ${JSON.stringify(finishedTxMeta.txParams)}`)) } }) }) @@ -177,6 +179,7 @@ module.exports = class TransactionController extends EventEmitter { const txParams = txMeta.txParams // ensure value txMeta.gasPriceSpecified = Boolean(txParams.gasPrice) + txMeta.nonceSpecified = Boolean(txParams.nonce) const gasPrice = txParams.gasPrice || await this.query.gasPrice() txParams.gasPrice = ethUtil.addHexPrefix(gasPrice.toString(16)) txParams.value = txParams.value || '0x0' @@ -207,7 +210,12 @@ module.exports = class TransactionController extends EventEmitter { // wait for a nonce nonceLock = await this.nonceTracker.getNonceLock(fromAddress) // add nonce to txParams - txMeta.txParams.nonce = ethUtil.addHexPrefix(nonceLock.nextNonce.toString(16)) + const nonce = txMeta.nonceSpecified ? txMeta.txParams.nonce : nonceLock.nextNonce + if (nonce > nonceLock.nextNonce) { + const message = `Specified nonce may not be larger than account's next valid nonce.` + throw new Error(message) + } + txMeta.txParams.nonce = ethUtil.addHexPrefix(nonce.toString(16)) // add nonce debugging information to txMeta txMeta.nonceDetails = nonceLock.nonceDetails this.txStateManager.updateTx(txMeta, 'transactions#approveTransaction') |