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 } = 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], }); 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 !'); // Initialiser la base de donnΓ©es (non bloquant) try { await initDatabase(); await createTables(); console.log('πŸ“¦ SystΓ¨me de liaison activΓ©'); // DΓ©marrer la surveillance de la console seulement si la DB est OK 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); }); 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); setInterval(()=>{clean(client)}, 86400000);