Support static save, load, subscribe to logger settings changes
This commit is contained in:
parent
6b9bf1b70f
commit
79e781dcd8
@ -19,45 +19,22 @@ class Logger {
|
|||||||
this.stopTime = conf.timeout ? performance.now() + (conf.timeout * 1000) : undefined;
|
this.stopTime = conf.timeout ? performance.now() + (conf.timeout * 1000) : undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
initLogger() {
|
static saveConfig(conf) {
|
||||||
const ths = this;
|
if (currentBrowser.firefox || currentBrowser.edge) {
|
||||||
|
return browser.storage.local.set( {'uwLogger': JSON.stringify(conf)});
|
||||||
|
} else if (currentBrowser.chrome) {
|
||||||
|
return chrome.storage.local.set( {'uwLogger': JSON.stringify(conf)});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static syncConfig(callback) {
|
||||||
const br = currentBrowser.firefox ? browser : chrome;
|
const br = currentBrowser.firefox ? browser : chrome;
|
||||||
br.storage.onChanged.addListener( (changes, area) => {
|
br.storage.onChanged.addListener( (changes, area) => {
|
||||||
if (Debug.debug && Debug.debugStorage) {
|
callback(JSON.parse(changes.uwLogger.newValue));
|
||||||
console.log("[Logger::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area);
|
|
||||||
if (changes['uwLogger'] && changes['uwLogger'].newValue) {
|
|
||||||
console.log("[Logger::<storage/on change>] new settings object:", JSON.parse(changes.uwLogger.newValue));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(changes['uwLogger'] && changes['uwLogger'].newValue) {
|
|
||||||
ths.conf = JSON.parse(changes.uwLogger.newValue);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async init() {
|
static async getConfig() {
|
||||||
if (!this.conf) {
|
|
||||||
this.conf = await this.getSaved();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
clear() {
|
|
||||||
this.log = [];
|
|
||||||
this.startTime = performance.now();
|
|
||||||
this.stopTime = this.conf.timeout ? performance.now() + (this.conf.timeout * 1000) : undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
setConf(conf) {
|
|
||||||
this.conf = conf; // effective immediately
|
|
||||||
// also persist settings:
|
|
||||||
if (currentBrowser.firefox || currentBrowser.edge) {
|
|
||||||
return browser.storage.local.set( {'uwLogger': JSON.stringify(this.conf)});
|
|
||||||
} else if (currentBrowser.chrome) {
|
|
||||||
return chrome.storage.local.set( {'uwLogger': JSON.stringify(this.logger)});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async getSaved() {
|
|
||||||
let ret;
|
let ret;
|
||||||
|
|
||||||
if (currentBrowser.firefox) {
|
if (currentBrowser.firefox) {
|
||||||
@ -87,6 +64,46 @@ class Logger {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
initLogger() {
|
||||||
|
const ths = this;
|
||||||
|
const br = currentBrowser.firefox ? browser : chrome;
|
||||||
|
br.storage.onChanged.addListener( (changes, area) => {
|
||||||
|
if (Debug.debug && Debug.debugStorage) {
|
||||||
|
console.log("[Logger::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area);
|
||||||
|
if (changes['uwLogger'] && changes['uwLogger'].newValue) {
|
||||||
|
console.log("[Logger::<storage/on change>] new settings object:", JSON.parse(changes.uwLogger.newValue));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(changes['uwLogger'] && changes['uwLogger'].newValue) {
|
||||||
|
ths.conf = JSON.parse(changes.uwLogger.newValue);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
this.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
async init() {
|
||||||
|
if (!this.conf) {
|
||||||
|
this.conf = await this.getSaved();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
clear() {
|
||||||
|
this.log = [];
|
||||||
|
this.startTime = performance.now();
|
||||||
|
this.stopTime = this.conf.timeout ? performance.now() + (this.conf.timeout * 1000) : undefined;
|
||||||
|
}
|
||||||
|
|
||||||
|
setConf(conf) {
|
||||||
|
this.conf = conf; // effective immediately
|
||||||
|
// also persist settings:
|
||||||
|
Logger.saveConfig(conf);
|
||||||
|
}
|
||||||
|
|
||||||
|
async getSaved() {
|
||||||
|
return Logger.getSaved();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// allow syncing of start times between bg and page scripts.
|
// allow syncing of start times between bg and page scripts.
|
||||||
// may result in negative times in the log file, but that doesn't
|
// may result in negative times in the log file, but that doesn't
|
||||||
@ -127,7 +144,7 @@ class Logger {
|
|||||||
}
|
}
|
||||||
|
|
||||||
canLog(component) {
|
canLog(component) {
|
||||||
return this.canLogFile(component) || this.canLogConsole(component);
|
return this.conf.allowLogging && (this.canLogFile(component) || this.canLogConsole(component));
|
||||||
}
|
}
|
||||||
|
|
||||||
canLogFile(component) {
|
canLogFile(component) {
|
||||||
@ -135,6 +152,7 @@ class Logger {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (performance.now() > this.stopTime) {
|
if (performance.now() > this.stopTime) {
|
||||||
|
this.conf.allowLogging = false;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (Array.isArray(component) && component.length ) {
|
if (Array.isArray(component) && component.length ) {
|
||||||
@ -152,6 +170,7 @@ class Logger {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (performance.now() > this.stopTime) {
|
if (performance.now() > this.stopTime) {
|
||||||
|
this.conf.allowLogging = false;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (Array.isArray(component) && component.length) {
|
if (Array.isArray(component) && component.length) {
|
||||||
|
Loading…
Reference in New Issue
Block a user