Updated autodeploy script and added preety-log

This commit is contained in:
2023-11-19 16:27:30 +01:00
parent ca44c07071
commit e70cd8b1a9
3 changed files with 112 additions and 5 deletions

View File

@@ -1,10 +1,17 @@
const { REST, Routes } = require('discord.js');
const log = require('log-beautify')
const fs = require('fs');
require('dotenv').config();
const token = process.env.DEVTOKEN;
const clientId = process.env.DEVID;
const guildId = process.env.GUILDID;
log.useSymbols = false
log.setColors({
newCmds: "#b4befe",
currentCmds: "#f38ba8"
})
async function autoDeployCommands() {
const commands = [];
const commandFiles = fs.readdirSync('./commands/').filter(file => file.endsWith('.js'));
@@ -17,14 +24,12 @@ async function autoDeployCommands() {
commands.push(command.data.toJSON());
}
}
for (const file of contentMenuCommands) {
const command = require(`../commands-contextmenu/${file}`);
if (command.dev) {
commands.push(command.data.toJSON());
}
}
for (const file of commandsTesting) {
const command = require(`../commands-testing/${file}`);
if (command.dev) {
@@ -44,7 +49,6 @@ async function autoDeployCommands() {
description: command.description,
}
})
const newCommandsInfo = commands.map(command => {
return {
name: command.name,
@@ -52,13 +56,26 @@ async function autoDeployCommands() {
}
})
if (JSON.stringify(currentCommandsInfo) === JSON.stringify(newCommandsInfo)) {
console.log('Commands are the same, skipping deploy.')
const sortedCurrentCommandsInfo = currentCommandsInfo.sort((a, b) => a.name.localeCompare(b.name))
const sortedNewCommandsInfo = newCommandsInfo.sort((a, b) => a.name.localeCompare(b.name))
const newCmds = sortedNewCommandsInfo.map(cmd => {
return " " + cmd.name + " was registered."
}).join('\n')
const currentCmds = sortedCurrentCommandsInfo.map(cmd => {
return " " + cmd.name + " was unregistered."
}).join('\n')
if (JSON.stringify(sortedNewCommandsInfo) === JSON.stringify(sortedCurrentCommandsInfo)) {
log.success('Commands are the same, skipping deploy.')
log.newCmds(newCmds)
return
}
(async () => {
try {
log.warning('Commands are different, starting deploy.')
log.currentCmds(currentCmds)
console.log(`Started refreshing ${commands.length} application (/) commands.`);
const data = await rest.put(
@@ -66,6 +83,7 @@ async function autoDeployCommands() {
{ body: commands },
);
log.newCmds(newCmds)
console.log(`Successfully reloaded ${data.length} application (/) commands.`);
} catch (error) {
console.error(error);