const { REST } = require('@discordjs/rest'); const { Routes } = require('discord-api-types/v10'); const { token, clientId, guildId, sequelizeCredentials, errorWebhookURL } = require('./config.json'); const { Collection, WebhookClient, EmbedBuilder, Client } = require('discord.js'); const { inspect } = require("util"); const fs = require('fs'); const rest = new REST({ version: '10' }).setToken(token); const Sequelize = require('sequelize'); function deploy_commands(client, loadcommands) { if (typeof loadcommands !="boolean" && loadcommands != null) throw "loadcommands argument needs to be boolean or null"; const commands = []; client.commands = new Collection(); const commandCategories = fs.readdirSync('./commands').filter(file => !file.includes('.')); for (const category of commandCategories) { const commandFiles = fs.readdirSync(`./commands/${category}`).filter(file => file.endsWith('.js')); for (const file of commandFiles) { const command = require(`./commands/${category}/${file}`); commands.push(command.data); client.commands.set(command.data.name, command); console.log(`${category}/${command.data.name} chargé !`); } } if (loadcommands==true){ slashCommandLoad(client, commands); console.log("Refreshed slash commands !"); } else if(loadcommands==false){//Deletes slash commands slashCommandLoad(client, []); console.log("Deleted slash commands !"); } else{ console.log("Kept old commands"); } }; async function slashCommandLoad(client, commands) { try { console.log('Je commence à actualiser les commandes slash.'); await rest.put( Routes.applicationGuildCommands(clientId, guildId), { body: commands }, ); console.log('Je viens de terminer de charger les commandes slash.'); } catch (error) { console.error(error); } return client.commands; }; function loadDatabase(client) { const sequelize = new Sequelize('database', sequelizeCredentials.username, sequelizeCredentials.password, { host: 'localhost', dialect: 'sqlite', logging: false, storage: 'database.sqlite', }); const blacklistdb = sequelize.define('blacklist', { name: {//id type: Sequelize.STRING, unique: true, }, username: Sequelize.STRING, reason: Sequelize.TEXT, timestamp: Sequelize.STRING, moderatorid: Sequelize.STRING }); const modlog = sequelize.define('sanctions', { name: Sequelize.STRING,//id username: Sequelize.STRING, type: Sequelize.STRING, reason: Sequelize.TEXT, timestamp: Sequelize.STRING, moderatorid: Sequelize.STRING }); const artists = sequelize.define('artists', { name: Sequelize.STRING,//id emoji: Sequelize.STRING, }); client.database = { sequelize: sequelize, modlog: modlog, blacklistdb: blacklistdb, artists: artists, }; blacklistdb.sync(); modlog.sync(); artists.sync(); } function loadErrorCatcher(client) { client.errorCatcherWebhook = new WebhookClient({ url: errorWebhookURL, }); process.on("unhandledRejection", (reason, promise) => { console.log(reason, "\n", promise); const errorEmbed = new EmbedBuilder() .setColor("Red") .setTitle("Unhandled Rejection/Catch") .setURL("https://nodejs.org/api/process.html#event-unhandledrejection") .addFields( { name: "Reason", value: `\`\`\`${inspect(reason, { depth: 0 }).slice(0, 1000)}\`\`\``, }, { name: "Promise", value: `\`\`\`${inspect(promise, { depth: 0 }).slice(0, 1000)}\`\`\``, } ) .setTimestamp(); return client.errorCatcherWebhook.send({ embeds: [errorEmbed] }); }); process.on("uncaughtException", (err, origin) => { console.log(err, "\n", origin); const errorEmbed = new EmbedBuilder() .setColor("Red") .setTitle("Uncaught Exception/Catch") .setURL("https://nodejs.org/api/process.html#event-uncaughtexception") .addFields( { name: "Error", value: `\`\`\`${inspect(err, { depth: 0 }).slice(0, 1000)}\`\`\``, }, { name: "Origin", value: `\`\`\`${inspect(origin, { depth: 0 }).slice(0, 1000)}\`\`\``, } ) .setTimestamp(); return client.errorCatcherWebhook.send({ embeds: [errorEmbed] }); }); process.on("uncaughtExceptionMonitor", (err, origin) => { console.log(err, "\n", origin); const errorEmbed = new EmbedBuilder() .setColor("Red") .setTitle("Uncaught Exception Monitor") .setURL( "https://nodejs.org/api/process.html#event-uncaughtexceptionmonitor" ) .addFields( { name: "Error", value: `\`\`\`${inspect(err, { depth: 0 }).slice(0, 1000)}\`\`\``, }, { name: "Origin", value: `\`\`\`${inspect(origin, { depth: 0 }).slice(0, 1000)}\`\`\``, } ) .setTimestamp(); return client.errorCatcherWebhook.send({ embeds: [errorEmbed] }); }); process.on("warning", (warn) => { console.log(warn); const errorEmbed = new EmbedBuilder() .setColor("Red") .setTitle("Uncaught Exception Monitor Warning") .setURL("https://nodejs.org/api/process.html#event-warning") .addFields({ name: "Warning", value: `\`\`\`${inspect(warn, { depth: 0 }).slice(0, 1000)}\`\`\``, }) .setTimestamp(); return client.errorCatcherWebhook.send({ embeds: [errorEmbed] }); }); } module.exports = { deploy_commands, loadDatabase, loadErrorCatcher }