diff options
author | kumavis <aaron@kumavis.me> | 2018-03-09 06:10:28 +0800 |
---|---|---|
committer | kumavis <aaron@kumavis.me> | 2018-03-09 06:10:28 +0800 |
commit | 98efca0a9798db205ef8068c038a225a79c575cd (patch) | |
tree | 4ec379cefe4c5e0a1838b2a89fe107cc4ee129c4 /app/scripts/lib | |
parent | 64fcd271028ff57c34dd930b76ce23081eff814a (diff) | |
download | tangerine-wallet-browser-98efca0a9798db205ef8068c038a225a79c575cd.tar.gz tangerine-wallet-browser-98efca0a9798db205ef8068c038a225a79c575cd.tar.zst tangerine-wallet-browser-98efca0a9798db205ef8068c038a225a79c575cd.zip |
background - storage - cleanup storage wiring
Diffstat (limited to 'app/scripts/lib')
-rw-r--r-- | app/scripts/lib/local-store.js | 30 |
1 files changed, 22 insertions, 8 deletions
diff --git a/app/scripts/lib/local-store.js b/app/scripts/lib/local-store.js index 9e8d8db37..73482a636 100644 --- a/app/scripts/lib/local-store.js +++ b/app/scripts/lib/local-store.js @@ -3,6 +3,7 @@ // https://developer.mozilla.org/en-US/Add-ons/WebExtensions/API/storage/local const extension = require('extensionizer') +const { promisify } = require('util').promisify module.exports = class ExtensionStore { constructor() { @@ -10,15 +11,28 @@ 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) } - get() { - return new Promise((resolve) => { - extension.storage.local.get(null, resolve) - }) + + async get() { + if (!this.isSupported) return undefined + const result = await this._get() + // extension.storage.local always returns an obj + // if the object is empty, treat it as undefined + if (isEmpty(result)) { + return undefined + } else { + return result + } } - set(state) { - return new Promise((resolve) => { - extension.storage.local.set(state, resolve) - }) + + async set(state) { + return this._set(state) } } + +function isEmpty(obj) { + return 0 === Object.keys(obj).length +} |