Move everything to logger, but for real

This commit is contained in:
Tamius Han 2019-09-03 22:17:10 +02:00
parent 0f14d9c7dd
commit 3c1b5f4b1a
2 changed files with 53 additions and 126 deletions

View File

@ -28,11 +28,9 @@ class Settings {
if(currentBrowser.firefox) { if(currentBrowser.firefox) {
browser.storage.onChanged.addListener( (changes, area) => { browser.storage.onChanged.addListener( (changes, area) => {
if (Debug.debug && Debug.debugStorage) { this.logger.log('info', 'Settings', "[Settings::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area);
console.log("[Settings::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area); if (changes['uwSettings'] && changes['uwSettings'].newValue) {
if (changes['uwSettings'] && changes['uwSettings'].newValue) { this.logger.log('info', 'Settings',"[Settings::<storage/on change>] new settings object:", JSON.parse(changes.uwSettings.newValue));
console.log("[Settings::<storage/on change>] new settings object:", JSON.parse(changes.uwSettings.newValue));
}
} }
if(changes['uwSettings'] && changes['uwSettings'].newValue) { if(changes['uwSettings'] && changes['uwSettings'].newValue) {
ths.setActive(JSON.parse(changes.uwSettings.newValue)); ths.setActive(JSON.parse(changes.uwSettings.newValue));
@ -42,17 +40,15 @@ class Settings {
try { try {
updateCallback(ths); updateCallback(ths);
} catch (e) { } catch (e) {
console.log("[Settings] CALLING UPDATE CALLBACK FAILED.") this.logger.log('error', 'Settings', "[Settings] CALLING UPDATE CALLBACK FAILED.")
} }
} }
}); });
} else if (currentBrowser.chrome) { } else if (currentBrowser.chrome) {
chrome.storage.onChanged.addListener( (changes, area) => { chrome.storage.onChanged.addListener( (changes, area) => {
if (Debug.debug && Debug.debugStorage) { this.logger.log('info', 'Settings', "[Settings::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area);
console.log("[Settings::<storage/on change>] Settings have been changed outside of here. Updating active settings. Changes:", changes, "storage area:", area); if (changes['uwSettings'] && changes['uwSettings'].newValue) {
if (changes['uwSettings'] && changes['uwSettings'].newValue) { this.logger.log('info', 'Settings',"[Settings::<storage/on change>] new settings object:", JSON.parse(changes.uwSettings.newValue));
console.log("[Settings::<storage/on change>] new settings object:", JSON.parse(changes.uwSettings.newValue));
}
} }
if(changes['uwSettings'] && changes['uwSettings'].newValue) { if(changes['uwSettings'] && changes['uwSettings'].newValue) {
ths.setActive(JSON.parse(changes.uwSettings.newValue)); ths.setActive(JSON.parse(changes.uwSettings.newValue));
@ -62,7 +58,7 @@ class Settings {
try { try {
updateCallback(ths); updateCallback(ths);
} catch (e) { } catch (e) {
console.log("[Settings] CALLING UPDATE CALLBACK FAILED.") this.logger.log('error', 'Settings',"[Settings] CALLING UPDATE CALLBACK FAILED.")
} }
} }
}); });
@ -133,13 +129,13 @@ class Settings {
const currentVersion = this.getExtensionVersion(); const currentVersion = this.getExtensionVersion();
if(Debug.debug) { if(Debug.debug) {
console.log("[Settings::init] Configuration fetched from storage:", settings, this.logger.log('info', 'Settings', "[Settings::init] Configuration fetched from storage:", settings,
"\nlast saved with:", settings.version, "\nlast saved with:", settings.version,
"\ncurrent version:", currentVersion "\ncurrent version:", currentVersion
); );
if (Debug.flushStoredSettings) { if (Debug.flushStoredSettings) {
console.log("%c[Settings::init] Debug.flushStoredSettings is true. Using default settings", "background: #d00; color: #ffd"); this.logger.log('info', 'Settings', "%c[Settings::init] Debug.flushStoredSettings is true. Using default settings", "background: #d00; color: #ffd");
Debug.flushStoredSettings = false; // don't do it again this session Debug.flushStoredSettings = false; // don't do it again this session
this.active = this.getDefaultSettings(); this.active = this.getDefaultSettings();
this.active.version = currentVersion; this.active.version = currentVersion;
@ -175,18 +171,14 @@ class Settings {
if (oldVersion == currentVersion) { if (oldVersion == currentVersion) {
if(Debug.debug) { this.logger.log('info', 'Settings', "[Settings::init] extension was saved with current version of ultrawidify. Returning object as-is.");
console.log("[Settings::init] extension was saved with current version of ultrawidify. Returning object as-is.");
}
return this.active; return this.active;
} }
// if extension has been updated, update existing settings with any options added in the // if extension has been updated, update existing settings with any options added in the
// new version. In addition to that, we remove old keys that are no longer used. // new version. In addition to that, we remove old keys that are no longer used.
const patched = ObjectCopy.addNew(settings, this.default); const patched = ObjectCopy.addNew(settings, this.default);
if(Debug.debug) { this.logger.log('info', 'Settings',"[Settings.init] Results from ObjectCopy.addNew()?", patched, "\n\nSettings from storage", settings, "\ndefault?", this.default);
console.log("[Settings.init] Results from ObjectCopy.addNew()?", patched, "\n\nSettings from storage", settings, "\ndefault?", this.default,);
}
if(patched){ if(patched){
this.active = patched; this.active = patched;
@ -221,13 +213,7 @@ class Settings {
}); });
} }
if (Debug.debug && Debug.debugStorage) { this.logger.log('info', 'Settings', 'Got settings:', ret && ret.uwSettings && JSON.parse(ret.uwSettings));
try {
console.log("[Settings::get] Got settings:", JSON.parse(ret.uwSettings));
} catch (e) {
console.log("[Settings::get] No settings.")
}
}
try { try {
return JSON.parse(ret.uwSettings); return JSON.parse(ret.uwSettings);
@ -237,9 +223,7 @@ class Settings {
} }
async set(extensionConf) { async set(extensionConf) {
if (Debug.debug && Debug.debugStorage) { this.logger.log('info', 'Settings', "[Settings::set] setting new settings:", extensionConf)
console.log("[Settings::set] setting new settings:", extensionConf)
}
if (currentBrowser.firefox || currentBrowser.edge) { if (currentBrowser.firefox || currentBrowser.edge) {
extensionConf.version = this.version; extensionConf.version = this.version;
@ -315,10 +299,7 @@ class Settings {
site = window.location.hostname; site = window.location.hostname;
if (!site) { if (!site) {
if (Debug.debug) { this.logger.log('info', 'Settings', `[Settings::canStartExtension] window.location.hostname is null or undefined: ${window.location.hostname} \nactive settings:`, this.active);
console.log("[Settings::canStartExtension] window.location.hostname is null or undefined:", window.location.hostname)
console.log("active settings:", this.active)
}
return ExtensionMode.Disabled; return ExtensionMode.Disabled;
} }
} }
@ -340,9 +321,8 @@ class Settings {
} }
} catch(e){ } catch(e){
if(Debug.debug){ this.logger.log('error', 'Settings', "[Settings.js::canStartExtension] Something went wrong — are settings defined/has init() been called?\n\nerror:", e, "\n\nSettings object:", this)
console.log("[Settings.js::canStartExtension] Something went wrong — are settings defined/has init() been called?\n\nerror:", e, "\n\nSettings object:", this)
}
return ExtensionMode.Disabled; return ExtensionMode.Disabled;
} }
} }
@ -353,8 +333,7 @@ class Settings {
site = window.location.hostname; site = window.location.hostname;
if (!site) { if (!site) {
console.log("[Settings::canStartExtension] window.location.hostname is null or undefined:", window.location.hostname) this.logger.log('info', 'Settings', `[Settings::canStartExtension] window.location.hostname is null or undefined: ${window.location.hostname} \nactive settings:`, this.active);
console.log("active settings:", this.active)
return false; return false;
} }
} }
@ -380,10 +359,8 @@ class Settings {
} else { } else {
return false; return false;
} }
} catch(e){ } catch(e) {
if(Debug.debug){ this.logger.log('error', 'Settings', "[Settings.js::canStartExtension] Something went wrong — are settings defined/has init() been called?\nSettings object:", this);
console.log("[Settings.js::canStartExtension] Something went wrong — are settings defined/has init() been called?\nSettings object:", this)
}
return false; return false;
} }
} }
@ -405,9 +382,7 @@ class Settings {
return this.active.sites[site].keyboardShortcutsEnabled === ExtensionMode.Enabled; return this.active.sites[site].keyboardShortcutsEnabled === ExtensionMode.Enabled;
} }
} catch (e) { } catch (e) {
if (Debug.debug) { this.logger.log('info', 'Settings',"[Settings.js::keyboardDisabled] something went wrong:", e);
console.error("[Settings.js::keyboardDisabled] something went wrong:", e);
}
return false; return false;
} }
} }
@ -438,12 +413,12 @@ class Settings {
const csar = this.canStartAutoAr(site); const csar = this.canStartAutoAr(site);
Debug.debug = true; Debug.debug = true;
console.log("[Settings::canStartAutoAr] ----------------\nCAN WE START AUTOAR ON SITE", site, this.logger.log('info', 'Settings', "[Settings::canStartAutoAr] ----------------\nCAN WE START AUTOAR ON SITE", site,
"?\n\nsettings.active.sites[site]=", this.active.sites[site], "settings.active.sites[@global]=", this.active.sites['@global'], "?\n\nsettings.active.sites[site]=", this.active.sites[site], "settings.active.sites[@global]=", this.active.sites['@global'],
"\nAutoar mode (global)?", this.active.sites['@global'].autoar, "\nAutoar mode (global)?", this.active.sites['@global'].autoar,
`\nAutoar mode (${site})`, this.active.sites[site] ? this.active.sites[site].autoar : '<not defined>', `\nAutoar mode (${site})`, this.active.sites[site] ? this.active.sites[site].autoar : '<not defined>',
"\nCan autoar be started?", csar "\nCan autoar be started?", csar
); );
} }
// if site is not defined, we use default mode: // if site is not defined, we use default mode:
@ -454,10 +429,10 @@ class Settings {
if (this.active.sites['@global'].autoar === ExtensionMode.Enabled) { if (this.active.sites['@global'].autoar === ExtensionMode.Enabled) {
return this.active.sites[site].autoar !== ExtensionMode.Disabled; return this.active.sites[site].autoar !== ExtensionMode.Disabled;
} else if (this.active.sites['@global'].autoar === ExtensionMode.Whitelist) { } else if (this.active.sites['@global'].autoar === ExtensionMode.Whitelist) {
console.log("canStartAutoAr — can(not) start csar because extension is in whitelist mode, and this site is (not) equal to", ExtensionMode.Enabled) this.logger.log('info', 'Settings', "canStartAutoAr — can(not) start csar because extension is in whitelist mode, and this site is (not) equal to", ExtensionMode.Enabled)
return this.active.sites[site].autoar === ExtensionMode.Enabled; return this.active.sites[site].autoar === ExtensionMode.Enabled;
} else { } else {
console.log("canStartAutoAr — cannot start csar because extension is globally disabled") this.logger.log('info', 'Settings', "canStartAutoAr — cannot start csar because extension is globally disabled")
return false; return false;
} }
} }

View File

@ -4,13 +4,12 @@ import BrowserDetect from '../../conf/BrowserDetect';
class CommsServer { class CommsServer {
constructor(server) { constructor(server) {
this.server = server; this.server = server;
this.logger = server.logger;
this.settings = server.settings; this.settings = server.settings;
this.ports = []; this.ports = [];
var ths = this; var ths = this;
// console.log("[CommsServer::ctor] INIT! are we in ff?", BrowserDetect.firefox, "BrowserDetect says ...", BrowserDetect)
if (BrowserDetect.firefox) { if (BrowserDetect.firefox) {
browser.runtime.onConnect.addListener(p => ths.onConnect(p)); browser.runtime.onConnect.addListener(p => ths.onConnect(p));
browser.runtime.onMessage.addListener((m, sender) => ths.processReceivedMessage_nonpersistent(m, sender)); browser.runtime.onMessage.addListener((m, sender) => ths.processReceivedMessage_nonpersistent(m, sender));
@ -20,20 +19,8 @@ class CommsServer {
} }
} }
async toObject(obj) {
// console.log("(not actually) CLONING OBJECT", obj);
// try {
// const r = JSON.parse(JSON.stringify(obj));
// return r;
// } catch (e) {
// console.log("ERROR WHILE CLONING", obj);
return obj;
// }
}
async getCurrentTabHostname() { async getCurrentTabHostname() {
const activeTab = await this._getActiveTab(); const activeTab = await this._getActiveTab();
const url = activeTab[0].url; const url = activeTab[0].url;
var hostname; var hostname;
@ -52,7 +39,6 @@ class CommsServer {
} }
sendToAll(message){ sendToAll(message){
message = JSON.parse(JSON.stringify(message)); // vue quirk. We should really use vue store instead
for(var p of this.ports){ for(var p of this.ports){
for(var frame in p){ for(var frame in p){
p[frame].postMessage(message); p[frame].postMessage(message);
@ -74,10 +60,7 @@ class CommsServer {
} }
async sendToFrame(message, tab, frame) { async sendToFrame(message, tab, frame) {
// message = JSON.parse(JSON.stringify(message)); // vue quirk. We should really use vue store instead this.logger.log('info', 'CommsServer', `%c[CommsServer::sendToFrame] attempting to send message to tab ${tab}, frame ${frame}`, "background: #dda; color: #11D", message);
if(Debug.debug && Debug.comms){
console.log(`%c[CommsServer::sendToFrame] attempting to send message to tab ${tab}, frame ${frame}`, "background: #dda; color: #11D", message);
}
if (isNaN(tab)) { if (isNaN(tab)) {
if (tab === '__playing') { if (tab === '__playing') {
@ -91,33 +74,23 @@ class CommsServer {
[tab, frame] = tab.split('-') [tab, frame] = tab.split('-')
} }
if(Debug.debug && Debug.comms){ this.logger.log('info', 'CommsServer', `%c[CommsServer::sendToFrame] attempting to send message to tab ${tab}, frame ${frame}`, "background: #dda; color: #11D", message);
console.log(`%c[CommsServer::sendToFrame] attempting to send message to tab ${tab}, frame ${frame}`, "background: #dda; color: #11D", message);
}
try { try {
this.ports[tab][frame].postMessage(message); this.ports[tab][frame].postMessage(message);
} catch (e) { } catch (e) {
if(Debug.debug && Debug.comms){ this.logger.log('error', 'CommsServer', `%c[CommsServer::sendToFrame] Sending message failed. Reason:`, "background: #dda; color: #11D", e);
console.log(`%c[CommsServer::sendToFrame] Sending message failed. Reason:`, "background: #dda; color: #11D", e);
}
} }
} }
async sendToActive(message) { async sendToActive(message) {
message = JSON.parse(JSON.stringify(message)); // vue quirk. We should really use vue store instead this.logger.log('info', 'CommsServer', "%c[CommsServer::sendToActive] trying to send a message to active tab. Message:", "background: #dda; color: #11D", message);
if(Debug.debug && Debug.comms){
console.log("%c[CommsServer::sendToActive] trying to send a message to active tab. Message:", "background: #dda; color: #11D", message);
}
var tabs = await this._getActiveTab(); var tabs = await this._getActiveTab();
if(Debug.debug && Debug.comms){ this.logger.log('info', 'CommsServer', "[CommsServer::_sendToActive] currently active tab(s)?", tabs);
console.log("[CommsServer::_sendToActive] currently active tab(s)?", tabs); for (var key in this.ports[tabs[0].id]) {
for (var key in this.ports[tabs[0].id]) { this.logger.log('info', 'CommsServer', "key?", key, this.ports[tabs[0].id]);
console.log("key?", key, this.ports[tabs[0].id]);
}
} }
for (var key in this.ports[tabs[0].id]) { for (var key in this.ports[tabs[0].id]) {
@ -151,27 +124,19 @@ class CommsServer {
} }
async processReceivedMessage(message, port){ async processReceivedMessage(message, port){
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "[CommsServer.js::processReceivedMessage] Received message from popup/content script!", message, "port", port, "\nsettings and server:", this.settings,this.server);
console.log("[CommsServer.js::processReceivedMessage] Received message from popup/content script!", message, "port", port, "\nsettings and server:", this.settings,this.server);
}
if (message.forwardToContentScript) { if (message.forwardToContentScript) {
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "[CommsServer.js::processReceivedMessage] Message has 'forward to content script' flag set. Forwarding message as is. Message:", message);
console.log("[CommsServer.js::processReceivedMessage] Message has 'forward to content script' flag set. Forwarding message as is. Message:", message);
}
this.sendToFrame(message, message.targetTab, message.targetFrame); this.sendToFrame(message, message.targetTab, message.targetFrame);
} }
if (message.forwardToAll) { if (message.forwardToAll) {
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "[CommsServer.js::processReceivedMessage] Message has 'forward to all' flag set. Forwarding message as is. Message:", message);
console.log("[CommsServer.js::processReceivedMessage] Message has 'forward to all' flag set. Forwarding message as is. Message:", message);
}
this.sendToAll(message); this.sendToAll(message);
} }
if (message.forwardToActive) { if (message.forwardToActive) {
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "[CommsServer.js::processReceivedMessage] Message has 'forward to active' flag set. Forwarding message as is. Message:", message);
console.log("[CommsServer.js::processReceivedMessage] Message has 'forward to active' flag set. Forwarding message as is. Message:", message);
}
this.sendToActive(message) this.sendToActive(message)
} }
@ -198,9 +163,7 @@ class CommsServer {
} }
if (message.cmd === 'get-config') { if (message.cmd === 'get-config') {
if(Debug.debug) { this.logger.log('info', 'CommsServer', "CommsServer: received get-config. Active settings?", this.settings.active, "\n(settings:", this.settings, ")");
console.log("CommsServer: received get-config. Active settings?", this.settings.active, "\n(settings:", this.settings, ")")
}
port.postMessage( port.postMessage(
{cmd: "set-config", conf: this.settings.active, site: this.server.currentSite} {cmd: "set-config", conf: this.settings.active, site: this.server.currentSite}
); );
@ -212,9 +175,7 @@ class CommsServer {
} }
processReceivedMessage_nonpersistent(message, sender, sendResponse){ processReceivedMessage_nonpersistent(message, sender, sendResponse){
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "%c[CommsServer.js::processMessage_nonpersistent] Received message from background script!", "background-color: #11D; color: #aad", message, sender);
console.log("%c[CommsServer.js::processMessage_nonpersistent] Received message from background script!", "background-color: #11D; color: #aad", message, sender);
}
if (message.cmd === 'inject-css') { if (message.cmd === 'inject-css') {
this.server.injectCss(message.cssString, sender); this.server.injectCss(message.cssString, sender);
@ -229,10 +190,8 @@ class CommsServer {
} }
if (message.forwardToContentScript) { if (message.forwardToContentScript) {
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "[CommsServer.js::processMessage_nonpersistent] Message has 'forward to content script' flag set. Forwarding message as is. Message:", message);
console.log("[CommsServer.js::processMessage_nonpersistent] Message has 'forward to content script' flag set. Forwarding message as is. Message:", message); this.logger.log('info', 'CommsServer', "[CommsServer.js::processMessage_nonpersistent] (btw we probably shouldn't be seeing this. This should prolly happen in persistent connection?");
console.log("[CommsServer.js::processMessage_nonpersistent] (btw we probably shouldn't be seeing this. This should prolly happen in persistent connection?");
}
this.sendToFrame(message, message.targetFrame); this.sendToFrame(message, message.targetFrame);
} }
@ -240,9 +199,7 @@ class CommsServer {
if (message.cmd === 'get-config') { if (message.cmd === 'get-config') {
if (BrowserDetect.firefox) { if (BrowserDetect.firefox) {
var ret = {extensionConf: JSON.stringify(this.settings.active)}; var ret = {extensionConf: JSON.stringify(this.settings.active)};
if (Debug.debug && Debug.comms) { this.logger.log('info', 'CommsServer', "%c[CommsServer.js::processMessage_nonpersistent] Returning this:", "background-color: #11D; color: #aad", ret);
console.log("%c[CommsServer.js::processMessage_nonpersistent] Returning this:", "background-color: #11D; color: #aad", ret);
}
Promise.resolve(ret); Promise.resolve(ret);
} else { } else {
sendResponse({extensionConf: JSON.stringify(this.settings.active)}); sendResponse({extensionConf: JSON.stringify(this.settings.active)});
@ -252,9 +209,7 @@ class CommsServer {
this.settings.active.sites['@global'].autoar = "blacklist"; this.settings.active.sites['@global'].autoar = "blacklist";
this.settings.save(); this.settings.save();
this.sendToAll({cmd: "reload-settings", sender: "uwbg"}) this.sendToAll({cmd: "reload-settings", sender: "uwbg"})
if(Debug.debug){ this.logger.log('info', 'CommsServer', "[uw-bg] autoar set to enabled (blacklist). evidenz:", this.settings.active);
console.log("[uw-bg] autoar set to enabled (blacklist). evidenz:", this.settings.active);
}
} else if (message.cmd === "autoar-disable") { } else if (message.cmd === "autoar-disable") {
this.settings.active.sites['@global'].autoar = "disabled"; this.settings.active.sites['@global'].autoar = "disabled";
if(message.reason){ if(message.reason){
@ -264,13 +219,10 @@ class CommsServer {
} }
this.settings.save(); this.settings.save();
this.sendToAll({cmd: 'reload-settings', newConf: this.settings.active}); this.sendToAll({cmd: 'reload-settings', newConf: this.settings.active});
if(Debug.debug){ this.logger.log('info', 'CommsServer', "[uw-bg] autoar set to disabled. evidenz:", this.settings.active);
console.log("[uw-bg] autoar set to disabled. evidenz:", this.settings.active);
}
} else if (message.cmd === "autoar-set-interval") { } else if (message.cmd === "autoar-set-interval") {
if (Debug.debug) { this.logger.log('info', 'CommsServer', `[uw-bg] trying to set new interval for autoAr. New interval is, ${message.timeout} ms`);
console.log("[uw-bg] trying to set new interval for autoAr. New interval is",message.timeout,"ms");
}
// set fairly liberal limit // set fairly liberal limit
var timeout = message.timeout < 4 ? 4 : message.timeout; var timeout = message.timeout < 4 ? 4 : message.timeout;
this.settings.active.arDetect.timer_playing = timeout; this.settings.active.arDetect.timer_playing = timeout;