diff options
author | frankiebee <frankie.diamond@gmail.com> | 2017-07-12 03:41:03 +0800 |
---|---|---|
committer | frankiebee <frankie.diamond@gmail.com> | 2017-07-12 03:41:03 +0800 |
commit | 971d25a8ab9fecbad041e3df1696bf67245bd858 (patch) | |
tree | 257ebef4fc679fede3ef7276879086cb250166da /app/scripts/migrations/016.js | |
parent | a670e54973ed1bae20455507a4b3c44e231ba822 (diff) | |
parent | a1fd9bc6bebcad4421a10ab85f525b9686103549 (diff) | |
download | tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.tar tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.tar.gz tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.tar.bz2 tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.tar.lz tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.tar.xz tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.tar.zst tangerine-wallet-browser-971d25a8ab9fecbad041e3df1696bf67245bd858.zip |
Merge branch 'master' into nonce-tracker
Diffstat (limited to 'app/scripts/migrations/016.js')
-rw-r--r-- | app/scripts/migrations/016.js | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/app/scripts/migrations/016.js b/app/scripts/migrations/016.js new file mode 100644 index 000000000..4fc534f1c --- /dev/null +++ b/app/scripts/migrations/016.js @@ -0,0 +1,41 @@ +const version = 16 + +/* + +This migration sets transactions with the 'Gave up submitting tx.' err message +to a 'failed' stated + +*/ + +const clone = require('clone') + +module.exports = { + version, + + migrate: function (originalVersionedData) { + const versionedData = clone(originalVersionedData) + versionedData.meta.version = version + try { + const state = versionedData.data + const newState = transformState(state) + versionedData.data = newState + } catch (err) { + console.warn(`MetaMask Migration #${version}` + err.stack) + } + return Promise.resolve(versionedData) + }, +} + +function transformState (state) { + const newState = state + const transactions = newState.TransactionController.transactions + newState.TransactionController.transactions = transactions.map((txMeta) => { + if (!txMeta.err) return txMeta + if (txMeta.err === 'transaction with the same hash was already imported.') { + txMeta.status = 'submitted' + delete txMeta.err + } + return txMeta + }) + return newState +} |