diff options
author | kumavis <kumavis@users.noreply.github.com> | 2018-03-28 08:01:01 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-03-28 08:01:01 +0800 |
commit | b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3 (patch) | |
tree | 406c402960ec4e6016328ddf065e2f8be794e230 /app/scripts/migrations/023.js | |
parent | cd3e092c14ce4541b36cd0fa15973057c7f2d561 (diff) | |
parent | fefbf40a06aa4af7d5cf08767fa96ad75427dd20 (diff) | |
download | tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.tar tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.tar.gz tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.tar.bz2 tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.tar.lz tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.tar.xz tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.tar.zst tangerine-wallet-browser-b6b18339e2de92afd2fb5364ec5bc4c29b4d10a3.zip |
Merge pull request #3758 from MetaMask/i#3731
I#3731
Diffstat (limited to 'app/scripts/migrations/023.js')
-rw-r--r-- | app/scripts/migrations/023.js | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/app/scripts/migrations/023.js b/app/scripts/migrations/023.js new file mode 100644 index 000000000..bce0a5bea --- /dev/null +++ b/app/scripts/migrations/023.js @@ -0,0 +1,50 @@ + +const version = 23 + +/* + +This migration removes transactions that are no longer usefull down to 40 total + +*/ + +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 + + if (transactions.length <= 40) return newState + + let reverseTxList = transactions.reverse() + let stripping = true + while (reverseTxList.length > 40 && stripping) { + let txIndex = reverseTxList.findIndex((txMeta) => { + return (txMeta.status === 'failed' || + txMeta.status === 'rejected' || + txMeta.status === 'confirmed' || + txMeta.status === 'dropped') + }) + if (txIndex < 0) stripping = false + else reverseTxList.splice(txIndex, 1) + } + + newState.TransactionController.transactions = reverseTxList.reverse() + return newState +} |