ultrawidify/src/ext/lib/Settings.js

385 lines
12 KiB
JavaScript
Raw Normal View History

import Debug from '../conf/Debug';
import currentBrowser from '../conf/BrowserDetect';
import ExtensionConf from '../conf/ExtensionConf';
import ExtensionMode from '../../common/enums/extension-mode';
import ObjectCopy from '../lib/ObjectCopy';
class Settings {
constructor(activeSettings, updateCallback) {
2018-08-22 22:34:07 +02:00
this.active = activeSettings ? activeSettings : undefined;
this.default = ExtensionConf;
2018-08-21 23:48:47 +02:00
this.useSync = false;
2018-08-22 22:34:07 +02:00
this.version = undefined;
this.updateCallback = updateCallback;
console.log("chrome object:", chrome)
console.log("browser.storage", browser.storage)
console.log("browser object:", browser)
console.log("window.browser", window.browser)
console.log("ExtensionConf", ExtensionConf)
const ths = this;
if(currentBrowser.firefox) {
browser.storage.onChanged.addListener( (changes, area) => {
if (Debug.debug && Debug.debugStorage) {
2018-08-29 00:41:26 +02:00
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) {
console.log("[Settings::<storage/on change>] new settings object:", JSON.parse(changes.uwSettings.newValue));
}
}
if(changes['uwSettings'] && changes['uwSettings'].newValue) {
ths.setActive(JSON.parse(changes.uwSettings.newValue));
}
if(this.updateCallback) {
try {
updateCallback(ths);
} catch (e) {
console.log("[Settings] CALLING UPDATE CALLBACK FAILED.")
}
}
});
} else if (currentBrowser.chrome) {
2018-08-29 00:41:26 +02:00
chrome.storage.onChanged.addListener( (changes, area) => {
if (Debug.debug && Debug.debugStorage) {
2018-08-29 00:41:26 +02:00
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) {
console.log("[Settings::<storage/on change>] new settings object:", JSON.parse(changes.uwSettings.newValue));
}
}
if(changes['uwSettings'] && changes['uwSettings'].newValue) {
ths.setActive(JSON.parse(changes.uwSettings.newValue));
2018-08-29 00:41:26 +02:00
}
if(this.updateCallback) {
try {
updateCallback(ths);
} catch (e) {
console.log("[Settings] CALLING UPDATE CALLBACK FAILED.")
}
}
});
}
}
async init() {
2018-08-21 23:48:47 +02:00
const settings = await this.get();
if(Debug.debug) {
2018-08-21 23:48:47 +02:00
console.log("[Settings::init] Configuration fetched from storage:", settings);
if (Debug.flushStoredSettings) {
console.log("%c[Settings::init] Debug.flushStoredSettings is true. Using default settings", "background: #d00; color: #ffd");
Debug.flushStoredSettings = false; // don't do it again this session
this.setDefaultSettings();
this.active = this.getDefaultSettings();
return this.active;
}
}
// if there's no settings saved, return default settings.
2018-08-07 23:31:28 +02:00
if(! settings || (Object.keys(settings).length === 0 && settings.constructor === Object)) {
this.setDefaultSettings();
this.active = this.getDefaultSettings();
return this.active;
}
// if there's settings, set saved object as active settings
this.active = settings;
// check if extension has been updated. If not, return settings as they were retreived
if (currentBrowser.firefox) {
2018-08-22 22:34:07 +02:00
this.version = browser.runtime.getManifest().version;
} else if (currentBrowser.chrome) {
2018-08-22 22:34:07 +02:00
this.version = chrome.runtime.getManifest().version;
} else if (currentBrowser.edge) {
2018-08-22 22:34:07 +02:00
this.version = browser.runtime.getManifest().version;
2018-08-07 23:31:28 +02:00
}
2018-08-22 22:34:07 +02:00
if(settings.version === this.version) {
if(Debug.debug) {
2018-08-22 22:34:07 +02:00
console.log("[Settings::init] extension was saved with current version of ultrawidify (", this.version, "). Returning object as-is.");
}
return this.active;
}
// 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.
2018-08-22 22:34:07 +02:00
const patched = ObjectCopy.addNew(settings, this.default);
if(Debug.debug) {
console.log("[Settings.init] Results from ObjectCopy.addNew()?", patched, "\n\nSettings from storage", settings, "\ndefault?", this.default,);
}
if(patched){
this.active = patched;
} else {
this.active = JSON.parse(JSON.stringify(this.default));
}
this.set(this.active);
return this.active;
}
async get() {
if (currentBrowser.firefox) {
2018-09-25 23:37:08 +02:00
const ret = await browser.storage.local.get('uwSettings');
2018-08-21 23:48:47 +02:00
try {
2018-08-22 22:34:07 +02:00
return JSON.parse(ret.uwSettings);
2018-08-21 23:48:47 +02:00
} catch(e) {
return undefined;
}
} else if (currentBrowser.chrome) {
2018-08-29 00:41:26 +02:00
const ret = new Promise( (resolve, reject) => {
chrome.storage.sync.get('uwSettings', (res) => resolve(res));
});
2018-08-22 22:34:07 +02:00
return ret['uwSettings'];
} else if (currentBrowser.edge) {
2018-09-25 23:37:08 +02:00
const ret = new Promise( (resolve, reject) => {
browser.storage.sync.get('uwSettings', (res) => resolve(res));
});
return ret['uwSettings'];
}
}
async set(extensionConf) {
if (Debug.debug) {
console.log("[Settings::set] setting new settings:", extensionConf)
}
if (currentBrowser.firefox || currentBrowser.edge) {
2018-08-22 22:34:07 +02:00
extensionConf.version = this.version;
return this.useSync ? browser.storage.sync.set( {'uwSettings': JSON.stringify(extensionConf)}): browser.storage.local.set( {'uwSettings': JSON.stringify(extensionConf)});
} else if (currentBrowser.chrome) {
2018-08-29 00:41:26 +02:00
return chrome.storage.sync.set( {'uwSettings': JSON.stringify(extensionConf)});
}
}
2018-08-07 23:31:28 +02:00
async setActive(activeSettings) {
this.active = activeSettings;
}
async setProp(prop, value) {
this.active[prop] = value;
}
async save() {
if (Debug.debug) {
console.log("[Settings::save] Saving active settings:", this.active);
}
2018-08-07 23:31:28 +02:00
this.set(this.active);
}
getDefaultSettings() {
return JSON.parse(JSON.stringify(this.default));
}
setDefaultSettings() {
this.set(this.default);
}
// -----------------------------------------
// Nastavitve za posamezno stran
// Config for a given page:
//
// <hostname> : {
// status: <option> // should extension work on this site?
// arStatus: <option> // should we do autodetection on this site?
// statusEmbedded: <option> // reserved for future... maybe
// }
//
// Veljavne vrednosti za možnosti
// Valid values for options:
//
// status, arStatus, statusEmbedded:
//
// * enabled — always allow
2018-11-02 02:52:01 +01:00
// * basic — only allow fullscreen
// * default — allow if default is to allow, block if default is to block
// * disabled — never allow
getSiteSettings(site) {
if (!site) {
site = window.location.hostname;
}
if (!site || !this.active.sites[site]) {
return {};
}
return this.active.sites[site];
}
getActionsForSite(site) {
if (!site) {
return this.active.actions;
}
if (this.active.sites[site] && this.active.sites[site].actions && this.active.sites[site].actions.length > 0) {
return this.active.sites[site].actions;
}
return this.active.actions;
}
2018-11-02 02:52:01 +01:00
getExtensionMode(site) {
if (!site) {
site = window.location.hostname;
if (!site) {
console.log("[Settings::canStartExtension] window.location.hostname is null or undefined:", window.location.hostname)
console.log("active settings:", this.active)
return ExtensionMode.Disabled;
}
}
try {
// if site-specific settings don't exist for the site, we use default mode:
if (! this.active.sites[site]) {
2019-01-20 22:59:06 +01:00
if (this.active.sites['@global'] === "blacklist") {
return ExtensionMode.Enabled;
2018-11-02 02:52:01 +01:00
} else {
return this.active.basicExtensionMode === "blacklist" ? ExtensionMode.Basic : ExtensionMode.Disabled;
}
}
if (this.active.sites[site].status === 'enabled') {
2019-01-20 22:59:06 +01:00
return ExtensionMode.Enabled;
2018-11-02 02:52:01 +01:00
} else if (this.active.sites[site].status === 'basic') {
return ExtensionMode.Basic;
} else if (this.active.sites[site].status === 'default') {
2019-01-20 22:59:06 +01:00
if (this.active.sites['@global'] === "blacklist") {
return ExtensionMode.Enabled;
2018-11-02 02:52:01 +01:00
} else {
return this.active.basicExtensionMode === "blacklist" ? ExtensionMode.Basic : ExtensionMode.Disabled;
}
} else {
return ExtensionMode.Disabled;
}
} catch(e){
if(Debug.debug){
console.log("[Settings.js::canStartExtension] Something went wrong — are settings defined/has init() been called?\nSettings object:", this)
}
return ExtensionMode.Disabled;
}
}
canStartExtension(site) {
// returns 'true' if extension can be started on a given site. Returns false if we shouldn't run.
if (!site) {
site = window.location.hostname;
if (!site) {
2018-08-07 23:31:28 +02:00
console.log("[Settings::canStartExtension] window.location.hostname is null or undefined:", window.location.hostname)
console.log("active settings:", this.active)
return false;
}
}
2018-11-02 02:52:01 +01:00
// if (Debug.debug) {
// // let's just temporarily disable debugging while recursively calling
// // this function to get extension status on current site without duplo
// // console logs (and without endless recursion)
// Debug.debug = false;
// const cse = this.canStartExtension(site);
// Debug.debug = true;
// }
2018-08-07 23:31:28 +02:00
try{
// if site is not defined, we use default mode:
if (! this.active.sites[site]) {
2019-01-20 22:59:06 +01:00
return this.active.sites['@global'] === "blacklist";
}
2019-01-20 22:59:06 +01:00
if(this.active.sites['@global'] === "blacklist") {
2018-08-07 23:31:28 +02:00
return this.active.sites[site].status !== "disabled";
2019-01-20 22:59:06 +01:00
} else if (this.active.sites['@global'] === "whitelist") {
2018-08-07 23:31:28 +02:00
return this.active.sites[site].status === "enabled";
} else {
return false;
}
2018-08-22 22:34:07 +02:00
}catch(e){
if(Debug.debug){
console.log("[Settings.js::canStartExtension] Something went wrong — are settings defined/has init() been called?\nSettings object:", this)
}
return false;
}
}
2018-09-16 14:14:16 +02:00
extensionEnabled(){
2019-01-20 22:59:06 +01:00
return this.active.sites['@global'] !== 'disabled'
2018-09-16 14:14:16 +02:00
}
extensionEnabledForSite(site) {
return this.canStartExtension(site);
}
canStartAutoAr(site) {
if (!site) {
site = window.location.hostname;
if (!site) {
return false;
}
}
if (Debug.debug) {
// let's just temporarily disable debugging while recursively calling
// this function to get extension status on current site without duplo
// console logs (and without endless recursion)
Debug.debug = false;
const csar = this.canStartAutoAr(site);
Debug.debug = true;
console.log("[Settings::canStartAutoAr] ----------------\nCAN WE START THIS EXTENSION ON SITE", site,
"?\n\nsettings.active.sites[site]=", this.active.sites[site],
2019-01-20 22:59:06 +01:00
"\nExtension mode?", this.active.site['@global'].autoar,
"\nCan extension be started?", csar
);
}
// if site is not defined, we use default mode:
if (! this.active.sites[site]) {
2019-01-20 22:59:06 +01:00
return this.active.site['@global'].autoar === "blacklist";
}
2019-01-20 22:59:06 +01:00
if (this.active.site['@global'].autoar === "blacklist") {
return this.active.sites[site].arStatus !== "disabled";
2019-01-20 22:59:06 +01:00
} else if (this.active.site['@global'].autoar === "whitelist") {
return this.active.sites[site].arStatus === "enabled";
} else {
return false;
}
}
getDefaultAr(site) {
site = this.getSiteSettings(site);
if (site.defaultAr) {
return site.defaultAr;
}
return this.active.miscSettings.defaultAr;
}
getDefaultStretchMode(site) {
site = this.getSiteSettings(site);
if (site.stretch) {
return site.stretch;
}
2019-01-20 22:59:06 +01:00
return this.active.site['@global'].stretch;
}
getDefaultVideoAlignment(site) {
site = this.getSiteSettings(site);
if (site.videoAlignment) {
return site.videoAlignment;
}
2019-01-20 22:59:06 +01:00
return this.active.site['@global'].videoAlignment;
}
}
export default Settings;