aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/background.js
diff options
context:
space:
mode:
authorDan Finlay <dan@danfinlay.com>2018-01-24 08:27:38 +0800
committerDan Finlay <dan@danfinlay.com>2018-01-24 08:33:37 +0800
commit7c4a9c32fa449197bf790b6ce6e91c41efe05ab9 (patch)
tree1179d69c2d8c721d5873cb945d4bda8e21b4918a /app/scripts/background.js
parent03c64ba8a646cbc5a62f2b2a8c5881bb4a4bda60 (diff)
parent456dfdb9fdc0b7b0637d50808beb85ae33602f5b (diff)
downloadtangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.tar
tangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.tar.gz
tangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.tar.bz2
tangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.tar.lz
tangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.tar.xz
tangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.tar.zst
tangerine-wallet-browser-7c4a9c32fa449197bf790b6ce6e91c41efe05ab9.zip
Merge branch 'UseStorageLocal' into i3076-UseStorageLocalInstead
Diffstat (limited to 'app/scripts/background.js')
-rw-r--r--app/scripts/background.js18
1 files changed, 18 insertions, 0 deletions
diff --git a/app/scripts/background.js b/app/scripts/background.js
index 0471cee3b..280c28d70 100644
--- a/app/scripts/background.js
+++ b/app/scripts/background.js
@@ -4,6 +4,7 @@ const pump = require('pump')
const log = require('loglevel')
const extension = require('extensionizer')
const LocalStorageStore = require('obs-store/lib/localStorage')
+const LocalStore = require('./lib/local-store')
const storeTransform = require('obs-store/lib/transform')
const asStream = require('obs-store/lib/asStream')
const ExtensionPlatform = require('./platforms/extension')
@@ -33,6 +34,7 @@ let popupIsOpen = false
// state persistence
const diskStore = new LocalStorageStore({ storageKey: STORAGE_KEY })
+const localStore = new LocalStore()
// initialization flow
initialize().catch(log.error)
@@ -52,6 +54,14 @@ async function loadStateFromPersistence () {
const migrator = new Migrator({ migrations })
// read from disk
let versionedData = diskStore.getState() || migrator.generateInitialState(firstTimeState)
+ // fetch from extension store and merge in data
+
+ if (localStore.isSupported) {
+ const localData = await localStore.get()
+ // TODO: handle possible exceptions (https://developer.chrome.com/apps/runtime#property-lastError)
+ versionedData = Object.keys(localData).length > 0 ? localData : versionedData
+ }
+
// migrate data
versionedData = await migrator.migrateData(versionedData)
// write to disk
@@ -91,6 +101,7 @@ function setupController (initState) {
pump(
asStream(controller.store),
storeTransform(versionifyData),
+ storeTransform(syncDataWithExtension),
asStream(diskStore)
)
@@ -100,6 +111,13 @@ function setupController (initState) {
return versionedData
}
+ function syncDataWithExtension(state) {
+ if (localStore.isSupported) {
+ localStore.set(state) // TODO: handle possible exceptions (https://developer.chrome.com/apps/runtime#property-lastError)
+ }
+ return state
+ }
+
//
// connect to other contexts
//