const Discord = require ( 'discord.js' ) ;
const chalk = require ( 'chalk' ) ;
const wait = require ( '../util/wait' ) ;
const UserData = require ( '../models/user' ) ;
const AR = require ( '../models/ar' ) ;
const LXP = require ( '../models/localxp' ) ;
const Monitors = require ( '../models/monitor' ) ;
const Monners = require ( '../models/monners' ) ;
const RP = require ( '../models/rpch' ) ;
const channelTypes = [ "GUILD_MESSAGE" , "DM" , "GUILD_NEWS_THREAD" , "GUILD_PRIVATE_THREAD" , "GUILD_PUBLIC_THREAD" , "GUILD_NEWS" , "GROUP_DM" , "GUILD_STORE" , "GUILD_TEXT" ] ;
module . exports = async ( client , message ) => {
if ( ! client . misc . fullyReady ) { return ; }
if ( message . partial ) { await message . fetch ( ) ; }
if ( message . channel . partial ) { await message . channel . fetch ( ) ; }
if ( ! message . author || message . author . bot ) { return undefined ; }
if ( ! channelTypes . includes ( message . channel . type ) ) { return undefined ; }
if ( message . guild && ! message . member . permissions . has ( "SEND_MESSAGES" ) ) { return undefined ; }
let defaultPrefix = client . misc . config . dev ? 'n!' : 'n?' ;
let prefix = message . guild ? client . guildconfig . prefixes . has ( message . guild . id ) ? client . guildconfig . prefixes . get ( message . guild . id ) !== null ? client . guildconfig . prefixes . get ( message . guild . id ) : defaultPrefix : defaultPrefix : defaultPrefix ;
let msg = message . content . toLowerCase ( ) . replace ( '\u200E' , '' ) ;
let mention = message . mentions . users . first ( ) ;
let args = msg . startsWith ( prefix )
? message . content . slice ( prefix . length ) . trim ( ) . replace ( '\u200E' , '' ) . split ( /\s+/g )
: msg . startsWith ( '<@!' )
? message . content . slice ( 4 + client . user . id . length ) . trim ( ) . replace ( '\u200E' , '' ) . split ( /\s+/g )
: message . content . slice ( 3 + client . user . id . length ) . trim ( ) . replace ( '\u200E' , '' ) . split ( /\s+/g ) ;
let cmd = args . shift ( ) . toLowerCase ( ) . trim ( ) ;
message . misc = { mn : message . guild ? ( client . misc . cache . monnersNames . get ( message . guild . id ) || 'Monners' ) : 'Monners' } ;
if ( message . content . includes ( "@everyone" ) ) { return ; }
if ( [ ` <@ ${ client . user . id } > ` , ` <@! ${ client . user . id } > ` ] . includes ( msg ) ) {
return message . channel . send ( { embeds : [ new Discord . MessageEmbed ( )
. setTitle ( [ "Yep, that's me!" , "^^ Hiya!" , "Oh, hi there!" , "Sure, what's up?" , "How can I help!" , "Natsuki is busy, but I can take a message for you!" , "Teehee that's me!" , "You were looking for Natsuki Tivastl, right?" , "Sure! What's up?" , "Pong!" ] [ Math . floor ( Math . random ( ) * 10 ) ] )
. setDescription ( ` My prefix here is \` ${ prefix } \` . Use \` ${ prefix } help \` to see what commands you can use. ` )
. setColor ( 'c375f0' ) ] } ) . catch ( ( ) => { } ) ;
}
if ( mention && message . guild ) { require ( '../util/mention' ) ( message , msg , args , cmd , prefix , mention , client ) ; }
UserData . findOne ( { uid : message . author . id } ) . then ( async ( tu ) => {
if ( tu && tu . statusmsg . length && tu . statusclearmode === 'auto' ) {
tu . statusmsg = '' ;
tu . statustype = '' ;
require ( '../util/siftstatuses' ) ( client , message . author . id , true ) ;
message . reply (
tu . statusSleeping
? tu . statussetat && ( new Date ( ) . getTime ( ) - tu . statussetat < 60 * 45 * 1000 )
? [
"Did you even sleep?! Well I cleared your status, but c'mon now!" ,
">:( That was hardly even sleep." ,
"You should really go back to bed." ,
"Burning the midnight oil are we? Go back to bed!"
] [ Math . floor ( Math . random ( ) * 4 ) ]
: [
"Good morning dear!" ,
"Heyo! Rise and shine!" ,
"Welcome! Hope you slept well." ,
"Good morning awesome wonderful person. Ready to start the day?"
] [ Math . floor ( Math . random ( ) * 4 ) ]
: 'Hey there! You asked me to clear your status when you send a message next, so I went ahead and did that for you.'
) . then ( m => { setTimeout ( ( ) => { m . delete ( ) . catch ( ( ) => { } ) ; } , 5000 ) ; } ) . catch ( ( ) => { } ) ;
if ( tu . statusSleeping ) {
tu . statusSleeping = false ; tu . markModified ( 'statusSleeping' ) ;
if ( tu . statussetat && ( new Date ( ) . getTime ( ) - tu . statussetat < 60 * 45 * 1000 ) ) { client . misc . cache . returnToSleep . set ( message . author . id , new Date ( ) . getTime ( ) ) ; }
}
tu . save ( ) ;
} } ) ;
if ( message . guild && client . misc . cache . rp . has ( message . guild . id ) && client . misc . cache . rp . get ( message . guild . id ) . includes ( message . channel . id ) ) {
if ( msg . match ( /^\w+:/m ) ) {
const rp = await RP . findOne ( { uid : message . author . id } ) ;
if ( rp && rp . chars [ msg . split ( ':' ) [ 0 ] ] ) {
const webhooks = await message . channel . fetchWebhooks ( ) ;
const webhook = await webhooks . find ( wh => wh . token ) ;
if ( webhook ) {
const char = rp . chars [ msg . split ( ':' ) [ 0 ] ] ;
webhook . send ( { content : message . content . slice ( char . prefix . length + 1 ) , avatarURL : char . image , username : char . name } ) . catch ( ( ) => { } ) ;
message . delete ( ) . catch ( ( ) => { } ) ;
}
}
}
}
if ( message . guild && client . misc . cache . ar . has ( message . guild . id ) && client . misc . cache . ar . get ( message . guild . id ) . includes ( msg . trim ( ) ) && ! ( client . misc . cache . arIgnore . has ( message . guild . id ) && client . misc . cache . arIgnore . get ( message . guild . id ) . includes ( message . channel . id ) ) ) {
AR . findOne ( { gid : message . guild . id } ) . then ( ar => {
if ( ar && ar . triggers . length && ar . triggers . includes ( msg . trim ( ) ) ) { return require ( '../util/response/filterresponse' ) ( message . member , client , ar . ars [ ar . triggers . indexOf ( msg . trim ( ) ) ] ) . then ( t => message . channel . send ( t ) . catch ( ( ) => { } ) ) . catch ( ( ) => { } ) ; }
} ) ;
}
if ( message . guild && client . misc . cache . lxp . enabled . includes ( message . guild . id ) ) {
if ( ! client . misc . cache . lxp . disabledChannels . has ( message . guild . id ) || ! client . misc . cache . lxp . disabledChannels . get ( message . guild . id ) . includes ( message . channel . id ) ) {
if ( ! client . misc . cache . lxp . xp [ message . guild . id ] ) { client . misc . cache . lxp . xp [ message . guild . id ] = { } ; }
if ( ! client . misc . cache . lxp . xp [ message . guild . id ] [ message . author . id ] ) {
LXP . findOne ( { gid : message . guild . id } ) . then ( xp => {
client . misc . cache . lxp . xp [ message . guild . id ] [ message . author . id ] = {
xp : xp . xp [ message . author . id ] ? xp . xp [ message . author . id ] [ 0 ] : 0 ,
level : xp . xp [ message . author . id ] ? xp . xp [ message . author . id ] [ 1 ] : 1 ,
lastXP : new Date ( ) . getTime ( ) - 60000
} ;
require ( '../util/lxp/gainxp' ) ( client , message . member . id , message . channel ) ;
} ) ;
}
else if ( new Date ( ) . getTime ( ) - client . misc . cache . lxp . xp [ message . guild . id ] [ message . author . id ] . lastXP > 60000 ) {
require ( '../util/lxp/gainxp' ) ( client , message . member . id , message . channel ) ;
}
}
}
if ( message . guild && client . misc . cache . chests . enabled . includes ( message . guild . id ) ) { require ( '../util/lxp/spawnchest' ) ( client , message . member , message . channel , prefix ) ; }
if ( ! client . misc . cache . monners [ message . author . id ] ) {
let tmonners = await Monners . findOne ( { uid : message . author . id } ) || new Monners ( { uid : message . author . id } ) ;
client . misc . cache . monners [ message . author . id ] = tmonners . currency ;
client . misc . cache . lastMonners [ message . author . id ] = new Date ( ) . getTime ( ) - ( 62 * 1000 ) ;
}
if ( message . guild && client . misc . cache . lastMonners [ message . author . id ] && new Date ( ) . getTime ( ) - client . misc . cache . lastMonners [ message . author . id ] > 60000 ) {
client . misc . cache . monners [ message . author . id ] += ( Math . floor (
( client . misc . cache . lxp . xp [ message . guild . id ] && client . misc . cache . lxp . xp [ message . guild . id ] [ message . author . id ]
? client . misc . cache . lxp . xp [ message . guild . id ] [ message . member . id ] . level
: 35 )
/ 3 5
) + 1 ) ;
client . misc . cache . lastMonners [ message . author . id ] = new Date ( ) . getTime ( ) ;
}
if ( message . guild && client . misc . cache . monitEnabled . includes ( message . guild . id ) ) {
if ( ! client . misc . cache . monit [ message . guild . id ] ) {
let tm = await Monitors . findOne ( { gid : message . guild . id } ) ;
client . misc . cache . monit [ tm . gid ] = {
messages : tm . messages ,
voice : tm . voice ,
expiry : new Date ( )
} ;
}
if ( ! client . misc . cache . monit ) { client . misc . cache . monit = { } ; }
if ( ! client . misc . cache . monit [ message . guild . id ] . messages . channels [ message . channel . id ] ) { client . misc . cache . monit [ message . guild . id ] . messages . channels [ message . channel . id ] = 0 ; }
if ( ! client . misc . cache . monit [ message . guild . id ] . messages . members [ message . author . id ] ) { client . misc . cache . monit [ message . guild . id ] . messages . members [ message . author . id ] = 0 ; }
client . misc . cache . monit [ message . guild . id ] . messages . channels [ message . channel . id ] += 1 ;
client . misc . cache . monit [ message . guild . id ] . messages . members [ message . author . id ] += 1 ;
client . misc . cache . monit [ message . guild . id ] . messages . total += 1 ;
client . misc . cache . monit [ message . guild . id ] . expiry . setTime ( Date . now ( ) ) ;
}
try {
if ( msg . startsWith ( prefix ) || msg . startsWith ( ` <@ ${ client . user . id } > ` ) || msg . startsWith ( ` <@! ${ client . user . id } > ` ) ) {
let command = client . commands . get ( cmd ) || client . commands . get ( client . aliases . get ( cmd ) ) ;
if ( command && command . name !== "blacklist" ) {
if ( message . guild && client . misc . cache . bl . guild . includes ( message . guild . id ) ) { return message . channel . send ( "Your server has been blacklisted from using my commands! Shame, tsk tsk" ) . catch ( ( ) => { } ) ; }
if ( client . misc . cache . bl . user . includes ( message . author . id ) ) { return message . channel . send ( "You've been blacklisted from using my commands! Now what'd ya do to deserve that??" ) . catch ( ( ) => { } ) ; }
}
if ( ! command ) { let trigger ; for ( trigger of client . responses . triggers ) { if ( await trigger [ 1 ] ( message , msg , args , cmd , prefix , mention , client ) ) { await client . responses . commands . get ( trigger [ 0 ] ) . execute ( message , msg , args , cmd , prefix , mention , client ) ; break ; } } return ; }
if ( message . guild && ! message . channel . permissionsFor ( client . user . id ) . has ( 'SEND_MESSAGES' ) ) { return message . author . send ( ` You tried to run the \` ${ command . name } \` command, but I don't seem to be able to send messages in <# ${ message . channel . id } >, so I can't do that! ` ) . catch ( ( ) => { } ) ; } ;
await message . channel . sendTyping ( ) . catch ( ( ) => { } ) ;
if ( ! require ( '../util/cooldownhandler' ) ( client , message , command ) ) { return ; }
if ( command . meta && command . meta . guildOnly && ! message . guild ) { return message . channel . send ( "You must be in a server to use this command!" ) . catch ( ( ) => { } ) ; }
require ( '../util/oncommand' ) ( message , msg , args , cmd , prefix , mention , client ) ;
if ( client . misc . loggers . cmds ) { client . misc . loggers . cmds . send ( ` ${ chalk . gray ( "[CMDL]" ) } >> ${ chalk . white ( "Command" ) } ${ chalk . blue ( command . name ) } ${ message . guild ? ` || ${ chalk . blue ( "Guild ID: " ) } ${ chalk . blueBright ( message . guild . id ) } ` : '' } || ${ chalk . blue ( "User ID: " ) } ${ chalk . blueBright ( message . author . id ) } ` ) ; }
return command . execute ( message , msg , args , cmd , prefix , mention , client ) ;
}
let trigger ; for ( trigger of client . responses . triggers ) { if ( await trigger [ 1 ] ( message , msg , args , cmd , prefix , mention , client ) ) { await client . responses . commands . get ( trigger [ 0 ] ) . execute ( message , msg , args , cmd , prefix , mention , client ) ; break ; } }
} catch ( e ) {
let date = new Date ( ) ; date = date . toString ( ) . slice ( date . toString ( ) . search ( ":" ) - 2 , date . toString ( ) . search ( ":" ) + 6 ) ;
console . error ( ` \n ${ chalk . red ( '[ERROR]' ) } >> ${ chalk . yellow ( ` At [ ${ date } ] | In ${ message . guild ? message . guild . name : ` a DM with ${ message . author . username } ` } \n ` ) } ` , e ) ;
}
} ;