2020-10-21 07:57:00 +00:00
class MessageHandler {
constructor ( client ) {
this . client = client ;
}
async handle ( message ) {
2020-10-23 03:26:30 +00:00
// Ignore messages from bots, and messages in DM's
if ( message . author . bot ) return ;
2021-07-16 03:30:28 +00:00
if ( ! message . guild ) return ;
2020-10-21 07:57:00 +00:00
2020-10-23 03:25:07 +00:00
// Request all the data we need from the database
2020-10-21 07:57:00 +00:00
const data = { } ;
data . user = await this . client . db . getUser ( message . author . id ) ;
2021-07-16 03:30:28 +00:00
data . guild = await this . client . db . getGuild ( message . guild . id ) ;
data . member = await this . client . db . getMember ( message . guild . id , message . author . id ) ;
2020-10-21 07:57:00 +00:00
2020-10-23 03:26:30 +00:00
// Ignore users on the guild blocklist
2020-10-23 08:10:32 +00:00
if ( data . guild . blocklist . includes ( message . author . id ) ) return ;
2020-10-23 03:26:30 +00:00
// If a user pings Woomy, respond to them with the prefixes they can use
if ( message . content === ` <@ ${ this . client . user . id } > ` || message . content === ` <@! ${ this . client . user . id } > ` ) {
2021-07-16 03:30:28 +00:00
return message . channel . send (
2020-10-26 01:09:06 +00:00
` Hi! The prefix for this server is \` ${ data . guild . prefix } \` , and your personal prefix is \` ${ data . user . prefix } \` . You can also ping me ^-^ `
2020-10-23 03:26:30 +00:00
) ;
}
2020-10-21 07:57:00 +00:00
2020-10-23 03:25:07 +00:00
// All the prefixes Woomy will respond to
const prefixes = [
data . user . prefix ,
data . guild . prefix ,
` <@ ${ this . client . user . id } > ` ,
` <@! ${ this . client . user . id } > `
] ;
2020-10-21 07:57:00 +00:00
let prefix ;
2020-10-23 03:26:30 +00:00
// Check the message content to see if it starts with one of our prefixes
2020-10-21 07:57:00 +00:00
for ( const thisPrefix of prefixes ) {
if ( message . content . startsWith ( thisPrefix ) ) {
prefix = thisPrefix ;
break ;
}
}
2020-10-23 03:26:30 +00:00
// Ignore the message if it doesn't start with a valid prefix
2020-10-21 07:57:00 +00:00
if ( ! prefix ) return ;
2020-10-29 08:19:59 +00:00
// Save prefix so we can use it later (mostly for help command)
if ( prefix === ` <@ ${ this . client . user . id } > ` || prefix === ` <@! ${ this . client . user . id } > ` ) {
message . prefix = '@Woomy ' ;
} else ( message . prefix = prefix ) ;
2020-10-23 03:26:30 +00:00
// Turn the message content into an array (excluding the prefix)
2020-10-21 07:57:00 +00:00
const args = message . content . slice ( prefix . length ) . trim ( ) . split ( / +/g ) ;
2020-10-23 03:26:30 +00:00
// Find the command
2020-10-21 07:57:00 +00:00
const commandName = args . shift ( ) . toLowerCase ( ) ;
const command = this . client . commands . get ( commandName ) || this . client . commands . get ( this . client . aliases . get ( commandName ) ) ;
2020-10-23 03:26:30 +00:00
// Return if a command (or its aliases) are not found
2020-10-21 07:57:00 +00:00
if ( ! command ) return ;
2020-10-23 03:26:30 +00:00
// Both of these blocks check if the command is disabled/in a disabled category
2021-07-16 03:30:28 +00:00
if ( data . guild . disabledcommands . includes ( command . name ) ) return message . channel . send (
2021-07-15 02:26:42 +00:00
this . client . config . emojis . permError + ' This command has been disabled by a server administrator.'
2020-10-23 03:26:30 +00:00
) ;
2020-10-21 07:57:00 +00:00
2021-07-16 03:30:28 +00:00
if ( data . guild . disabledcategories . includes ( command . category ) ) return message . channel . send (
2021-07-15 02:26:42 +00:00
this . client . config . emojis . permError + ' The category this command is apart of has been disabled by a server administrator.'
2020-10-23 03:26:30 +00:00
) ;
2020-10-21 07:57:00 +00:00
2020-10-23 03:26:30 +00:00
// Both of these blocks check the permissions of the user, and reply with missing perms if any are found
2020-10-25 02:10:05 +00:00
const missingUserPerms = this . client . functions . checkPermissions ( message . channel , message . author . id , command . userPerms ) ;
2021-07-16 03:30:28 +00:00
if ( missingUserPerms ) return message . channel . send (
2021-07-15 02:26:42 +00:00
` ${ this . client . config . emojis . permError } You can't use this command because you lack these permissions: \` ${ missingUserPerms . join ( '`, `' ) } \` `
2020-10-23 03:26:30 +00:00
) ;
2020-10-21 07:57:00 +00:00
2020-10-25 02:10:05 +00:00
const missingBotPerms = this . client . functions . checkPermissions ( message . channel , this . client . user . id , command . botPerms ) ;
2021-07-16 03:30:28 +00:00
if ( missingBotPerms ) return message . channel . send (
2021-07-15 02:26:42 +00:00
` ${ this . client . config . emojis . permError } I can't run this command because I lack these permissions: \` ${ missingBotPerms . join ( '`, `' ) } \` `
2020-10-23 03:26:30 +00:00
) ;
2020-10-21 07:57:00 +00:00
2020-10-23 03:26:30 +00:00
// Return if the command is disabled globally
2021-07-16 03:30:28 +00:00
if ( command . enabled === false ) return message . channel . send (
2021-07-15 02:26:42 +00:00
this . client . config . emojis . permError + ' This command has been disabled by my developers.'
2020-10-23 03:26:30 +00:00
) ;
2020-10-21 07:57:00 +00:00
2020-10-23 03:26:30 +00:00
// Return if the command is restricted to developers (and the user is not a developer)
2020-10-29 01:57:17 +00:00
if ( command . devOnly === true && this . client . config . ownerIDs . includes ( message . author . id ) !== true ) {
2021-07-16 03:30:28 +00:00
return message . channel . send (
2021-07-15 02:26:42 +00:00
` ${ this . client . config . emojis . permError } ${ message . author . username } is not in the sudoers file. This incident will be reported. `
2020-10-23 08:10:32 +00:00
) ;
2020-10-21 07:57:00 +00:00
}
2020-10-22 01:14:28 +00:00
// Cooldown
if ( this . client . cooldowns . get ( command . name ) . has ( message . author . id ) ) {
2020-10-22 01:49:31 +00:00
const timestamp = this . client . cooldowns . get ( command . name ) . get ( message . author . id ) ;
const currentTime = Date . now ( ) ;
const cooldown = command . cooldown / 1000 ;
const timePassed = Math . floor ( ( currentTime - timestamp ) / 1000 ) ;
2021-07-16 03:30:28 +00:00
return message . channel . send (
2021-07-15 02:26:42 +00:00
` ${ this . client . config . emojis . wait } ${ message . author . mention } , you need to wait ${ cooldown - timePassed } seconds before using this command again. `
2020-10-22 01:49:31 +00:00
) ;
2020-10-22 01:14:28 +00:00
} else {
this . client . cooldowns . get ( command . name ) . set ( message . author . id , new Date ( ) ) ;
setTimeout ( ( ) => {
this . client . cooldowns . get ( command . name ) . delete ( message . author . id ) ;
} , this . client . commands . get ( command . name ) . cooldown ) ;
}
2020-10-21 07:57:00 +00:00
try {
command . run ( this . client , message , args , data ) ;
this . client . logger . command ( ` Ran ${ command . name } ` ) ;
} catch ( error ) {
2021-07-16 03:30:28 +00:00
this . client . logger . error ( 'COMMAND_EXECUTION_ERROR' , ` ${ command . name } : ${ error . stack } ` ) ;
message . channel . send ( ` ${ this . client . config . emojis . botError } An error occured when I was trying to run this command. I've sent through the details of the error to my developers. ` ) ;
2020-10-21 07:57:00 +00:00
}
}
}
module . exports = MessageHandler ;