mirror of
https://git.unlock-music.dev/um/web.git
synced 2025-01-01 19:05:03 +08:00
refactor: storage factory + singleton
- Make storage easier. (cherry picked from commit ed84a4732d7dd3ce6b2c22f30553ab5c59f85dbb)
This commit is contained in:
parent
8673adfda6
commit
d8b362efbe
@ -13,7 +13,7 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import storage from '../utils/storage';
|
import { storage } from '@/utils/storage';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
components: {},
|
components: {},
|
||||||
|
@ -2,8 +2,8 @@ import { DecryptResult } from './entity';
|
|||||||
import { AudioMimeType, GetArrayBuffer, SniffAudioExt } from './utils';
|
import { AudioMimeType, GetArrayBuffer, SniffAudioExt } from './utils';
|
||||||
|
|
||||||
import jooxFactory from '@unlock-music/joox-crypto';
|
import jooxFactory from '@unlock-music/joox-crypto';
|
||||||
import storage from '@/utils/storage';
|
|
||||||
import { MergeUint8Array } from '@/utils/MergeUint8Array';
|
import { MergeUint8Array } from '@/utils/MergeUint8Array';
|
||||||
|
import { storage } from '@/utils/storage';
|
||||||
|
|
||||||
export async function Decrypt(file: Blob, raw_filename: string, raw_ext: string): Promise<DecryptResult> {
|
export async function Decrypt(file: Blob, raw_filename: string, raw_ext: string): Promise<DecryptResult> {
|
||||||
const uuid = await storage.loadJooxUUID('');
|
const uuid = await storage.loadJooxUUID('');
|
||||||
|
@ -1,7 +1,3 @@
|
|||||||
import BaseStorage from './storage/BaseStorage';
|
import storageFactory from './storage/StorageFactory';
|
||||||
import BrowserNativeStorage from './storage/BrowserNativeStorage';
|
|
||||||
import ChromeExtensionStorage from './storage/ChromeExtensionStorage';
|
|
||||||
|
|
||||||
const storage: BaseStorage = ChromeExtensionStorage.works ? new ChromeExtensionStorage() : new BrowserNativeStorage();
|
export const storage = storageFactory();
|
||||||
|
|
||||||
export default storage;
|
|
||||||
|
@ -3,6 +3,8 @@ const KEY_JOOX_UUID = 'joox.uuid';
|
|||||||
export default abstract class BaseStorage {
|
export default abstract class BaseStorage {
|
||||||
protected abstract save<T>(name: string, value: T): Promise<void>;
|
protected abstract save<T>(name: string, value: T): Promise<void>;
|
||||||
protected abstract load<T>(name: string, defaultValue: T): Promise<T>;
|
protected abstract load<T>(name: string, defaultValue: T): Promise<T>;
|
||||||
|
public abstract getAll(): Promise<Record<string, any>>;
|
||||||
|
public abstract setAll(obj: Record<string, any>): Promise<void>;
|
||||||
|
|
||||||
public saveJooxUUID(uuid: string): Promise<void> {
|
public saveJooxUUID(uuid: string): Promise<void> {
|
||||||
return this.save(KEY_JOOX_UUID, uuid);
|
return this.save(KEY_JOOX_UUID, uuid);
|
||||||
|
@ -1,6 +1,10 @@
|
|||||||
import BaseStorage from './BaseStorage';
|
import BaseStorage from './BaseStorage';
|
||||||
|
|
||||||
export default class BrowserNativeStorage extends BaseStorage {
|
export default class BrowserNativeStorage extends BaseStorage {
|
||||||
|
public static get works() {
|
||||||
|
return typeof localStorage !== 'undefined' && localStorage.getItem;
|
||||||
|
}
|
||||||
|
|
||||||
protected async load<T>(name: string, defaultValue: T): Promise<T> {
|
protected async load<T>(name: string, defaultValue: T): Promise<T> {
|
||||||
const result = localStorage.getItem(name);
|
const result = localStorage.getItem(name);
|
||||||
if (result === null) {
|
if (result === null) {
|
||||||
@ -12,4 +16,18 @@ export default class BrowserNativeStorage extends BaseStorage {
|
|||||||
protected async save<T>(name: string, value: T): Promise<void> {
|
protected async save<T>(name: string, value: T): Promise<void> {
|
||||||
localStorage.setItem(name, JSON.stringify(value));
|
localStorage.setItem(name, JSON.stringify(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async getAll(): Promise<Record<string, any>> {
|
||||||
|
const result = {};
|
||||||
|
for (const [key, value] of Object.entries(localStorage)) {
|
||||||
|
Object.assign(result, { [key]: JSON.parse(value) });
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async setAll(obj: Record<string, any>): Promise<void> {
|
||||||
|
for (const [key, value] of Object.entries(obj)) {
|
||||||
|
localStorage.setItem(key, JSON.stringify(value));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,4 +24,16 @@ export default class ChromeExtensionStorage extends BaseStorage {
|
|||||||
chrome.storage.local.set({ [name]: value }, resolve);
|
chrome.storage.local.set({ [name]: value }, resolve);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async getAll(): Promise<Record<string, any>> {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
chrome.storage.local.get(null, resolve);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public async setAll(obj: Record<string, any>): Promise<void> {
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
chrome.storage.local.set(obj, resolve);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
32
src/utils/storage/InMemoryStorage.ts
Normal file
32
src/utils/storage/InMemoryStorage.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import BaseStorage from './BaseStorage';
|
||||||
|
|
||||||
|
export default class InMemoryStorage extends BaseStorage {
|
||||||
|
private values = new Map<string, any>();
|
||||||
|
protected async load<T>(name: string, defaultValue: T): Promise<T> {
|
||||||
|
if (this.values.has(name)) {
|
||||||
|
return this.values.get(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
return defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected async save<T>(name: string, value: T): Promise<void> {
|
||||||
|
this.values.set(name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async getAll(): Promise<Record<string, any>> {
|
||||||
|
const result = {};
|
||||||
|
this.values.forEach((value, key) => {
|
||||||
|
Object.assign(result, {
|
||||||
|
[key]: value,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public async setAll(obj: Record<string, any>): Promise<void> {
|
||||||
|
for (const [key, value] of Object.entries(obj)) {
|
||||||
|
this.values.set(key, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
13
src/utils/storage/StorageFactory.ts
Normal file
13
src/utils/storage/StorageFactory.ts
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import BaseStorage from './BaseStorage';
|
||||||
|
import BrowserNativeStorage from './BrowserNativeStorage';
|
||||||
|
import ChromeExtensionStorage from './ChromeExtensionStorage';
|
||||||
|
import InMemoryStorage from './InMemoryStorage';
|
||||||
|
|
||||||
|
export default function storageFactory(): BaseStorage {
|
||||||
|
if (ChromeExtensionStorage.works) {
|
||||||
|
return new ChromeExtensionStorage();
|
||||||
|
} else if (BrowserNativeStorage.works) {
|
||||||
|
return new BrowserNativeStorage();
|
||||||
|
}
|
||||||
|
return new InMemoryStorage();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user