April/functions.mjs
2023-10-13 15:04:11 +02:00

234 lines
7.2 KiB
JavaScript

import { REST } from "@discordjs/rest";
import { Routes } from "discord-api-types/v10";
import { Collection, WebhookClient, EmbedBuilder, Client } from "discord.js";
import { inspect } from "util";
import fs from "fs";
import Sequelize from "sequelize";
import config from "./config.json" assert { type: "json" };
const { token, clientId, guildId, sequelizeCredentials, errorWebhookURL } =
config;
const rest = new REST({ version: "10" }).setToken(token);
async 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("."));
console.log(`Loading ${commandCategories.toString()} commands...`);
for (const category of commandCategories) {
const commandFiles = fs
.readdirSync(`./commands/${category}`)
.filter((file) => file.endsWith(".mjs"));
console.log(`Loading ${commandFiles.toString()}...`);
for (const file of commandFiles) {
const { default: command } = await import(
`./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) {
console.log("Starting to load database...");
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();
console.log("Database loaded !");
}
function loadErrorCatcher(client) {
console.log("Loading error catcher...");
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] });
});
console.log("Error catcher loaded !");
}
export { deploy_commands, loadDatabase, loadErrorCatcher };