mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-12 19:50:46 +01:00
replace electron store with lowdb
This commit is contained in:
parent
98e2e611f8
commit
f618c0b5ee
50
package-lock.json
generated
50
package-lock.json
generated
@ -105,6 +105,21 @@
|
|||||||
"integrity": "sha512-loKBID6UL4QjhD2scuvv6oAPlQ/WAY7aYTDyKlKo7fIgriLS8EZExqT567cHL5CY6si51MRoX1+r3mitD3eYrA==",
|
"integrity": "sha512-loKBID6UL4QjhD2scuvv6oAPlQ/WAY7aYTDyKlKo7fIgriLS8EZExqT567cHL5CY6si51MRoX1+r3mitD3eYrA==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"@types/lodash": {
|
||||||
|
"version": "4.14.109",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.109.tgz",
|
||||||
|
"integrity": "sha512-hop8SdPUEzbcJm6aTsmuwjIYQo1tqLseKCM+s2bBqTU2gErwI4fE+aqUVOlscPSQbKHKgtMMPoC+h4AIGOJYvw==",
|
||||||
|
"dev": true
|
||||||
|
},
|
||||||
|
"@types/lowdb": {
|
||||||
|
"version": "1.0.2",
|
||||||
|
"resolved": "https://registry.npmjs.org/@types/lowdb/-/lowdb-1.0.2.tgz",
|
||||||
|
"integrity": "sha512-0lS8jOba45tcXne01LXkw06x8uqpIKuh8LTwTOo2zmIXCVoXXmIxAemAGoLJvzNc8Q0qBG+fJT0xJMx7N0FLtA==",
|
||||||
|
"dev": true,
|
||||||
|
"requires": {
|
||||||
|
"@types/lodash": "4.14.109"
|
||||||
|
}
|
||||||
|
},
|
||||||
"@types/lunr": {
|
"@types/lunr": {
|
||||||
"version": "2.1.5",
|
"version": "2.1.5",
|
||||||
"resolved": "https://registry.npmjs.org/@types/lunr/-/lunr-2.1.5.tgz",
|
"resolved": "https://registry.npmjs.org/@types/lunr/-/lunr-2.1.5.tgz",
|
||||||
@ -4220,6 +4235,11 @@
|
|||||||
"integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=",
|
"integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"is-promise": {
|
||||||
|
"version": "2.1.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz",
|
||||||
|
"integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o="
|
||||||
|
},
|
||||||
"is-redirect": {
|
"is-redirect": {
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/is-redirect/-/is-redirect-1.0.0.tgz",
|
||||||
@ -5413,8 +5433,7 @@
|
|||||||
"lodash": {
|
"lodash": {
|
||||||
"version": "4.17.4",
|
"version": "4.17.4",
|
||||||
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz",
|
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz",
|
||||||
"integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=",
|
"integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4="
|
||||||
"dev": true
|
|
||||||
},
|
},
|
||||||
"lodash.isequal": {
|
"lodash.isequal": {
|
||||||
"version": "4.5.0",
|
"version": "4.5.0",
|
||||||
@ -5494,6 +5513,25 @@
|
|||||||
"signal-exit": "3.0.2"
|
"signal-exit": "3.0.2"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"lowdb": {
|
||||||
|
"version": "1.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/lowdb/-/lowdb-1.0.0.tgz",
|
||||||
|
"integrity": "sha512-2+x8esE/Wb9SQ1F9IHaYWfsC9FIecLOPrK4g17FGEayjUWH172H6nwicRovGvSE2CPZouc2MCIqCI7h9d+GftQ==",
|
||||||
|
"requires": {
|
||||||
|
"graceful-fs": "4.1.11",
|
||||||
|
"is-promise": "2.1.0",
|
||||||
|
"lodash": "4.17.4",
|
||||||
|
"pify": "3.0.0",
|
||||||
|
"steno": "0.4.4"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"pify": {
|
||||||
|
"version": "3.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz",
|
||||||
|
"integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY="
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"lowercase-keys": {
|
"lowercase-keys": {
|
||||||
"version": "1.0.1",
|
"version": "1.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-1.0.1.tgz",
|
||||||
@ -8044,6 +8082,14 @@
|
|||||||
"integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=",
|
"integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"steno": {
|
||||||
|
"version": "0.4.4",
|
||||||
|
"resolved": "https://registry.npmjs.org/steno/-/steno-0.4.4.tgz",
|
||||||
|
"integrity": "sha1-BxEFvfwobmYVwEA8J+nXtdy4Vcs=",
|
||||||
|
"requires": {
|
||||||
|
"graceful-fs": "4.1.11"
|
||||||
|
}
|
||||||
|
},
|
||||||
"stream-browserify": {
|
"stream-browserify": {
|
||||||
"version": "2.0.1",
|
"version": "2.0.1",
|
||||||
"resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz",
|
"resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz",
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
"@types/form-data": "^2.2.1",
|
"@types/form-data": "^2.2.1",
|
||||||
"@types/jasmine": "^2.8.2",
|
"@types/jasmine": "^2.8.2",
|
||||||
"@types/keytar": "^4.0.1",
|
"@types/keytar": "^4.0.1",
|
||||||
|
"@types/lowdb": "^1.0.1",
|
||||||
"@types/lunr": "2.1.5",
|
"@types/lunr": "2.1.5",
|
||||||
"@types/node": "8.0.19",
|
"@types/node": "8.0.19",
|
||||||
"@types/node-fetch": "^1.6.9",
|
"@types/node-fetch": "^1.6.9",
|
||||||
@ -75,6 +76,7 @@
|
|||||||
"electron-updater": "2.21.4",
|
"electron-updater": "2.21.4",
|
||||||
"form-data": "2.3.2",
|
"form-data": "2.3.2",
|
||||||
"keytar": "4.1.0",
|
"keytar": "4.1.0",
|
||||||
|
"lowdb": "1.0.0",
|
||||||
"lunr": "2.1.6",
|
"lunr": "2.1.6",
|
||||||
"node-fetch": "2.1.2",
|
"node-fetch": "2.1.2",
|
||||||
"node-forge": "0.7.1",
|
"node-forge": "0.7.1",
|
||||||
|
@ -1,36 +0,0 @@
|
|||||||
import { StorageService } from '../../abstractions/storage.service';
|
|
||||||
|
|
||||||
// tslint:disable-next-line
|
|
||||||
const Store = require('electron-store');
|
|
||||||
|
|
||||||
export class ElectronStorageService implements StorageService {
|
|
||||||
private store: any;
|
|
||||||
|
|
||||||
constructor(defaults?: any) {
|
|
||||||
const storeConfig: any = {
|
|
||||||
defaults: {} as any,
|
|
||||||
name: 'data',
|
|
||||||
};
|
|
||||||
|
|
||||||
if (defaults != null) {
|
|
||||||
storeConfig.defaults = Object.assign({}, storeConfig.defaults, defaults);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.store = new Store(storeConfig);
|
|
||||||
}
|
|
||||||
|
|
||||||
get<T>(key: string): Promise<T> {
|
|
||||||
const val = this.store.get(key) as T;
|
|
||||||
return Promise.resolve(val != null ? val : null);
|
|
||||||
}
|
|
||||||
|
|
||||||
save(key: string, obj: any): Promise<any> {
|
|
||||||
this.store.set(key, obj);
|
|
||||||
return Promise.resolve();
|
|
||||||
}
|
|
||||||
|
|
||||||
remove(key: string): Promise<any> {
|
|
||||||
this.store.delete(key);
|
|
||||||
return Promise.resolve();
|
|
||||||
}
|
|
||||||
}
|
|
16
src/misc/nodeUtils.ts
Normal file
16
src/misc/nodeUtils.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import * as fs from 'fs';
|
||||||
|
import * as path from 'path';
|
||||||
|
|
||||||
|
export class NodeUtils {
|
||||||
|
static mkdirpSync(targetDir: string, mode = 755, relative = false, relativeDir: string = null) {
|
||||||
|
const initialDir = path.isAbsolute(targetDir) ? path.sep : '';
|
||||||
|
const baseDir = relative ? (relativeDir != null ? relativeDir : __dirname) : '.';
|
||||||
|
targetDir.split(path.sep).reduce((parentDir, childDir) => {
|
||||||
|
const dir = path.resolve(baseDir, parentDir, childDir);
|
||||||
|
if (!fs.existsSync(dir)) {
|
||||||
|
fs.mkdirSync(dir, mode);
|
||||||
|
}
|
||||||
|
return dir;
|
||||||
|
}, initialDir);
|
||||||
|
}
|
||||||
|
}
|
@ -13,9 +13,9 @@ export class Utils {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Utils.inited = true;
|
Utils.inited = true;
|
||||||
Utils.isNode = typeof window === 'undefined';
|
Utils.isNode = typeof process !== 'undefined' && (process as any).release.name === 'node';
|
||||||
Utils.isBrowser = !Utils.isNode;
|
Utils.isBrowser = typeof window !== 'undefined';
|
||||||
Utils.global = Utils.isNode ? global : window;
|
Utils.global = Utils.isNode && !Utils.isBrowser ? global : window;
|
||||||
}
|
}
|
||||||
|
|
||||||
static fromB64ToArray(str: string): Uint8Array {
|
static fromB64ToArray(str: string): Uint8Array {
|
||||||
|
@ -353,7 +353,7 @@ export class CipherService implements CipherServiceAbstraction {
|
|||||||
const blob = new Blob([encData], { type: 'application/octet-stream' });
|
const blob = new Blob([encData], { type: 'application/octet-stream' });
|
||||||
fd.append('data', blob, encFileName.encryptedString);
|
fd.append('data', blob, encFileName.encryptedString);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (Utils.isNode) {
|
if (Utils.isNode && !Utils.isBrowser) {
|
||||||
fd.append('data', new Buffer(encData) as any, {
|
fd.append('data', new Buffer(encData) as any, {
|
||||||
filepath: encFileName.encryptedString,
|
filepath: encFileName.encryptedString,
|
||||||
contentType: 'application/octet-stream',
|
contentType: 'application/octet-stream',
|
||||||
|
51
src/services/lowdbStorage.service.ts
Normal file
51
src/services/lowdbStorage.service.ts
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
import * as fs from 'fs';
|
||||||
|
import * as lowdb from 'lowdb';
|
||||||
|
import * as FileSync from 'lowdb/adapters/FileSync';
|
||||||
|
import * as path from 'path';
|
||||||
|
|
||||||
|
import { StorageService } from '../abstractions/storage.service';
|
||||||
|
|
||||||
|
import { NodeUtils } from '../misc/nodeUtils';
|
||||||
|
import { Utils } from '../misc/utils';
|
||||||
|
|
||||||
|
export class LowdbStorageService implements StorageService {
|
||||||
|
private db: lowdb.LowdbSync<any>;
|
||||||
|
private defaults: any;
|
||||||
|
|
||||||
|
constructor(defaults?: any, dir?: string) {
|
||||||
|
this.defaults = defaults;
|
||||||
|
|
||||||
|
let adapter: lowdb.AdapterSync<any>;
|
||||||
|
if (Utils.isNode && dir != null) {
|
||||||
|
if (!fs.existsSync(dir)) {
|
||||||
|
NodeUtils.mkdirpSync(dir, 755);
|
||||||
|
}
|
||||||
|
const p = path.join(dir, 'data.json');
|
||||||
|
adapter = new FileSync(p);
|
||||||
|
} else if (Utils.isBrowser && !Utils.isNode) {
|
||||||
|
// local storage adapter for web
|
||||||
|
}
|
||||||
|
this.db = lowdb(adapter);
|
||||||
|
}
|
||||||
|
|
||||||
|
init() {
|
||||||
|
if (this.defaults != null) {
|
||||||
|
this.db.defaults(this.defaults).write();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
get<T>(key: string): Promise<T> {
|
||||||
|
const val = this.db.get(key).value();
|
||||||
|
return Promise.resolve(val as T);
|
||||||
|
}
|
||||||
|
|
||||||
|
save(key: string, obj: any): Promise<any> {
|
||||||
|
this.db.set(key, obj).write();
|
||||||
|
return Promise.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
remove(key: string): Promise<any> {
|
||||||
|
this.db.unset(key).write();
|
||||||
|
return Promise.resolve();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user