Update 0BDFDB.plugin.js
This commit is contained in:
parent
7090528329
commit
213c0079cf
|
@ -51,20 +51,23 @@ module.exports = (_ => {
|
||||||
load() {
|
load() {
|
||||||
if (window.BDFDB_Global.loading) PluginStores.delayedLoad.push(this);
|
if (window.BDFDB_Global.loading) PluginStores.delayedLoad.push(this);
|
||||||
else {
|
else {
|
||||||
Object.assign(this, BDFDB.ObjectUtils.extract(config, "name", "author", "version", "description", "changeLog", "patchedModules", "rawUrl"));
|
Object.assign(this, config);
|
||||||
|
BDFDB.TimeUtils.suppress(_ => {
|
||||||
BDFDB.PluginUtils.load(this);
|
BDFDB.PluginUtils.load(this);
|
||||||
if (typeof this.onLoad == "function") this.onLoad();
|
if (typeof this.onLoad == "function") this.onLoad();
|
||||||
|
}, "Failed to load plugin!", config.name)();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
start() {
|
start() {
|
||||||
if (window.BDFDB_Global.loading) PluginStores.delayedStart.push(this);
|
if (window.BDFDB_Global.loading) PluginStores.delayedStart.push(this);
|
||||||
else {
|
else {
|
||||||
if (this.started) return;
|
if (this.started) return;
|
||||||
|
this.started = true;
|
||||||
|
BDFDB.TimeUtils.suppress(_ => {
|
||||||
BDFDB.DOMUtils.appendLocalStyle(config.name, BDFDB.DOMUtils.formatCSS(config.css));
|
BDFDB.DOMUtils.appendLocalStyle(config.name, BDFDB.DOMUtils.formatCSS(config.css));
|
||||||
BDFDB.PluginUtils.init(this);
|
BDFDB.PluginUtils.init(this);
|
||||||
if (typeof this.onStart == "function") this.onStart();
|
if (typeof this.onStart == "function") this.onStart();
|
||||||
|
}, "Failed to start plugin!", config.name)();
|
||||||
this.started = true;
|
|
||||||
delete this.stopping;
|
delete this.stopping;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -73,8 +76,10 @@ module.exports = (_ => {
|
||||||
this.stopping = true;
|
this.stopping = true;
|
||||||
BDFDB.TimeUtils.timeout(_ => {delete this.stopping;});
|
BDFDB.TimeUtils.timeout(_ => {delete this.stopping;});
|
||||||
|
|
||||||
|
BDFDB.TimeUtils.suppress(_ => {
|
||||||
if (typeof this.onStop == "function") this.onStop();
|
if (typeof this.onStop == "function") this.onStop();
|
||||||
BDFDB.PluginUtils.clear(this);
|
BDFDB.PluginUtils.clear(this);
|
||||||
|
}, "Failed to stop plugin!", config.name)();
|
||||||
|
|
||||||
delete this.started;
|
delete this.started;
|
||||||
}
|
}
|
||||||
|
@ -249,7 +254,7 @@ module.exports = (_ => {
|
||||||
delete window.BDFDB_Global.loaded;
|
delete window.BDFDB_Global.loaded;
|
||||||
BDFDB.TimeUtils.interval((interval, count) => {
|
BDFDB.TimeUtils.interval((interval, count) => {
|
||||||
if (count > 60 || window.BDFDB_Global.loaded) BDFDB.TimeUtils.clear(interval);
|
if (count > 60 || window.BDFDB_Global.loaded) BDFDB.TimeUtils.clear(interval);
|
||||||
if (window.BDFDB_Global.loaded) for (let pluginName of PluginStores.started) BDFDB.BDUtils.reloadPlugin(pluginName);
|
if (window.BDFDB_Global.loaded) for (let pluginName of [].concat(PluginStores.started).sort()) BDFDB.BDUtils.reloadPlugin(pluginName);
|
||||||
}, 1000);
|
}, 1000);
|
||||||
}
|
}
|
||||||
BDFDB.DOMUtils.removeLocalStyle(plugin.name);
|
BDFDB.DOMUtils.removeLocalStyle(plugin.name);
|
||||||
|
@ -506,8 +511,8 @@ module.exports = (_ => {
|
||||||
}
|
}
|
||||||
}, config, window.BDFDB_Global);
|
}, config, window.BDFDB_Global);
|
||||||
|
|
||||||
require("request").get("https://mwittrien.github.io/BetterDiscordAddons/Library/_res/BDFDB.data.json", (error, response, body) => {
|
require("request").get("https://mwittrien.github.io/BetterDiscordAddons/Library/_res/BDFDB.data.json", BDFDB.TimeUtils.suppress((error, response, body) => {
|
||||||
const InternalData = !error && body ? JSON.parse(body) : {};
|
const InternalData = JSON.parse(body);
|
||||||
|
|
||||||
BDFDB.ObserverUtils = {};
|
BDFDB.ObserverUtils = {};
|
||||||
BDFDB.ObserverUtils.connect = function (plugin, eleOrSelec, observer, config = {childList: true}) {
|
BDFDB.ObserverUtils.connect = function (plugin, eleOrSelec, observer, config = {childList: true}) {
|
||||||
|
@ -1532,9 +1537,9 @@ module.exports = (_ => {
|
||||||
BDFDB.PatchUtils = {};
|
BDFDB.PatchUtils = {};
|
||||||
BDFDB.PatchUtils.isPatched = function (plugin, module, methodName) {
|
BDFDB.PatchUtils.isPatched = function (plugin, module, methodName) {
|
||||||
plugin = plugin == BDFDB && InternalBDFDB || plugin;
|
plugin = plugin == BDFDB && InternalBDFDB || plugin;
|
||||||
if (!plugin || !BDFDB.ObjectUtils.is(module) || !module.BDFDBpatch || !methodName) return false;
|
if (!plugin || !BDFDB.ObjectUtils.is(module) || !module.BDFDB_patches || !methodName) return false;
|
||||||
const pluginId = (typeof plugin === "string" ? plugin : plugin.name).toLowerCase();
|
const pluginId = (typeof plugin === "string" ? plugin : plugin.name).toLowerCase();
|
||||||
return pluginId && module[methodName] && module[methodName].__isBDFDBpatched && module.BDFDBpatch[methodName] && BDFDB.ObjectUtils.toArray(module.BDFDBpatch[methodName]).some(patchObj => BDFDB.ObjectUtils.toArray(patchObj).some(priorityObj => Object.keys(priorityObj).includes(pluginId)));
|
return pluginId && module[methodName] && module[methodName].__is_BDFDB_patched && module.BDFDB_patches[methodName] && BDFDB.ObjectUtils.toArray(module.BDFDB_patches[methodName]).some(patchObj => BDFDB.ObjectUtils.toArray(patchObj).some(priorityObj => Object.keys(priorityObj).includes(pluginId)));
|
||||||
};
|
};
|
||||||
BDFDB.PatchUtils.patch = function (plugin, module, methodNames, patchMethods, config = {}) {
|
BDFDB.PatchUtils.patch = function (plugin, module, methodNames, patchMethods, config = {}) {
|
||||||
plugin = plugin == BDFDB && InternalBDFDB || plugin;
|
plugin = plugin == BDFDB && InternalBDFDB || plugin;
|
||||||
|
@ -1544,18 +1549,18 @@ module.exports = (_ => {
|
||||||
const pluginName = typeof plugin === "string" ? plugin : plugin.name;
|
const pluginName = typeof plugin === "string" ? plugin : plugin.name;
|
||||||
const pluginId = pluginName.toLowerCase();
|
const pluginId = pluginName.toLowerCase();
|
||||||
const patchPriority = BDFDB.ObjectUtils.is(plugin) && !isNaN(plugin.patchPriority) ? (plugin.patchPriority < 0 ? 0 : (plugin.patchPriority > 10 ? 10 : Math.round(plugin.patchPriority))) : 5;
|
const patchPriority = BDFDB.ObjectUtils.is(plugin) && !isNaN(plugin.patchPriority) ? (plugin.patchPriority < 0 ? 0 : (plugin.patchPriority > 10 ? 10 : Math.round(plugin.patchPriority))) : 5;
|
||||||
if (!BDFDB.ObjectUtils.is(module.BDFDBpatch)) module.BDFDBpatch = {};
|
if (!BDFDB.ObjectUtils.is(module.BDFDB_patches)) module.BDFDB_patches = {};
|
||||||
methodNames = [methodNames].flat(10).filter(n => n);
|
methodNames = [methodNames].flat(10).filter(n => n);
|
||||||
let cancel = _ => {BDFDB.PatchUtils.unpatch(plugin, module, methodNames);};
|
let cancel = _ => {BDFDB.PatchUtils.unpatch(plugin, module, methodNames);};
|
||||||
for (let methodName of methodNames) if (module[methodName] == null || typeof module[methodName] == "function") {
|
for (let methodName of methodNames) if (module[methodName] == null || typeof module[methodName] == "function") {
|
||||||
if (!module.BDFDBpatch[methodName] || config.force && (!module[methodName] || !module[methodName].__isBDFDBpatched)) {
|
if (!module.BDFDB_patches[methodName] || config.force && (!module[methodName] || !module[methodName].__is_BDFDB_patched)) {
|
||||||
if (!module.BDFDBpatch[methodName]) {
|
if (!module.BDFDB_patches[methodName]) {
|
||||||
module.BDFDBpatch[methodName] = {};
|
module.BDFDB_patches[methodName] = {};
|
||||||
for (let type of InternalData.ModuleUtilsConfig.PatchTypes) module.BDFDBpatch[methodName][type] = {};
|
for (let type of InternalData.ModuleUtilsConfig.PatchTypes) module.BDFDB_patches[methodName][type] = {};
|
||||||
}
|
}
|
||||||
if (!module[methodName]) module[methodName] = (_ => {});
|
if (!module[methodName]) module[methodName] = (_ => {});
|
||||||
const originalMethod = module[methodName];
|
const originalMethod = module[methodName];
|
||||||
module.BDFDBpatch[methodName].originalMethod = originalMethod;
|
module.BDFDB_patches[methodName].originalMethod = originalMethod;
|
||||||
module[methodName] = function () {
|
module[methodName] = function () {
|
||||||
let callInstead = false, stopCall = false;
|
let callInstead = false, stopCall = false;
|
||||||
const data = {
|
const data = {
|
||||||
|
@ -1567,22 +1572,22 @@ module.exports = (_ => {
|
||||||
callOriginalMethodAfterwards: _ => {callInstead = true;},
|
callOriginalMethodAfterwards: _ => {callInstead = true;},
|
||||||
stopOriginalMethodCall: _ => {stopCall = true;}
|
stopOriginalMethodCall: _ => {stopCall = true;}
|
||||||
};
|
};
|
||||||
if (module.BDFDBpatch && module.BDFDBpatch[methodName]) {
|
if (module.BDFDB_patches && module.BDFDB_patches[methodName]) {
|
||||||
for (let priority in module.BDFDBpatch[methodName].before) for (let id in BDFDB.ObjectUtils.sort(module.BDFDBpatch[methodName].before[priority])) {
|
for (let priority in module.BDFDB_patches[methodName].before) for (let id in BDFDB.ObjectUtils.sort(module.BDFDB_patches[methodName].before[priority])) {
|
||||||
BDFDB.TimeUtils.suppress(module.BDFDBpatch[methodName].before[priority][id], `"before" callback of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`, module.BDFDBpatch[methodName].before[priority][id].pluginName)(data);
|
BDFDB.TimeUtils.suppress(module.BDFDB_patches[methodName].before[priority][id], `"before" callback of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`, module.BDFDB_patches[methodName].before[priority][id].pluginName)(data);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!module.BDFDBpatch || !module.BDFDBpatch[methodName]) return methodName == "render" && data.returnValue === undefined ? null : data.returnValue;
|
if (!module.BDFDB_patches || !module.BDFDB_patches[methodName]) return methodName == "render" && data.returnValue === undefined ? null : data.returnValue;
|
||||||
let hasInsteadPatches = BDFDB.ObjectUtils.toArray(module.BDFDBpatch[methodName].instead).some(priorityObj => !BDFDB.ObjectUtils.isEmpty(priorityObj));
|
let hasInsteadPatches = BDFDB.ObjectUtils.toArray(module.BDFDB_patches[methodName].instead).some(priorityObj => !BDFDB.ObjectUtils.isEmpty(priorityObj));
|
||||||
if (hasInsteadPatches) for (let priority in module.BDFDBpatch[methodName].instead) for (let id in BDFDB.ObjectUtils.sort(module.BDFDBpatch[methodName].instead[priority])) {
|
if (hasInsteadPatches) for (let priority in module.BDFDB_patches[methodName].instead) for (let id in BDFDB.ObjectUtils.sort(module.BDFDB_patches[methodName].instead[priority])) {
|
||||||
let tempReturn = BDFDB.TimeUtils.suppress(module.BDFDBpatch[methodName].instead[priority][id], `"instead" callback of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`, module.BDFDBpatch[methodName].instead[priority][id].pluginName)(data);
|
let tempReturn = BDFDB.TimeUtils.suppress(module.BDFDB_patches[methodName].instead[priority][id], `"instead" callback of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`, module.BDFDB_patches[methodName].instead[priority][id].pluginName)(data);
|
||||||
if (tempReturn !== undefined) data.returnValue = tempReturn;
|
if (tempReturn !== undefined) data.returnValue = tempReturn;
|
||||||
}
|
}
|
||||||
if ((!hasInsteadPatches || callInstead) && !stopCall) BDFDB.TimeUtils.suppress(data.callOriginalMethod, `originalMethod of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`)();
|
if ((!hasInsteadPatches || callInstead) && !stopCall) BDFDB.TimeUtils.suppress(data.callOriginalMethod, `originalMethod of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`)();
|
||||||
|
|
||||||
if (!module.BDFDBpatch || !module.BDFDBpatch[methodName]) return methodName == "render" && data.returnValue === undefined ? null : data.returnValue;
|
if (!module.BDFDB_patches || !module.BDFDB_patches[methodName]) return methodName == "render" && data.returnValue === undefined ? null : data.returnValue;
|
||||||
for (let priority in module.BDFDBpatch[methodName].after) for (let id in BDFDB.ObjectUtils.sort(module.BDFDBpatch[methodName].after[priority])) {
|
for (let priority in module.BDFDB_patches[methodName].after) for (let id in BDFDB.ObjectUtils.sort(module.BDFDB_patches[methodName].after[priority])) {
|
||||||
let tempReturn = BDFDB.TimeUtils.suppress(module.BDFDBpatch[methodName].after[priority][id], `"after" callback of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`, module.BDFDBpatch[methodName].after[priority][id].pluginName)(data);
|
let tempReturn = BDFDB.TimeUtils.suppress(module.BDFDB_patches[methodName].after[priority][id], `"after" callback of ${methodName} in ${module.constructor ? (module.constructor.displayName || module.constructor.name) : "module"}`, module.BDFDB_patches[methodName].after[priority][id].pluginName)(data);
|
||||||
if (tempReturn !== undefined) data.returnValue = tempReturn;
|
if (tempReturn !== undefined) data.returnValue = tempReturn;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1598,15 +1603,15 @@ module.exports = (_ => {
|
||||||
module[methodName].toString = _ => realOriginalMethod.toString();
|
module[methodName].toString = _ => realOriginalMethod.toString();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
module[methodName].__isBDFDBpatched = true;
|
module[methodName].__is_BDFDB_patched = true;
|
||||||
}
|
}
|
||||||
for (let type in patchMethods) if (typeof patchMethods[type] == "function") {
|
for (let type in patchMethods) if (typeof patchMethods[type] == "function") {
|
||||||
if (!BDFDB.ObjectUtils.is(module.BDFDBpatch[methodName][type][patchPriority])) module.BDFDBpatch[methodName][type][patchPriority] = {};
|
if (!BDFDB.ObjectUtils.is(module.BDFDB_patches[methodName][type][patchPriority])) module.BDFDB_patches[methodName][type][patchPriority] = {};
|
||||||
module.BDFDBpatch[methodName][type][patchPriority][pluginId] = (...args) => {
|
module.BDFDB_patches[methodName][type][patchPriority][pluginId] = (...args) => {
|
||||||
if (config.once || !plugin.started) cancel();
|
if (config.once || !plugin.started) cancel();
|
||||||
return patchMethods[type](...args);
|
return patchMethods[type](...args);
|
||||||
};
|
};
|
||||||
module.BDFDBpatch[methodName][type][patchPriority][pluginId].pluginName = pluginName;
|
module.BDFDB_patches[methodName][type][patchPriority][pluginId].pluginName = pluginName;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (BDFDB.ObjectUtils.is(plugin) && !config.once && !config.noCache) {
|
if (BDFDB.ObjectUtils.is(plugin) && !config.once && !config.noCache) {
|
||||||
|
@ -1621,25 +1626,25 @@ module.exports = (_ => {
|
||||||
if (BDFDB.ObjectUtils.is(plugin) && BDFDB.ArrayUtils.is(plugin.patchCancels)) while (plugin.patchCancels.length) (plugin.patchCancels.pop())();
|
if (BDFDB.ObjectUtils.is(plugin) && BDFDB.ArrayUtils.is(plugin.patchCancels)) while (plugin.patchCancels.length) (plugin.patchCancels.pop())();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (!BDFDB.ObjectUtils.is(module) || !module.BDFDBpatch) return;
|
if (!BDFDB.ObjectUtils.is(module) || !module.BDFDB_patches) return;
|
||||||
const pluginId = !plugin ? null : (typeof plugin === "string" ? plugin : plugin.name).toLowerCase();
|
const pluginId = !plugin ? null : (typeof plugin === "string" ? plugin : plugin.name).toLowerCase();
|
||||||
if (methodNames) {
|
if (methodNames) {
|
||||||
for (let methodName of [methodNames].flat(10).filter(n => n)) if (module[methodName] && module.BDFDBpatch[methodName]) unpatch(methodName, pluginId);
|
for (let methodName of [methodNames].flat(10).filter(n => n)) if (module[methodName] && module.BDFDB_patches[methodName]) unpatch(methodName, pluginId);
|
||||||
}
|
}
|
||||||
else for (let patchedMethod of module.BDFDBpatch) unpatch(patchedMethod, pluginId);
|
else for (let patchedMethod of module.BDFDB_patches) unpatch(patchedMethod, pluginId);
|
||||||
}
|
}
|
||||||
function unpatch (funcName, pluginId) {
|
function unpatch (funcName, pluginId) {
|
||||||
for (let type of InternalData.ModuleUtilsConfig.PatchTypes) {
|
for (let type of InternalData.ModuleUtilsConfig.PatchTypes) {
|
||||||
if (pluginId) for (let priority in module.BDFDBpatch[funcName][type]) {
|
if (pluginId) for (let priority in module.BDFDB_patches[funcName][type]) {
|
||||||
delete module.BDFDBpatch[funcName][type][priority][pluginId];
|
delete module.BDFDB_patches[funcName][type][priority][pluginId];
|
||||||
if (BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch[funcName][type][priority])) delete module.BDFDBpatch[funcName][type][priority];
|
if (BDFDB.ObjectUtils.isEmpty(module.BDFDB_patches[funcName][type][priority])) delete module.BDFDB_patches[funcName][type][priority];
|
||||||
}
|
}
|
||||||
else delete module.BDFDBpatch[funcName][type];
|
else delete module.BDFDB_patches[funcName][type];
|
||||||
}
|
}
|
||||||
if (BDFDB.ObjectUtils.isEmpty(BDFDB.ObjectUtils.filter(module.BDFDBpatch[funcName], key => InternalData.ModuleUtilsConfig.PatchTypes.includes(key) && !BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch[funcName][key]), true))) {
|
if (BDFDB.ObjectUtils.isEmpty(BDFDB.ObjectUtils.filter(module.BDFDB_patches[funcName], key => InternalData.ModuleUtilsConfig.PatchTypes.includes(key) && !BDFDB.ObjectUtils.isEmpty(module.BDFDB_patches[funcName][key]), true))) {
|
||||||
module[funcName] = module.BDFDBpatch[funcName].originalMethod;
|
module[funcName] = module.BDFDB_patches[funcName].originalMethod;
|
||||||
delete module.BDFDBpatch[funcName];
|
delete module.BDFDB_patches[funcName];
|
||||||
if (BDFDB.ObjectUtils.isEmpty(module.BDFDBpatch)) delete module.BDFDBpatch;
|
if (BDFDB.ObjectUtils.isEmpty(module.BDFDB_patches)) delete module.BDFDB_patches;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -7443,7 +7448,7 @@ module.exports = (_ => {
|
||||||
while (PluginStores.delayedLoad.length) PluginStores.delayedLoad.shift().load();
|
while (PluginStores.delayedLoad.length) PluginStores.delayedLoad.shift().load();
|
||||||
while (PluginStores.delayedStart.length) PluginStores.delayedStart.shift().start();
|
while (PluginStores.delayedStart.length) PluginStores.delayedStart.shift().start();
|
||||||
while (pluginQueue.length) BDFDB.BDUtils.reloadPlugin(pluginQueue.shift());
|
while (pluginQueue.length) BDFDB.BDUtils.reloadPlugin(pluginQueue.shift());
|
||||||
});
|
}, "Could not initiate library!", config.name));
|
||||||
|
|
||||||
return class BDFDB_Frame {
|
return class BDFDB_Frame {
|
||||||
getName () {return config.name;}
|
getName () {return config.name;}
|
||||||
|
|
Loading…
Reference in New Issue