mirror of
				https://git.unlock-music.dev/um/web.git
				synced 2025-11-04 19:53:28 +08:00 
			
		
		
		
	fix: only pass over config settings
(cherry picked from commit 3884158f06b71907f004d7a2b4df53e3e486983b)
This commit is contained in:
		
							parent
							
								
									eaf457e6a0
								
							
						
					
					
						commit
						0715eeea0b
					
				@ -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;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					    try {
 | 
				
			||||||
      return JSON.parse(result);
 | 
					      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)) {
 | 
				
			||||||
 | 
					      if (key.startsWith(KEY_PREFIX)) {
 | 
				
			||||||
 | 
					        try {
 | 
				
			||||||
          Object.assign(result, { [key]: JSON.parse(value) });
 | 
					          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);
 | 
				
			||||||
 | 
					      });
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user