Merge pull request #3565 from MetaMask/local-store-fix

Fix local store promisification
This commit is contained in:
Dan Finlay 2018-03-14 11:27:24 -07:00 committed by GitHub
commit 19b553907c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 31 additions and 9 deletions

View File

@ -3,7 +3,6 @@
// https://developer.mozilla.org/en-US/Add-ons/WebExtensions/API/storage/local
const extension = require('extensionizer')
const { promisify } = require('util')
module.exports = class ExtensionStore {
constructor() {
@ -11,9 +10,6 @@ module.exports = class ExtensionStore {
if (!this.isSupported) {
log.error('Storage local API not available.')
}
const local = extension.storage.local
this._get = promisify(local.get).bind(local)
this._set = promisify(local.set).bind(local)
}
async get() {
@ -31,6 +27,34 @@ module.exports = class ExtensionStore {
async set(state) {
return this._set(state)
}
_get() {
const local = extension.storage.local
return new Promise((resolve, reject) => {
local.get(null, (result) => {
const err = extension.runtime.lastError
if (err) {
reject(err)
} else {
resolve(result)
}
})
})
}
_set(obj) {
const local = extension.storage.local
return new Promise((resolve, reject) => {
local.set(obj, () => {
const err = extension.runtime.lastError
if (err) {
reject(err)
} else {
resolve()
}
})
})
}
}
function isEmpty(obj) {

View File

@ -1,6 +1,6 @@
const fs = require('fs')
const path = require('path')
const { promisify } = require('util')
const promisify = require('pify')
start().catch(console.error)

View File

@ -1,4 +1,4 @@
const { promisify } = require('util')
const promisify = require('pify')
const fs = require('fs')
const readFile = promisify(fs.readFile)
const writeFile = promisify(fs.writeFile)

View File

@ -1,6 +1,6 @@
const assert = require('assert')
const versionBump = require('../../../development/version-bump')
const { promisify } = require('util')
const promisify = require('pify')
const fs = require('fs')
const readFile = promisify(fs.readFile)
const path = require('path')
@ -41,5 +41,3 @@ describe('version bumper', function () {
assert.ok(result.changelog.includes(expected))
})
})