Use Utils

This commit is contained in:
Jiiks 2018-01-16 03:55:14 +02:00
parent f160cb9c8b
commit a1261cab0a
2 changed files with 143 additions and 247 deletions

View File

@ -4666,41 +4666,6 @@ module.exports = { Module };
/* 2 */ /* 2 */
/***/ (function(module, exports, __webpack_require__) { /***/ (function(module, exports, __webpack_require__) {
/**
* BetterDiscord Events
* Copyright (c) 2015-present JsSucks - https://github.com/JsSucks
* All rights reserved.
* https://github.com/JsSucks - https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
const { EventEmitter } = __webpack_require__(134);
const emitter = new EventEmitter();
class Events {
static on(eventName, callBack) {
emitter.on(eventName, callBack);
}
static off(eventName, callBack) {
emitter.removeListener(eventName, callBack);
}
static emit(...args) {
emitter.emit(...args);
}
}
module.exports = { Events };
/***/ }),
/* 3 */
/***/ (function(module, exports, __webpack_require__) {
/** /**
* BetterDiscord Client Utils Module * BetterDiscord Client Utils Module
* Copyright (c) 2015-present JsSucks - https://github.com/JsSucks * Copyright (c) 2015-present JsSucks - https://github.com/JsSucks
@ -4713,6 +4678,8 @@ module.exports = { Events };
const { Module } = __webpack_require__(1); const { Module } = __webpack_require__(1);
const moment = __webpack_require__(0); const moment = __webpack_require__(0);
const fs = window.require('fs');
const path = window.require('path');
const logs = []; const logs = [];
@ -4752,9 +4719,129 @@ class Utils {
}; };
} }
static async tryParseJson(jsonString) {
try {
return JSON.parse(jsonString);
} catch (err) {
throw {
'message': 'Failed to parse json',
err
};
}
} }
module.exports = { Logger, Utils }; }
class FileUtils {
static async fileExists(path) {
return new Promise((resolve, reject) => {
fs.stat(path, (err, stats) => {
if (err) return reject({
'message': `No such file or directory: ${err.path}`,
err
});
if (!stats.isFile()) return reject({
'message': `Not a file: ${path}`,
stats
});
resolve();
});
});
}
static async directoryExists(path) {
return new Promise(resolve => {
fs.stat(path, (err, stats) => {
if (err) return reject({
'message': `Directory does not exist: ${path}`,
err
});
if (!stats.isDirectory()) return reject({
'message': `Not a directory: ${path}`,
stats
});
resolve();
});
});
}
static async readFile(path) {
try {
await this.fileExists(path);
} catch (err) {
throw err;
}
return new Promise(resolve => {
fs.readFile(path, 'utf-8', (err, data) => {
if (err) reject({
'message': `Could not read file: ${path}`,
err
});
resolve(data);
});
});
}
static async readJsonFromFile(path) {
let readFile;
try {
readFile = await this.readFile(path);
} catch (err) {
throw err;
}
try {
const parsed = await Utils.tryParseJson(readFile);
return parsed;
} catch (err) {
throw Object.assign(err, { path });
}
}
}
module.exports = { Logger, Utils, FileUtils };
/***/ }),
/* 3 */
/***/ (function(module, exports, __webpack_require__) {
/**
* BetterDiscord Events
* Copyright (c) 2015-present JsSucks - https://github.com/JsSucks
* All rights reserved.
* https://github.com/JsSucks - https://betterdiscord.net
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
const { EventEmitter } = __webpack_require__(134);
const emitter = new EventEmitter();
class Events {
static on(eventName, callBack) {
emitter.on(eventName, callBack);
}
static off(eventName, callBack) {
emitter.removeListener(eventName, callBack);
}
static emit(...args) {
emitter.emit(...args);
}
}
module.exports = { Events };
/***/ }), /***/ }),
/* 4 */ /* 4 */
@ -16463,7 +16550,7 @@ module.exports = { BDIpc };
*/ */
const { Module } = __webpack_require__(1); const { Module } = __webpack_require__(1);
const { Events } = __webpack_require__(2); const { Events } = __webpack_require__(3);
class Global extends Module { class Global extends Module {
@ -26807,10 +26894,11 @@ if (window.BetterDiscord) {
"use strict"; "use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true }); Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils__ = __webpack_require__(3); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils__ = __webpack_require__(2);
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__utils__); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__utils___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__utils__);
/* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_0__utils__, "Logger")) __webpack_require__.d(__webpack_exports__, "Logger", function() { return __WEBPACK_IMPORTED_MODULE_0__utils__["Logger"]; }); /* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_0__utils__, "Logger")) __webpack_require__.d(__webpack_exports__, "Logger", function() { return __WEBPACK_IMPORTED_MODULE_0__utils__["Logger"]; });
/* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_0__utils__, "Utils")) __webpack_require__.d(__webpack_exports__, "Utils", function() { return __WEBPACK_IMPORTED_MODULE_0__utils__["Utils"]; }); /* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_0__utils__, "Utils")) __webpack_require__.d(__webpack_exports__, "Utils", function() { return __WEBPACK_IMPORTED_MODULE_0__utils__["Utils"]; });
/* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_0__utils__, "FileUtils")) __webpack_require__.d(__webpack_exports__, "FileUtils", function() { return __WEBPACK_IMPORTED_MODULE_0__utils__["FileUtils"]; });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__pluginmanager__ = __webpack_require__(130); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__pluginmanager__ = __webpack_require__(130);
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__pluginmanager___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__pluginmanager__); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__pluginmanager___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__pluginmanager__);
/* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_1__pluginmanager__, "PluginManager")) __webpack_require__.d(__webpack_exports__, "PluginManager", function() { return __WEBPACK_IMPORTED_MODULE_1__pluginmanager__["PluginManager"]; }); /* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_1__pluginmanager__, "PluginManager")) __webpack_require__.d(__webpack_exports__, "PluginManager", function() { return __WEBPACK_IMPORTED_MODULE_1__pluginmanager__["PluginManager"]; });
@ -26826,7 +26914,7 @@ Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__global__ = __webpack_require__(124); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__global__ = __webpack_require__(124);
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__global___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__global__); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__global___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__global__);
/* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_5__global__, "Global")) __webpack_require__.d(__webpack_exports__, "Global", function() { return __WEBPACK_IMPORTED_MODULE_5__global__["Global"]; }); /* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_5__global__, "Global")) __webpack_require__.d(__webpack_exports__, "Global", function() { return __WEBPACK_IMPORTED_MODULE_5__global__["Global"]; });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__events__ = __webpack_require__(2); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__events__ = __webpack_require__(3);
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__events___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6__events__); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__events___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6__events__);
/* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_6__events__, "Events")) __webpack_require__.d(__webpack_exports__, "Events", function() { return __WEBPACK_IMPORTED_MODULE_6__events__["Events"]; }); /* harmony reexport (binding) */ if(__webpack_require__.o(__WEBPACK_IMPORTED_MODULE_6__events__, "Events")) __webpack_require__.d(__webpack_exports__, "Events", function() { return __WEBPACK_IMPORTED_MODULE_6__events__["Events"]; });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__discordsocket__ = __webpack_require__(135); /* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__discordsocket__ = __webpack_require__(135);
@ -27145,113 +27233,22 @@ webpackContext.id = 129;
const { Module } = __webpack_require__(1); const { Module } = __webpack_require__(1);
const { BDIpc } = __webpack_require__(123); const { BDIpc } = __webpack_require__(123);
const { Utils, FileUtils } = __webpack_require__(2);
const fs = window.require('fs'); const fs = window.require('fs');
const path = window.require('path'); const path = window.require('path');
//TODO add these to actual utils
class Utils {
static async tryParseJson(jsonString) {
try {
return JSON.parse(jsonString);
} catch (err) {
throw {
'message': 'Failed to parse json',
err
};
}
}
static get timestamp() {
return 'Timestamp';
}
}
class FileUtils {
static async fileExists(path) {
return new Promise((resolve, reject) => {
fs.stat(path, (err, stats) => {
if (err) return reject({
'message': `No such file or directory: ${err.path}`,
err
});
if (!stats.isFile()) return reject({
'message': `Not a file: ${path}`,
stats
});
resolve();
});
});
}
static async directoryExists(path) {
return new Promise(resolve => {
fs.stat(path, (err, stats) => {
if (err) return reject({
'message': `Directory does not exist: ${path}`,
err
});
if (!stats.isDirectory()) return reject({
'message': `Not a directory: ${path}`,
stats
});
resolve();
});
});
}
static async readFile(path) {
try {
await this.fileExists(path);
} catch (err) {
throw err;
}
return new Promise(resolve => {
fs.readFile(path, 'utf-8', (err, data) => {
if (err) reject({
'message': `Could not read file: ${path}`,
err
});
resolve(data);
});
});
}
static async readJsonFromFile(path) {
let readFile;
try {
readFile = await this.readFile(path);
} catch (err) {
throw err;
}
try {
const parsed = await Utils.tryParseJson(readFile);
return parsed;
} catch (err) {
throw Object.assign(err, { path });
}
}
}
class Plugin { class Plugin {
constructor(args) {} constructor(args) {}
start() { start() {
if (this.onStart) return this.onStart(); if (this.onStart) return this.onStart();
return true; //Assume plugin started since it doesn't have onStart
} }
stop() { stop() {
if (this.onStop) return this.onStop(); if (this.onStop) return this.onStop();
return true; //Assume plugin stopped since it doesn't have onStop
} }
} }
@ -27274,13 +27271,13 @@ class PluginManager extends Module {
const { plugins } = this.state; const { plugins } = this.state;
try { try {
const loaded = plugins.find(plugin => plugin.pluginPath === pluginPath); const loaded = plugins.find(plugin => plugin.pluginPath === pluginPath);
if (loaded) { if (loaded) {
throw { 'message': 'Attempted to load an already loaded plugin' }; throw { 'message': 'Attempted to load an already loaded plugin' };
} }
const readConfig = await this.readConfig(pluginPath); const readConfig = await this.readConfig(pluginPath);
const mainPath = path.join(pluginPath, readConfig.main); const mainPath = path.join(pluginPath, readConfig.main);
const plugin = window.require(mainPath)(Plugin, {}, {}); const plugin = window.require(mainPath)(Plugin, {}, {});
@ -27299,10 +27296,14 @@ class PluginManager extends Module {
} }
} }
async reloadPlugin(pluginPath) {
//TODO Cleanup loaded plugin
return await this.loadPlugin(pluginPath);
}
getPluginByName(name) { getPluginByName(name) {
return this.plugins.find(plugin => plugin.name === name); return this.plugins.find(plugin => plugin.name === name);
} }
getPluginById(id) { getPluginById(id) {
return this.plugins.find(plugin => plugin.id === id); return this.plugins.find(plugin => plugin.id === id);
} }
@ -27310,13 +27311,13 @@ class PluginManager extends Module {
stopPlugin(name) { stopPlugin(name) {
const plugin = this.getPluginByName(name); const plugin = this.getPluginByName(name);
if (plugin && plugin.instance) return plugin.instance.stop(); if (plugin && plugin.instance) return plugin.instance.stop();
return null; return true; //Return true anyways since plugin doesn't exist
} }
startPlugin(name) { startPlugin(name) {
const plugin = this.getPluginByName(name); const plugin = this.getPluginByName(name);
if (plugin && plugin.instance) return plugin.instance.start(); if (plugin && plugin.instance) return plugin.instance.start();
return null; return true; //Return true anyways since plugin doesn't exist
} }
async readConfig(path) { async readConfig(path) {
@ -27334,26 +27335,13 @@ async function tests() {
const config = await BDIpc.send('getConfig'); const config = await BDIpc.send('getConfig');
const pluginPath = config.paths.find(path => 'plugins' in path).plugins; const pluginPath = config.paths.find(path => 'plugins' in path).plugins;
try { try {
//Load test plugin
const plugin = await _instance.loadPlugin(path.join(pluginPath, pluginName)); const plugin = await _instance.loadPlugin(path.join(pluginPath, pluginName));
//Attempt to load the same plugin again
const plugin2 = await _instance.loadPlugin(path.join(pluginPath, pluginName)); const plugin2 = await _instance.loadPlugin(path.join(pluginPath, pluginName));
window.pl = plugin;
} catch (err) { } catch (err) {
console.log(`Failed to load plugin! ${err.message}`); console.log(`Failed to load plugin! ${err.message}`);
} }
// const config = await BDIpc.send('getConfig');
// const pluginPath = config.paths.find(path => 'plugins' in path).plugins;
// const examplePluginPath = path.join(pluginPath, pluginName);
//Test read config
/*try {
const readConfig = await _instance.readConfig(examplePluginPath);
console.log(readConfig);
window.testPlugin = window.require(path.join(examplePluginPath, readConfig.main));
} catch (err) {
console.log(err);
}*/
} }
module.exports = { PluginManager: _instance }; module.exports = { PluginManager: _instance };
@ -27784,10 +27772,10 @@ function isUndefined(arg) {
* LICENSE file in the root directory of this source tree. * LICENSE file in the root directory of this source tree.
*/ */
const { Events } = __webpack_require__(2); const { Events } = __webpack_require__(3);
const { Module } = __webpack_require__(1); const { Module } = __webpack_require__(1);
const { Global } = __webpack_require__(124); const { Global } = __webpack_require__(124);
const { Utils } = __webpack_require__(3); const { Utils } = __webpack_require__(2);
class SocketProxy extends Module { class SocketProxy extends Module {

View File

@ -10,102 +10,10 @@
const { Module } = require('./modulebase'); const { Module } = require('./modulebase');
const { BDIpc } = require('./bdipc'); const { BDIpc } = require('./bdipc');
const { Utils, FileUtils } = require('./utils');
const fs = window.require('fs'); const fs = window.require('fs');
const path = window.require('path'); const path = window.require('path');
//TODO add these to actual utils
class Utils {
static async tryParseJson(jsonString) {
try {
return JSON.parse(jsonString);
} catch (err) {
throw ({
'message': 'Failed to parse json',
err
});
}
}
static get timestamp() {
return 'Timestamp';
}
}
class FileUtils {
static async fileExists(path) {
return new Promise((resolve, reject) => {
fs.stat(path, (err, stats) => {
if (err) return reject({
'message': `No such file or directory: ${err.path}`,
err
});
if (!stats.isFile()) return reject({
'message': `Not a file: ${path}`,
stats
});
resolve();
});
});
}
static async directoryExists(path) {
return new Promise(resolve => {
fs.stat(path, (err, stats) => {
if (err) return reject({
'message': `Directory does not exist: ${path}`,
err
});
if (!stats.isDirectory()) return reject({
'message': `Not a directory: ${path}`,
stats
});
resolve();
});
});
}
static async readFile(path) {
try {
await this.fileExists(path);
} catch (err) {
throw (err);
}
return new Promise(resolve => {
fs.readFile(path, 'utf-8', (err, data) => {
if (err) reject({
'message': `Could not read file: ${path}`,
err
});
resolve(data);
});
});
}
static async readJsonFromFile(path) {
let readFile;
try {
readFile = await this.readFile(path);
} catch (err) {
throw (err);
}
try {
const parsed = await Utils.tryParseJson(readFile);
return parsed;
} catch (err) {
throw (Object.assign(err, { path }));
}
}
}
class Plugin { class Plugin {