aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkumavis <kumavis@users.noreply.github.com>2017-04-22 05:51:02 +0800
committerGitHub <noreply@github.com>2017-04-22 05:51:02 +0800
commit46677427b4fba94ba727137716d2424ae4af72d6 (patch)
tree1724b1fe557351bca0b4f3258b99a1533144322f
parentd7d13caf05f027dca86882db0a72625db8da167c (diff)
parent1b19b51e0823726a01eab49ef9416f852f365500 (diff)
downloadtangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.tar
tangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.tar.gz
tangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.tar.bz2
tangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.tar.lz
tangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.tar.xz
tangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.tar.zst
tangerine-wallet-browser-46677427b4fba94ba727137716d2424ae4af72d6.zip
Merge pull request #1333 from MetaMask/firefoxIDB
Fix for Firefox idb
-rw-r--r--mascara/src/lib/index-db-controller.js95
-rw-r--r--mascara/src/ui.js2
2 files changed, 40 insertions, 57 deletions
diff --git a/mascara/src/lib/index-db-controller.js b/mascara/src/lib/index-db-controller.js
index 8db1d5d21..5aded1cbe 100644
--- a/mascara/src/lib/index-db-controller.js
+++ b/mascara/src/lib/index-db-controller.js
@@ -3,37 +3,17 @@ module.exports = class IndexDbController extends EventEmitter {
constructor (opts) {
super()
+ global.IDBTransaction = global.IDBTransaction || global.webkitIDBTransaction || global.msIDBTransaction || {READ_WRITE: "readwrite"}; // This line should only be needed if it is needed to support the object's constants for older browsers
+ global.IDBKeyRange = global.IDBKeyRange || global.webkitIDBKeyRange || global.msIDBKeyRange
this.migrations = opts.migrations
this.key = opts.key
- this.dbObject = global.indexedDB
- this.IDBTransaction = global.IDBTransaction || global.webkitIDBTransaction || global.msIDBTransaction || {READ_WRITE: "readwrite"}; // This line should only be needed if it is needed to support the object's constants for older browsers
- this.IDBKeyRange = global.IDBKeyRange || global.webkitIDBKeyRange || global.msIDBKeyRange;
this.version = opts.version
- this.logging = opts.logging
this.initialState = opts.initialState
- if (this.logging) this.on('log', logger)
}
// Opens the database connection and returns a promise
- open (version = this.version) {
- return new Promise((resolve, reject) => {
- const dbOpenRequest = this.dbObject.open(this.key, version)
- dbOpenRequest.onerror = (event) => {
- return reject(event)
- }
- dbOpenRequest.onsuccess = (event) => {
- this.db = dbOpenRequest.result
- this.emit('success')
- resolve(this.db)
- }
- dbOpenRequest.onupgradeneeded = (event) => {
- this.db = event.target.result
- this.db.createObjectStore('dataStore')
- }
- })
- .then((openRequest) => {
- return this.get('dataStore')
- })
+ open () {
+ return this.get('dataStore')
.then((data) => {
if (!data) {
return this._add('dataStore', this.initialState)
@@ -44,45 +24,48 @@ module.exports = class IndexDbController extends EventEmitter {
})
}
- requestObjectStore (key, type = 'readonly') {
- return new Promise((resolve, reject) => {
- const dbReadWrite = this.db.transaction(key, type)
- const dataStore = dbReadWrite.objectStore(key)
- resolve(dataStore)
- })
- }
get (key = 'dataStore') {
- return this.requestObjectStore(key)
- .then((dataObject)=> {
- return new Promise((resolve, reject) => {
- const getRequest = dataObject.get(key)
- getRequest.onsuccess = (event) => resolve(event.currentTarget.result)
- getRequest.onerror = (event) => reject(event)
- })
- })
+ return this._request('get', key)
}
-
put (state) {
- return this.requestObjectStore('dataStore', 'readwrite')
- .then((dataObject)=> {
- const putRequest = dataObject.put(state, 'dataStore')
- putRequest.onsuccess = (event) => Promise.resolve(event.currentTarget.result)
- putRequest.onerror = (event) => Promise.reject(event)
- })
+ return this._request('put', state, 'dataStore')
}
- _add (key, objStore, cb = logger) {
- return this.requestObjectStore(key, 'readwrite')
- .then((dataObject)=> {
- const addRequest = dataObject.add(objStore, key)
- addRequest.onsuccess = (event) => Promise.resolve(event.currentTarget.result)
- addRequest.onerror = (event) => Promise.reject(event)
- })
+ _add (key = 'dataStore', objStore) {
+ return this._request('add', objStore, key)
}
-}
+ _request (call, ...args) {
+ return new Promise((resolve, reject) => {
+ const self = this
+ const dbOpenRequest = global.indexedDB.open(this.key, this.version)
+
+ dbOpenRequest.addEventListener('upgradeneeded', (event) => {
+ this.db = event.target.result
+ this.db.createObjectStore('dataStore')
+ })
-function logger (err, ress) {
- err ? console.error(`Logger says: ${err}`) : console.dir(`Logger says: ${ress}`)
+ dbOpenRequest.onsuccess = (event) => {
+ this.db = dbOpenRequest.result
+ this.emit('success')
+ const dbTransaction = this.db.transaction('dataStore', 'readwrite')
+ const request = dbTransaction.objectStore('dataStore')
+ const objRequest = request[call](...args)
+ objRequest.addEventListener('success', (event) => {
+ return resolve(objRequest.result)
+ })
+ objRequest.addEventListener('error', (err) => {
+ return reject(`IndexDBController - ${call} failed to excute on indexedDB`)
+ })
+ dbTransaction.addEventListener('complete', (event) => {
+ this.emit('complete')
+ })
+ }
+
+ dbOpenRequest.addEventListener('error', (event) => {
+ return reject({message: `IndexDBController - open:@${call} failed to excute on indexedDB`, errorEvent: event})
+ })
+ })
+ }
}
diff --git a/mascara/src/ui.js b/mascara/src/ui.js
index 2873017cb..cdf985ebd 100644
--- a/mascara/src/ui.js
+++ b/mascara/src/ui.js
@@ -24,7 +24,7 @@ const background = new SWcontroller({
fileName: '/background.js',
letBeIdle: false,
intervalDelay,
- wakeUpInterval: 30000
+ wakeUpInterval: 20000
})
// Setup listener for when the service worker is read
background.on('ready', (readSw) => {