require('dotenv').config(); const fs = require('node:fs'); const deepl = require('deepl-node'); const path = require('node:path'); const deploy = require('./deploy_command.js') const update = require('./displayer.js'); const clean = require('./cleaner.js'); const { Client, GatewayIntentBits, Collection, Events, Partials } = require('discord.js'); const { initDatabase, createTables, cleanExpiredCodes } = require('./database.js'); const { startConsoleMonitoring } = require('./consoleMonitor.js'); const client = new Client({ intents: [ GatewayIntentBits.GuildMembers, GatewayIntentBits.GuildMessages, GatewayIntentBits.GuildMessageReactions, GatewayIntentBits.MessageContent, GatewayIntentBits.Guilds ], partials: [Partials.Message, Partials.Channel, Partials.Reaction, Partials.User], }); const headers = { "Accept": "application/json", "Content-Type": "application/json", "Authorization": "Bearer " + process.env.PTERODACTYL_API_TOKEN }; const numbers=["๐ŸŽ","๐Ÿ","๐Ÿ","๐Ÿ‘","๐Ÿ’","๐Ÿ“","๐Ÿ”","๐Ÿ•","๐Ÿ–","๐Ÿ—","๐Ÿ๐ŸŽ","๐Ÿ๐Ÿ","๐Ÿ๐Ÿ","๐Ÿ๐Ÿ‘","๐Ÿ๐Ÿ–","๐Ÿ๐Ÿ•","๐Ÿ๐Ÿ–","๐Ÿ๐Ÿ—","๐Ÿ๐ŸŽ","๐Ÿ๐Ÿ","๐Ÿ๐Ÿ","๐Ÿ๐Ÿ‘","๐Ÿ๐Ÿ’","๐Ÿ๐Ÿ“","๐Ÿ๐Ÿ”","๐Ÿ๐Ÿ•","๐Ÿ๐Ÿ–","๐Ÿ๐Ÿ—","๐Ÿ‘๐ŸŽ","๐Ÿ‘๐Ÿ","๐Ÿ‘๐Ÿ"]; const translator = process.env.DEEPL_TOKEN ? new deepl.Translator(process.env.DEEPL_TOKEN) : null; client.commands = new Collection(); const foldersPath = path.join(__dirname, 'commands'); const commandFolders = fs.readdirSync(foldersPath); for (const folder of commandFolders) { const commandsPath = path.join(foldersPath, folder); const commandFiles = fs.readdirSync(commandsPath).filter(file => file.endsWith('.js')); for (const file of commandFiles) { const filePath = path.join(commandsPath, file); const command = require(filePath); // Set a new item in the Collection with the key as the command name and the value as the exported module if ('data' in command && 'execute' in command) { client.commands.set(command.data.name, command); } else { console.log(`[WARNING] The command at ${filePath} is missing a required "data" or "execute" property.`); } } } client.once('ready', async () => { client.user.setPresence({ activities: [{ name: 'Rygain', type: 'WATCHING' }], status: 'online' }); console.log('Bot started !'); try { await initDatabase(); await createTables(); // Nettoyer les codes expirรฉs au dรฉmarrage await cleanExpiredCodes(); console.log('๐Ÿงน Codes expirรฉs nettoyรฉs'); console.log('๐Ÿ“ฆ Systรจme de liaison activรฉ'); startConsoleMonitoring(client, process.env.PTERODACTYL_API_TOKEN); } catch (error) { console.error('โš ๏ธ Erreur lors de l\'initialisation de la base de donnรฉes'); console.error('โš ๏ธ Le systรจme de liaison est dรฉsactivรฉ'); console.error('โš ๏ธ Les autres fonctionnalitรฉs du bot restent actives'); } deploy(process.env.DISCORD_TOKEN); clean(client); }); client.on(Events.InteractionCreate, async interaction => { if (!interaction.isChatInputCommand()) return; // Vรฉrifier que la commande provient du bon serveur if (interaction.guildId !== process.env.GUILD_ID) { return interaction.reply({ content: 'Ce bot ne peut รชtre utilisรฉ que sur un serveur spรฉcifique.', ephemeral: true }); } const command = interaction.client.commands.get(interaction.commandName); if (!command) { console.error(`No command matching ${interaction.commandName} was found.`); return; } try { if (interaction.commandName === 'server-stats') { await command.execute(interaction, process.env.PALWORLD_API_TOKEN); } else if (interaction.commandName === 'trad') { await command.execute(interaction, translator); } else if (interaction.commandName === 'start-server' || interaction.commandName === 'reboot-server') { await command.execute(interaction, headers); } else { await command.execute(interaction); } } catch (error) { console.error(error); if (interaction.replied || interaction.deferred) { await interaction.followUp({ content: 'There was an error while executing this command!', ephemeral: true }); } else { await interaction.reply({ content: 'There was an error while executing this command!', ephemeral: true }); } } }); client.login(process.env.DISCORD_TOKEN); setInterval(()=>{update(headers,numbers,client,process.env.PALWORLD_API_TOKEN)}, 300000);