fix: only pass over config settings
This commit is contained in:
		| @@ -1,4 +1,5 @@ | |||||||
| const KEY_JOOX_UUID = 'joox.uuid'; | export const KEY_PREFIX = 'um.conf.'; | ||||||
|  | const KEY_JOOX_UUID = `${KEY_PREFIX}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>; | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| import BaseStorage from './BaseStorage'; | import BaseStorage, { KEY_PREFIX } from './BaseStorage'; | ||||||
|  |  | ||||||
| export default class BrowserNativeStorage extends BaseStorage { | export default class BrowserNativeStorage extends BaseStorage { | ||||||
|   public static get works() { |   public static get works() { | ||||||
| @@ -10,7 +10,11 @@ export default class BrowserNativeStorage extends BaseStorage { | |||||||
|     if (result === null) { |     if (result === null) { | ||||||
|       return defaultValue; |       return defaultValue; | ||||||
|     } |     } | ||||||
|     return JSON.parse(result); |     try { | ||||||
|  |       return JSON.parse(result); | ||||||
|  |     } catch { | ||||||
|  |       return defaultValue; | ||||||
|  |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   protected async save<T>(name: string, value: T): Promise<void> { |   protected async save<T>(name: string, value: T): Promise<void> { | ||||||
| @@ -20,14 +24,20 @@ export default class BrowserNativeStorage extends BaseStorage { | |||||||
|   public async getAll(): Promise<Record<string, any>> { |   public async getAll(): Promise<Record<string, any>> { | ||||||
|     const result = {}; |     const result = {}; | ||||||
|     for (const [key, value] of Object.entries(localStorage)) { |     for (const [key, value] of Object.entries(localStorage)) { | ||||||
|       Object.assign(result, { [key]: JSON.parse(value) }); |       if (key.startsWith(KEY_PREFIX)) { | ||||||
|  |         try { | ||||||
|  |           Object.assign(result, { [key]: JSON.parse(value) }); | ||||||
|  |         } catch { | ||||||
|  |           // ignored | ||||||
|  |         } | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|     return result; |     return result; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   public async setAll(obj: Record<string, any>): Promise<void> { |   public async setAll(obj: Record<string, any>): Promise<void> { | ||||||
|     for (const [key, value] of Object.entries(obj)) { |     for (const [key, value] of Object.entries(obj)) { | ||||||
|       localStorage.setItem(key, JSON.stringify(value)); |       await this.save(key, value); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| import BaseStorage from './BaseStorage'; | import BaseStorage, { KEY_PREFIX } from './BaseStorage'; | ||||||
|  |  | ||||||
| declare var chrome: any; | declare var chrome: any; | ||||||
|  |  | ||||||
| @@ -27,7 +27,15 @@ export default class ChromeExtensionStorage extends BaseStorage { | |||||||
|  |  | ||||||
|   public async getAll(): Promise<Record<string, any>> { |   public async getAll(): Promise<Record<string, any>> { | ||||||
|     return new Promise((resolve) => { |     return new Promise((resolve) => { | ||||||
|       chrome.storage.local.get(null, resolve); |       chrome.storage.local.get(null, (obj: Record<string, any>) => { | ||||||
|  |         const result: Record<string, any> = {}; | ||||||
|  |         for (const [key, value] of Object.entries(obj)) { | ||||||
|  |           if (key.startsWith(KEY_PREFIX)) { | ||||||
|  |             result[key] = value; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |         resolve(result); | ||||||
|  |       }); | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Jixun Wu
					Jixun Wu