Add onLogEnd callback to logger
This commit is contained in:
parent
78ff7d7e40
commit
97d97e022b
@ -3,10 +3,17 @@ import currentBrowser from '../conf/BrowserDetect';
|
|||||||
|
|
||||||
class Logger {
|
class Logger {
|
||||||
constructor(conf) {
|
constructor(conf) {
|
||||||
|
this.onLogEndCallbacks = [];
|
||||||
|
this.history = [];
|
||||||
|
this.globalHistory = {};
|
||||||
|
this.isContentScript = false;
|
||||||
|
this.isBackgroundScript = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static saveConfig(conf) {
|
static saveConfig(conf) {
|
||||||
|
if (process.env.CHANNEL === 'dev') {
|
||||||
console.info('Saving logger conf:', conf)
|
console.info('Saving logger conf:', conf)
|
||||||
|
}
|
||||||
|
|
||||||
if (currentBrowser.firefox || currentBrowser.edge) {
|
if (currentBrowser.firefox || currentBrowser.edge) {
|
||||||
return browser.storage.local.set( {'uwLogger': JSON.stringify(conf)});
|
return browser.storage.local.set( {'uwLogger': JSON.stringify(conf)});
|
||||||
@ -20,7 +27,9 @@ class Logger {
|
|||||||
br.storage.onChanged.addListener( (changes, area) => {
|
br.storage.onChanged.addListener( (changes, area) => {
|
||||||
if (changes.uwLogger) {
|
if (changes.uwLogger) {
|
||||||
const newLoggerConf = JSON.parse(changes.uwLogger.newValue)
|
const newLoggerConf = JSON.parse(changes.uwLogger.newValue)
|
||||||
|
if (process.env.CHANNEL === 'dev') {
|
||||||
console.info('Logger settings reloaded. New conf:', conf);
|
console.info('Logger settings reloaded. New conf:', conf);
|
||||||
|
}
|
||||||
callback(newLoggerConf);
|
callback(newLoggerConf);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -57,6 +66,14 @@ class Logger {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async init(conf) {
|
async init(conf) {
|
||||||
|
// this is the only property that always gets passed via conf
|
||||||
|
// and doesn't get ignored even if the rest of the conf gets
|
||||||
|
// loaded from browser storage
|
||||||
|
if (conf.isContentScript) {
|
||||||
|
this.isContentScript = true;
|
||||||
|
this.isBackgroundScript = false;
|
||||||
|
}
|
||||||
|
|
||||||
if (conf && process.env.CHANNEL === 'dev' && !conf.useConfFromStorage) {
|
if (conf && process.env.CHANNEL === 'dev' && !conf.useConfFromStorage) {
|
||||||
this.conf = conf;
|
this.conf = conf;
|
||||||
} else {
|
} else {
|
||||||
@ -68,12 +85,7 @@ class Logger {
|
|||||||
if (this.conf.fileOptions === undefined) {
|
if (this.conf.fileOptions === undefined) {
|
||||||
this.conf.fileOptions = {};
|
this.conf.fileOptions = {};
|
||||||
}
|
}
|
||||||
// this is the only property that always gets passed via conf
|
|
||||||
// and doesn't get ignored even if the rest of the conf gets
|
|
||||||
// loaded from browser storage
|
|
||||||
this.isBackgroundPage = !!conf.isBackgroundPage;
|
|
||||||
this.history = [];
|
|
||||||
this.globalHistory = {};
|
|
||||||
this.startTime = performance.now();
|
this.startTime = performance.now();
|
||||||
this.temp_disable = false;
|
this.temp_disable = false;
|
||||||
this.stopTime = this.conf.timeout ? performance.now() + (this.conf.timeout * 1000) : undefined;
|
this.stopTime = this.conf.timeout ? performance.now() + (this.conf.timeout * 1000) : undefined;
|
||||||
@ -82,7 +94,7 @@ class Logger {
|
|||||||
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) {
|
if (process.env.CHANNEL === 'dev') {
|
||||||
console.log("[Logger::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area);
|
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) {
|
if (changes['uwLogger'] && changes['uwLogger'].newValue) {
|
||||||
console.log("[Logger::<storage/on change>] new settings object:", JSON.parse(changes.uwLogger.newValue));
|
console.log("[Logger::<storage/on change>] new settings object:", JSON.parse(changes.uwLogger.newValue));
|
||||||
@ -92,7 +104,6 @@ class Logger {
|
|||||||
ths.conf = JSON.parse(changes.uwLogger.newValue);
|
ths.conf = JSON.parse(changes.uwLogger.newValue);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
clear() {
|
clear() {
|
||||||
@ -150,6 +161,28 @@ class Logger {
|
|||||||
this.temp_disable = false;
|
this.temp_disable = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onLogEnd(callback) {
|
||||||
|
this.onLogEndCallbacks.push(callback);
|
||||||
|
}
|
||||||
|
|
||||||
|
// this should be used mostly in background page instance of logger, btw
|
||||||
|
addToGlobalHistory(key, log) {
|
||||||
|
this.globalHistory[key] = log;
|
||||||
|
}
|
||||||
|
|
||||||
|
finish() {
|
||||||
|
this.allowLogging = false;
|
||||||
|
if (!this.isBackgroundScript) {
|
||||||
|
const logJson = JSON.stringify(this.history);
|
||||||
|
for(const f of this.onLogEndCallbacks) {
|
||||||
|
f(logJson);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.globalHistory['uw-bg'] = this.history;
|
||||||
|
return this.globalHistory;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
parseStack() {
|
parseStack() {
|
||||||
const trace = (new Error()).stack;
|
const trace = (new Error()).stack;
|
||||||
|
|
||||||
@ -213,7 +246,7 @@ class Logger {
|
|||||||
if (this.stopTime && performance.now() > this.stopTime) {
|
if (this.stopTime && performance.now() > this.stopTime) {
|
||||||
if (this.conf.allowLogging) {
|
if (this.conf.allowLogging) {
|
||||||
this.log('force', 'debug', '-----[ alloted time has run out. logging will stop ]-----');
|
this.log('force', 'debug', '-----[ alloted time has run out. logging will stop ]-----');
|
||||||
this.conf.allowLogging = false;
|
this.finish();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user