mirror of
https://github.com/Hessenuk/DiscordTickets.git
synced 2024-11-17 17:23:08 +02:00
Improvements and fixes, start on command manager
This commit is contained in:
parent
8b661f0462
commit
7c0b1311dc
@ -1 +1 @@
|
||||
This documentation is intended to be access through the website (https://eartharoid.github.io/discordtickets)
|
||||
This documentation is intended to be access through the website (https://discordtickets.eartharoid.me)
|
84
src/index.js
84
src/index.js
@ -28,29 +28,30 @@ if (node_version < 14)
|
||||
const fs = require('fs');
|
||||
const { path } = require('./utils/fs');
|
||||
|
||||
const ENV_PATH = path('./.env');
|
||||
const EXAMPLE_ENV_PATH = path('./example.env');
|
||||
if (!fs.existsSync(ENV_PATH )) {
|
||||
if (!fs.existsSync(EXAMPLE_ENV_PATH)) {
|
||||
console.log('Error: \'.env\' not found, and unable to create it due to \'example.env\' being missing');
|
||||
const checkFile = (file, example) => {
|
||||
|
||||
file = path(file);
|
||||
example = path(example);
|
||||
|
||||
if (fs.existsSync(file)) return true;
|
||||
if (!fs.existsSync(example)) {
|
||||
console.log(`Error: '${file}' not found, and unable to create it due to '${example}' being missing`);
|
||||
return process.exit();
|
||||
}
|
||||
console.log('Copying \'example.env\' to \'.env\'');
|
||||
fs.copyFileSync(EXAMPLE_ENV_PATH, ENV_PATH);
|
||||
console.log('Please set your bot\'s token in your \'.env\' file');
|
||||
|
||||
console.log(`Copying '${example}' to '${file}'`);
|
||||
fs.copyFileSync(example, file);
|
||||
return false;
|
||||
|
||||
};
|
||||
|
||||
if (!checkFile('./.env', './example.env')) {
|
||||
console.log('Please set your bot\'s token in \'.env\'');
|
||||
process.exit();
|
||||
}
|
||||
|
||||
const CONFIG_PATH = path('./user/config.js');
|
||||
const EXAMPLE_CONFIG_PATH = path('./user/example.config.js');
|
||||
if (!fs.existsSync(CONFIG_PATH)) {
|
||||
if (!fs.existsSync(EXAMPLE_CONFIG_PATH)) {
|
||||
console.log('Error: \'user/config.js\' not found, and unable to create it due to \'user/example.config.js\' being missing');
|
||||
return process.exit();
|
||||
}
|
||||
console.log('Copying \'user/example.config.js\' to \'user/config.js\'');
|
||||
fs.copyFileSync(EXAMPLE_CONFIG_PATH, CONFIG_PATH);
|
||||
}
|
||||
checkFile('./user/config.js', './user/example.config.js');
|
||||
|
||||
|
||||
|
||||
require('dotenv').config({
|
||||
@ -105,33 +106,36 @@ class Bot extends Client {
|
||||
}
|
||||
});
|
||||
|
||||
/** The global bot configuration */
|
||||
this.config= config;
|
||||
/** A sequelize instance */
|
||||
this.db = require('./database')(log), // this.db.models.Ticket...
|
||||
/** A leekslazylogger instance */
|
||||
this.log = log;
|
||||
/** An @eartharoid/i18n instance */
|
||||
this.i18n = new I18n(path('./src/locales'), 'en-GB');
|
||||
(async () => {
|
||||
/** The global bot configuration */
|
||||
this.config = config;
|
||||
|
||||
// set the max listeners for each event to the number in the config
|
||||
this.setMaxListeners(this.config.max_listeners);
|
||||
/** A sequelize instance */
|
||||
this.db = await require('./database')(log), // this.db.models.Ticket...
|
||||
|
||||
// check for updates
|
||||
require('./updater')(this);
|
||||
// load internal listeners
|
||||
require('./modules/listeners')(this);
|
||||
/** A leekslazylogger instance */
|
||||
this.log = log;
|
||||
|
||||
/** The command manager, used by internal and plugin commands */
|
||||
this.commands = new CommandManager(this);
|
||||
/** The plugin manager */
|
||||
this.plugins = new PluginManager(this);
|
||||
// load plugins
|
||||
this.plugins.load();
|
||||
/** An @eartharoid/i18n instance */
|
||||
this.i18n = new I18n(path('./src/locales'), 'en-GB');
|
||||
|
||||
this.log.info('Connecting to Discord API...');
|
||||
this.setMaxListeners(this.config.max_listeners); // set the max listeners for each event
|
||||
|
||||
this.login();
|
||||
require('./updater')(this); // check for updates
|
||||
require('./modules/listeners')(this); // load internal listeners
|
||||
|
||||
/** The command manager, used by internal and plugin commands */
|
||||
this.commands = new CommandManager(this);
|
||||
this.commands.load(); // load internal commands
|
||||
|
||||
/** The plugin manager */
|
||||
this.plugins = new PluginManager(this);
|
||||
this.plugins.load(); // load plugins
|
||||
|
||||
this.log.info('Connecting to Discord API...');
|
||||
|
||||
this.login();
|
||||
})();
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -1,41 +0,0 @@
|
||||
const fs = require('fs');
|
||||
const { join } = require('path');
|
||||
const { path } = require('../utils/fs');
|
||||
|
||||
class CommandManager {
|
||||
constructor(client) {
|
||||
this.client = client;
|
||||
this.commands = new Map();
|
||||
}
|
||||
|
||||
load(command) {
|
||||
|
||||
}
|
||||
|
||||
unload(command) {
|
||||
|
||||
}
|
||||
|
||||
reload(command) {
|
||||
|
||||
}
|
||||
|
||||
get(command) {
|
||||
|
||||
}
|
||||
|
||||
get list() {
|
||||
return this.commands;
|
||||
}
|
||||
}
|
||||
|
||||
class Command {
|
||||
constructor(client) {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = {
|
||||
CommandManager,
|
||||
Command
|
||||
};
|
92
src/modules/commands/command.js
Normal file
92
src/modules/commands/command.js
Normal file
@ -0,0 +1,92 @@
|
||||
/* eslint-disable no-unused-vars */
|
||||
const { Client } = require('discord.js');
|
||||
|
||||
const fs = require('fs');
|
||||
const { join } = require('path');
|
||||
const { path } = require('../../utils/fs');
|
||||
|
||||
/** A plugin */
|
||||
module.exports = class Plugin {
|
||||
/**
|
||||
* Create a new Plugin
|
||||
* @param {Client} client The Discord Client
|
||||
* @param {String} id The plugin ID
|
||||
* @param {Object} options Plugin options
|
||||
* @param {String} options.name A human-friendly name (can be different to the name in package.json)
|
||||
*/
|
||||
constructor(client, id, options = {}) {
|
||||
/** The human-friendly name of the plugin */
|
||||
this.name = options.name || id;
|
||||
|
||||
/** The Discord Client */
|
||||
this.client = client;
|
||||
|
||||
/** The PluginManager */
|
||||
this.manager = this.client.plugins;
|
||||
|
||||
// Object.assign(this, this.manager.plugins.get(id));
|
||||
// make JSDoc happy
|
||||
|
||||
let {
|
||||
version,
|
||||
author,
|
||||
description
|
||||
} = this.manager.plugins.get(id);
|
||||
|
||||
/** The unique ID of the plugin (NPM package name) */
|
||||
this.id = id;
|
||||
|
||||
/** The version of the plugin (NPM package version) */
|
||||
this.version = version;
|
||||
|
||||
/** The plugin author's name (NPM package author) */
|
||||
this.author = author;
|
||||
|
||||
/** The plugin description (NPM package description) */
|
||||
this.description = description;
|
||||
|
||||
this.directory = {};
|
||||
|
||||
/** A cleaned version of the plugin's ID suitable for use in the directory name */
|
||||
this.directory.name = this.id.replace(/@[-_a-zA-Z0-9]+\//, '');
|
||||
|
||||
/** The absolute path of the plugin directory */
|
||||
this.directory.path = path(`./user/plugins/${this.directory.name}`);
|
||||
}
|
||||
|
||||
/**
|
||||
* Create the plugin directory if it doesn't already exist
|
||||
* @returns {Boolean} True if created, false if it already existed
|
||||
*/
|
||||
createDirectory() {
|
||||
if (!fs.existsSync(this.directory.path)) {
|
||||
this.client.log.plugins(`Creating plugin directory for "${this.name}"`);
|
||||
fs.mkdirSync(this.directory.path);
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Create the plugin config file if it doesn't already exist
|
||||
* @param {Object} template The default config template
|
||||
* @returns {Boolean} True if created, false if it already existed
|
||||
*/
|
||||
createConfig(template) {
|
||||
this.createDirectory();
|
||||
let file = join(this.directory.path, 'config.json');
|
||||
if (!fs.existsSync(file)) {
|
||||
this.client.log.plugins(`Creating plugin config file for "${this.name}"`);
|
||||
fs.writeFileSync(file, JSON.stringify(template, null, 2));
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* The main function where your code should go. Create functions and event listeners here
|
||||
*/
|
||||
load() {}
|
||||
};
|
4
src/modules/commands/index.js
Normal file
4
src/modules/commands/index.js
Normal file
@ -0,0 +1,4 @@
|
||||
module.exports = {
|
||||
CommandManager: require('./manager'),
|
||||
Command: require('./command')
|
||||
};
|
33
src/modules/commands/manager.js
Normal file
33
src/modules/commands/manager.js
Normal file
@ -0,0 +1,33 @@
|
||||
// eslint-disable-next-line no-unused-vars
|
||||
const { Collection, Client } = require('discord.js');
|
||||
// eslint-disable-next-line no-unused-vars
|
||||
const Command = require('./command');
|
||||
|
||||
const fs = require('fs');
|
||||
const { path } = require('../../utils/fs');
|
||||
|
||||
/** Manages the loading of commands */
|
||||
module.exports = class CommandManager {
|
||||
/**
|
||||
* Create a CommandManager instance
|
||||
* @param {Client} client
|
||||
*/
|
||||
constructor(client) {
|
||||
/** The Discord Client */
|
||||
this.client = client;
|
||||
/** A discord.js Collection (Map) of loaded commands */
|
||||
this.commands = new Collection();
|
||||
}
|
||||
|
||||
/** Automatically load all internal commands */
|
||||
load() {
|
||||
const files = fs.readdirSync(path('./src/commands'))
|
||||
.filter(file => file.endsWith('.js'));
|
||||
|
||||
for (const file of files) {
|
||||
const cmd = require(`../commands/${file}`);
|
||||
this.commands.set(cmd, new cmd(this.client));
|
||||
}
|
||||
}
|
||||
|
||||
};
|
@ -80,15 +80,13 @@ module.exports = class PluginManager {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Automatically register and load plugins
|
||||
*/
|
||||
/** Automatically register and load plugins */
|
||||
load() {
|
||||
// normal plugins (NPM)
|
||||
this.client.config.plugins.forEach(plugin => {
|
||||
try {
|
||||
let pkg = require(`${plugin}/package.json`);
|
||||
let main = require(plugin);
|
||||
let pkg = require(`${plugin}/package.json`);
|
||||
this.registerPlugin(true, main, pkg);
|
||||
} catch (e) {
|
||||
this.client.log.warn(`An error occurred whilst loading ${plugin}; have you installed it?`);
|
||||
|
@ -14,14 +14,13 @@ module.exports = class Plugin {
|
||||
* @param {Object} options Plugin options
|
||||
* @param {String} options.name A human-friendly name (can be different to the name in package.json)
|
||||
*/
|
||||
constructor(client, id, options) {
|
||||
if (typeof options === 'object') {
|
||||
/** The human-friendly name of the plugin */
|
||||
this.name = options.name || id;
|
||||
}
|
||||
constructor(client, id, options = {}) {
|
||||
/** The human-friendly name of the plugin */
|
||||
this.name = options.name || id;
|
||||
|
||||
/** The Discord Client */
|
||||
this.client = client;
|
||||
|
||||
/** The PluginManager */
|
||||
this.manager = this.client.plugins;
|
||||
|
||||
@ -36,16 +35,21 @@ module.exports = class Plugin {
|
||||
|
||||
/** The unique ID of the plugin (NPM package name) */
|
||||
this.id = id;
|
||||
|
||||
/** The version of the plugin (NPM package version) */
|
||||
this.version = version;
|
||||
|
||||
/** The plugin author's name (NPM package author) */
|
||||
this.author = author;
|
||||
|
||||
/** The plugin description (NPM package description) */
|
||||
this.description = description;
|
||||
|
||||
this.directory = {};
|
||||
|
||||
/** A cleaned version of the plugin's ID suitable for use in the directory name */
|
||||
this.directory.name = this.id.replace(/@[-_a-zA-Z0-9]+\//, '');
|
||||
|
||||
/** The absolute path of the plugin directory */
|
||||
this.directory.path = path(`./user/plugins/${this.directory.name}`);
|
||||
}
|
||||
|
@ -10,14 +10,14 @@
|
||||
* Quick Start
|
||||
* ---------------------
|
||||
*
|
||||
* > For detailed instructions, visit the documentation: https://eartharoid.github.io/discordtickets
|
||||
* > For detailed instructions, visit the documentation: https://discordtickets.eartharoid.me
|
||||
*
|
||||
* ---------------------
|
||||
* Support
|
||||
* ---------------------
|
||||
*
|
||||
* > Discord support server: https://go.eartharoid.me/discord
|
||||
* > Wiki: https://eartharoid.github.io/discordtickets
|
||||
* > Documentation: https://discordtickets.eartharoid.me
|
||||
*
|
||||
* ###############################################################################################
|
||||
*/
|
||||
@ -35,12 +35,8 @@ module.exports = {
|
||||
max_listeners: 10,
|
||||
plugins: [
|
||||
// 'dsctickets.plugin-name'
|
||||
'discordtickets-portal'
|
||||
// 'discordtickets-portal'
|
||||
],
|
||||
portal: {
|
||||
enabled: false,
|
||||
host: 'https://tickets.example.com'
|
||||
},
|
||||
presences: [
|
||||
{
|
||||
activity: '/new | /help',
|
||||
|
Loading…
Reference in New Issue
Block a user