aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib
diff options
context:
space:
mode:
Diffstat (limited to 'app/scripts/lib')
-rw-r--r--app/scripts/lib/extension-store.js39
-rw-r--r--app/scripts/lib/local-store.js25
2 files changed, 64 insertions, 0 deletions
diff --git a/app/scripts/lib/extension-store.js b/app/scripts/lib/extension-store.js
new file mode 100644
index 000000000..67ee71f16
--- /dev/null
+++ b/app/scripts/lib/extension-store.js
@@ -0,0 +1,39 @@
+const extension = require('extensionizer')
+
+const KEYS_TO_SYNC = ['KeyringController', 'PreferencesController']
+const FIREFOX_SYNC_DISABLED_MESSAGE = 'Please set webextensions.storage.sync.enabled to true in about:config'
+
+const handleDisabledSyncAndResolve = (resolve, toResolve) => {
+ // Firefox 52 has sync available on extension.storage, but it is disabled by default
+ const lastError = extension.runtime.lastError
+ if (lastError && lastError.message.includes(FIREFOX_SYNC_DISABLED_MESSAGE)) {
+ resolve({})
+ } else {
+ resolve(toResolve)
+ }
+}
+
+module.exports = class ExtensionStore {
+ constructor() {
+ this.isSupported = !!(extension.storage.sync)
+ this.isEnabled = true // TODO: get value from user settings
+ }
+ async fetch() {
+ return new Promise((resolve) => {
+ extension.storage.sync.get(KEYS_TO_SYNC, (data) => {
+ handleDisabledSyncAndResolve(resolve, data)
+ })
+ })
+ }
+ async sync(state) {
+ const dataToSync = KEYS_TO_SYNC.reduce((result, key) => {
+ result[key] = state.data[key]
+ return result
+ }, {})
+ return new Promise((resolve) => {
+ extension.storage.sync.set(dataToSync, () => {
+ handleDisabledSyncAndResolve(resolve)
+ })
+ })
+ }
+}
diff --git a/app/scripts/lib/local-store.js b/app/scripts/lib/local-store.js
new file mode 100644
index 000000000..32faac96b
--- /dev/null
+++ b/app/scripts/lib/local-store.js
@@ -0,0 +1,25 @@
+// We should not rely on local storage in an extension!
+// We should use this instead!
+// https://developer.mozilla.org/en-US/Add-ons/WebExtensions/API/storage/local
+
+const extension = require('extensionizer')
+const STORAGE_KEY = 'metamask-config'
+
+module.exports = class ExtensionStore {
+ constructor() {
+ this.isSupported = !!(extension.storage.local)
+ if (!this.isSupported) {
+ log.error('Storage local API not available.')
+ }
+ }
+ async get() {
+ return new Promise((resolve) => {
+ extension.storage.local.get(STORAGE_KEY, resolve)
+ })
+ }
+ async set(state) {
+ return new Promise((resolve) => {
+ extension.storage.local.set(state, resolve)
+ })
+ }
+}