From b1395eb0326be6f0df19137071dc63c335499a81 Mon Sep 17 00:00:00 2001 From: Ayden Jahola Date: Mon, 2 Sep 2024 19:12:59 +0100 Subject: [PATCH] I did an opsie and removed comamnds regiseteration with discord api --- index.js | 53 ++++++++++++++++++++++++++++++++++++----------------- 1 file changed, 36 insertions(+), 17 deletions(-) diff --git a/index.js b/index.js index 83c3cb9..c6c1f31 100644 --- a/index.js +++ b/index.js @@ -1,8 +1,14 @@ require("dotenv").config(); +const { + Client, + GatewayIntentBits, + Collection, + REST, + Routes, +} = require("discord.js"); +const mongoose = require("mongoose"); const fs = require("fs"); const path = require("path"); -const { Client, GatewayIntentBits, Collection } = require("discord.js"); -const mongoose = require("mongoose"); const client = new Client({ intents: [ @@ -12,21 +18,20 @@ const client = new Client({ ], }); +const GUIlD_ID = process.env.GUILD_ID; + client.commands = new Collection(); -// Load command files dynamically -const commandsPath = path.join(__dirname, "commands"); const commandFiles = fs - .readdirSync(commandsPath) + .readdirSync(path.join(__dirname, "commands")) .filter((file) => file.endsWith(".js")); for (const file of commandFiles) { - const filePath = path.join(commandsPath, file); - const command = require(filePath); + const command = require(`./commands/${file}`); client.commands.set(command.data.name, command); } -client.once("ready", () => { +client.once("ready", async () => { console.log(`\n==============================`); console.log(`🤖 Logged in as ${client.user.tag}`); console.log(`==============================`); @@ -36,16 +41,26 @@ client.once("ready", () => { }); console.log(`\n==============================\n`); - // Set the bot's activity here - client.user.setActivity({ type: "WATCHING", name: "Degenerate Gamers" }); + const commands = client.commands.map((cmd) => cmd.data.toJSON()); - // Database connection (MongoDB) - mongoose - .connect(process.env.MONGODB_URI) - .then(() => console.log("✅ Connected to MongoDB")) - .catch((err) => console.error("❌ Failed to connect to MongoDB", err)); + const rest = new REST({ version: "10" }).setToken(process.env.BOT_TOKEN); + + try { + await rest.put(Routes.applicationGuildCommands(client.user.id, GUIlD_ID), { + body: commands, + }); + console.log("Successfully registered all application commands."); + } catch (err) { + console.error("Error registering application commands:", err); + } }); +// MongoDB connection +mongoose + .connect(process.env.MONGODB_URI) + .then(() => console.log("✅ Connected to MongoDB")) + .catch((err) => console.error("❌ Failed to connect to MongoDB", err)); + client.on("interactionCreate", async (interaction) => { if (!interaction.isCommand()) return; @@ -55,8 +70,8 @@ client.on("interactionCreate", async (interaction) => { try { await command.execute(interaction, client); - } catch (error) { - console.error(error); + } catch (err) { + console.error(err); await interaction.reply({ content: "There was an error while executing this command!", ephemeral: true, @@ -64,4 +79,8 @@ client.on("interactionCreate", async (interaction) => { } }); +client.on("Error", (err) => { + console.error("Client error:", err); +}); + client.login(process.env.BOT_TOKEN);