mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
Merge pull request #1250 from MetaMask/notice-modification
Erase notice body when read
This commit is contained in:
commit
c45ed395a6
36
app/scripts/migrations/012.js
Normal file
36
app/scripts/migrations/012.js
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
const version = 12
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
|
This migration modifies our notices to delete their body after being read.
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
const clone = require('clone')
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
version,
|
||||||
|
|
||||||
|
migrate: function (originalVersionedData) {
|
||||||
|
let 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
|
||||||
|
newState.NoticeController.noticesList.forEach((notice) => {
|
||||||
|
if (notice.read) {
|
||||||
|
notice.body = ''
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return newState
|
||||||
|
}
|
@ -41,6 +41,7 @@ module.exports = class NoticeController extends EventEmitter {
|
|||||||
var notices = this.getNoticesList()
|
var notices = this.getNoticesList()
|
||||||
var index = notices.findIndex((currentNotice) => currentNotice.id === noticeToMark.id)
|
var index = notices.findIndex((currentNotice) => currentNotice.id === noticeToMark.id)
|
||||||
notices[index].read = true
|
notices[index].read = true
|
||||||
|
notices[index].body = ''
|
||||||
this.setNoticesList(notices)
|
this.setNoticesList(notices)
|
||||||
const latestNotice = this.getLatestUnreadNotice()
|
const latestNotice = this.getLatestUnreadNotice()
|
||||||
cb(null, latestNotice)
|
cb(null, latestNotice)
|
||||||
|
@ -48,6 +48,13 @@
|
|||||||
"title":"Ending Morden Support",
|
"title":"Ending Morden Support",
|
||||||
"body":"Due to [recent events](https://blog.ethereum.org/2016/11/20/from-morden-to-ropsten/), MetaMask is now deprecating support for the Morden Test Network.\n\nUsers will still be able to access Morden through a locally hosted node, but we will no longer be providing hosted access to this network through [Infura](http://infura.io/).\n\nPlease use the new Ropsten Network as your new default test network.\n\nYou can fund your Ropsten account using the buy button on your account page.\n\nBest wishes!\nThe MetaMask Team\n\n",
|
"body":"Due to [recent events](https://blog.ethereum.org/2016/11/20/from-morden-to-ropsten/), MetaMask is now deprecating support for the Morden Test Network.\n\nUsers will still be able to access Morden through a locally hosted node, but we will no longer be providing hosted access to this network through [Infura](http://infura.io/).\n\nPlease use the new Ropsten Network as your new default test network.\n\nYou can fund your Ropsten account using the buy button on your account page.\n\nBest wishes!\nThe MetaMask Team\n\n",
|
||||||
"id":0
|
"id":0
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"read":false,
|
||||||
|
"date":"Sat Dec 17 2016",
|
||||||
|
"title":"Keeping It Real",
|
||||||
|
"body":"nonempty",
|
||||||
|
"id":1
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"conversionRate":12.66441492,
|
"conversionRate":12.66441492,
|
||||||
|
@ -15,6 +15,8 @@ const migration8 = require(path.join('..', '..', 'app', 'scripts', 'migrations',
|
|||||||
const migration9 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '009'))
|
const migration9 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '009'))
|
||||||
const migration10 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '010'))
|
const migration10 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '010'))
|
||||||
const migration11 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '011'))
|
const migration11 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '011'))
|
||||||
|
const migration12 = require(path.join('..', '..', 'app', 'scripts', 'migrations', '012'))
|
||||||
|
|
||||||
|
|
||||||
const oldTestRpc = 'https://rawtestrpc.metamask.io/'
|
const oldTestRpc = 'https://rawtestrpc.metamask.io/'
|
||||||
const newTestRpc = 'https://testrpc.metamask.io/'
|
const newTestRpc = 'https://testrpc.metamask.io/'
|
||||||
@ -91,6 +93,11 @@ describe('wallet1 is migrated successfully', () => {
|
|||||||
}).then((eleventhResult) => {
|
}).then((eleventhResult) => {
|
||||||
assert.equal(eleventhResult.data.isDisclaimerConfirmed, null, 'isDisclaimerConfirmed should not exist')
|
assert.equal(eleventhResult.data.isDisclaimerConfirmed, null, 'isDisclaimerConfirmed should not exist')
|
||||||
assert.equal(eleventhResult.data.TOSHash, null, 'TOSHash should not exist')
|
assert.equal(eleventhResult.data.TOSHash, null, 'TOSHash should not exist')
|
||||||
|
|
||||||
|
return migration12.migrate(eleventhResult)
|
||||||
|
}).then((twelfthResult) => {
|
||||||
|
assert.equal(twelfthResult.data.NoticeController.noticesList[0].body, '', 'notices that have been read should have an empty body.')
|
||||||
|
assert.equal(twelfthResult.data.NoticeController.noticesList[1].body, 'nonempty', 'notices that have not been read should not have an empty body.')
|
||||||
})
|
})
|
||||||
|
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user