2022-12-15 13:07:35 -06:00
/ *
2022-12-16 06:00:03 -06:00
* Konpeki Discord Bot - Main Bot File
2022-12-15 13:07:35 -06:00
* All base level bot setup is done here
* /
// Require filesystem libraries
const fs = require ( 'node:fs' ) ;
const path = require ( 'node:path' ) ;
2022-12-16 02:42:59 -06:00
// Add pm2 metrics - this should NEVER track ANYTHING identifiable. This is purely for basic metrics and bot performance tracking
2022-12-16 03:58:49 -06:00
const metrics = require ( './utils/pm2-metrics.js' ) ;
// Use a custom logging script
const logger = require ( './utils/logging.js' ) ;
2022-12-16 02:42:59 -06:00
2022-12-15 13:07:35 -06:00
// Require the necessary discord.js classes
const { Client , Collection , Events , GatewayIntentBits } = require ( 'discord.js' ) ;
const { token , botOwner } = require ( './config.json' ) ;
// Create a new client instance
const client = new Client ( { intents : [ GatewayIntentBits . Guilds ] } ) ;
// Setup the commands collection
client . commands = new Collection ( ) ;
const commandsPath = path . join ( _ _dirname , 'commands' ) ;
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 {
2022-12-16 03:58:49 -06:00
logger . log ( logger . logLevels . WARN , ` The command at ${ filePath } is missing a required "data" or "execute" property. ` ) ;
2022-12-15 13:07:35 -06:00
}
}
// When the client is ready, run this code (only once)
// We use 'c' for the event parameter to keep it separate from the already defined 'client'
client . once ( Events . ClientReady , c => {
2022-12-16 03:58:49 -06:00
logger . log ( logger . logLevels . INFO , ` ${ logger . colorText ( 'Ready!' , logger . textColor . Green ) } Logged in as ${ logger . colorText ( c . user . tag , logger . textColor . Blue ) } ` ) ;
2022-12-15 13:07:35 -06:00
} ) ;
// Client "on" Events
client . on ( Events . InteractionCreate , async interaction => {
if ( ! interaction . isChatInputCommand ( ) ) return ;
const command = interaction . client . commands . get ( interaction . commandName ) ;
if ( ! command ) {
2022-12-16 03:58:49 -06:00
logger . log ( logger . logLevels . ERROR , ` No command matching ${ interaction . commandName } was found. ` ) ;
2022-12-15 13:07:35 -06:00
await interaction . reply ( { content : ` This command no longer exists! Please contact ${ botOwner } to report that this is happening! ` , ephemeral : true } ) ;
2022-12-16 02:42:59 -06:00
// Report error to PM2 dashboard
metrics . interactionErrors . inc ( ) ;
metrics . io . notifyError ( new Error ( 'Interaction doesn\'t exist' ) , {
custom : {
interactionCommand : interaction . commandName ,
} ,
} ) ;
2022-12-15 13:07:35 -06:00
return ;
}
try {
await command . execute ( interaction ) ;
}
catch ( error ) {
2022-12-16 03:58:49 -06:00
logger . log ( logger . logLevels . ERROR , error ) ;
2022-12-15 13:07:35 -06:00
await interaction . reply ( { content : 'There was an error while executing this command!' , ephemeral : true } ) ;
2022-12-16 02:42:59 -06:00
// Report error to PM2 dashboard
metrics . interactionErrors . inc ( ) ;
metrics . io . notifyError ( new Error ( 'Error executing interaction' ) , {
custom : {
interactionCommand : interaction . commandName ,
error : error ,
} ,
} ) ;
2022-12-15 13:07:35 -06:00
}
2022-12-16 02:42:59 -06:00
// Successful Execution, report as a PM2 metric
// If the bot gets a lot of use, consider removing this for performance
metrics . interactionSuccess ( ) ;
2022-12-15 13:07:35 -06:00
} ) ;
// Log in to Discord with your client's token
client . login ( token ) ;