2017-09-30 01:21:48 +02:00
// Check for environmental variables.
require ( 'checkenv' ) . check ( ) ;
2017-08-03 03:48:16 +02:00
const discord = require ( 'discord.js' ) ;
const fs = require ( 'fs' ) ;
const path = require ( 'path' ) ;
const schedule = require ( 'node-schedule' ) ;
2016-12-08 04:52:37 +01:00
2017-08-03 03:48:16 +02:00
const logger = require ( './logging.js' ) ;
const app = require ( './app.js' ) ;
const data = require ( './data.js' ) ;
2016-12-08 04:52:37 +01:00
2017-09-30 01:21:48 +02:00
var responses = require ( './data/responses.json' ) ;
2016-12-08 04:52:37 +01:00
var cachedModules = [ ] ;
2016-12-31 06:49:12 +01:00
var cachedTriggers = [ ] ;
2016-12-08 04:52:37 +01:00
var client = new discord . Client ( ) ;
2017-09-24 21:44:49 +02:00
process . on ( 'unhandledRejection' , function onError ( err ) {
logger . error ( err ) ;
} ) ;
2016-12-08 04:52:37 +01:00
function findArray ( haystack , arr ) {
return arr . some ( function ( v ) {
return haystack . indexOf ( v ) >= 0 ;
} ) ;
} ;
client . on ( 'ready' , ( ) => {
// Initalize app channels.
2017-09-30 01:21:48 +02:00
app . logChannel = client . channels . get ( process . env . DISCORD _LOG _CHANNEL ) ;
2016-12-08 04:52:37 +01:00
app . guild = app . logChannel . guild ;
2017-03-31 03:17:21 +02:00
logger . info ( 'Bot is now online and connected to server.' ) ;
2016-12-08 04:52:37 +01:00
} ) ;
2017-07-20 03:45:58 +02:00
client . on ( "guildMemberAdd" , ( member ) => {
app . stats . joins += 1 ;
} ) ;
client . on ( "guildMemberRemove" , ( member ) => {
app . stats . leaves += 1 ;
} ) ;
// Output the stats for app.stats every 24 hours.
2017-07-20 04:05:02 +02:00
// Server is in UTC mode, 11:30 EST would be 03:30 UTC.
schedule . scheduleJob ( { hour : 3 , minute : 30 } , function ( ) {
2017-07-20 03:45:58 +02:00
logger . info ( ` Here are today's stats for ${ ( new Date ( ) ) . toLocaleDateString ( ) } ! ${ app . stats . joins } users have joined, ${ app . stats . leaves } users have left, ${ app . stats . warnings } warnings have been issued. ` ) ;
app . logChannel . sendMessage ( ` Here are today's stats for ${ ( new Date ( ) ) . toLocaleDateString ( ) } ! ${ app . stats . joins } users have joined, ${ app . stats . leaves } users have left, ${ app . stats . warnings } warnings have been issued. ` ) ;
// Clear the stats for the day.
app . stats . joins = 0 ;
app . stats . leaves = 0 ;
app . stats . warnings = 0 ;
} ) ;
2016-12-08 04:52:37 +01:00
client . on ( 'message' , message => {
if ( message . author . bot && message . content . startsWith ( '.ban' ) == false ) { return ; }
2017-09-30 01:21:48 +02:00
if ( message . guild == null && responses . pmReply ) {
2016-12-08 04:52:37 +01:00
// We want to log PM attempts.
logger . info ( ` ${ message . author . username } ${ message . author } [PM]: ${ message . content } ` ) ;
app . logChannel . sendMessage ( ` ${ message . author } [PM]: ${ message . content } ` ) ;
2017-09-30 01:21:48 +02:00
message . reply ( responses . pmReply ) ;
2016-12-08 04:52:37 +01:00
return ;
}
2017-07-09 05:53:01 +02:00
logger . verbose ( ` ${ message . author . username } ${ message . author } [Channel: ${ message . channel . name } ${ message . channel } ]: ${ message . content } ` ) ;
2016-12-08 04:52:37 +01:00
2017-09-30 01:21:48 +02:00
if ( message . content . startsWith ( '.' ) ) {
2016-12-08 04:52:37 +01:00
let cmd = message . content . split ( ' ' ) [ 0 ] . slice ( 1 ) ;
// Check by the name of the command.
let cachedModule = cachedModules [ ` ${ cmd } .js ` ] ;
let cachedModuleType = 'Command' ;
// Check by the quotes in the configuration.
2017-09-30 01:21:48 +02:00
if ( cachedModule == null ) { cachedModule = responses . quotes [ cmd ] ; cachedModuleType = 'Quote' ; }
2016-12-08 04:52:37 +01:00
if ( cachedModule ) {
// Check access permissions.
if ( cachedModule . roles != undefined && findArray ( message . member . roles . map ( function ( x ) { return x . name ; } ) , cachedModule . roles ) == false ) {
app . logChannel . sendMessage ( ` ${ message . author } attempted to use admin command: ${ message . content } ` ) ;
2017-08-03 01:11:05 +02:00
logger . info ( ` ${ message . author . username } ${ message . author } attempted to use admin command: ${ message . content } ` ) ;
2016-12-08 04:52:37 +01:00
return false ;
}
2017-03-31 03:29:52 +02:00
logger . info ( ` ${ message . author . username } ${ message . author } [Channel: ${ message . channel } ] executed command: ${ message . content } ` ) ;
2016-12-08 04:52:37 +01:00
message . delete ( ) ;
2017-01-15 18:37:43 +01:00
try {
if ( cachedModuleType == 'Command' ) {
cachedModule . command ( message ) ;
} else if ( cachedModuleType == 'Quote' ) {
cachedModules [ 'quote.js' ] . command ( message , cachedModule . reply ) ;
}
} catch ( err ) { logger . error ( err ) ; }
2016-12-08 04:52:37 +01:00
2017-04-08 01:33:03 +02:00
// Warn after running command?
2017-01-15 18:37:43 +01:00
try {
// Check if the command requires a warning.
if ( cmd != 'warn' && cachedModule . warn == true ) {
2017-04-08 01:33:03 +02:00
// Access check to see if the user has privilages to warn.
let warnCommand = cachedModules [ 'warn.js' ] ;
if ( findArray ( message . member . roles . map ( function ( x ) { return x . name ; } ) , warnCommand . roles ) ) {
// They are allowed to warn because they are in warn's roles.
warnCommand . command ( message ) ;
}
2017-01-15 18:37:43 +01:00
}
} catch ( err ) { logger . error ( err ) ; }
2017-04-08 01:33:03 +02:00
2016-12-08 04:52:37 +01:00
} else {
// Not a valid command.
}
2017-01-29 21:50:10 +01:00
} else if ( message . author . bot == false ) {
2016-12-31 06:49:12 +01:00
// This is a normal channel message.
cachedTriggers . forEach ( function ( trigger ) {
if ( trigger . roles == undefined || findArray ( message . member . roles . map ( function ( x ) { return x . name ; } ) , trigger . roles ) ) {
if ( trigger . trigger ( message ) == true ) {
2017-08-03 01:11:05 +02:00
logger . debug ( ` ${ message . author . username } ${ message . author } [Channel: ${ message . channel } ] triggered: ${ message . content } ` ) ;
2017-01-15 18:37:43 +01:00
try {
trigger . execute ( message ) ;
} catch ( err ) { logger . error ( err ) ; }
2016-12-31 06:49:12 +01:00
}
}
} ) ;
2016-12-08 04:52:37 +01:00
}
2017-03-31 03:17:21 +02:00
} ) ;
2016-12-08 04:52:37 +01:00
2017-03-31 03:17:21 +02:00
// Cache all command modules.
2017-03-31 03:18:23 +02:00
cachedModules = [ ] ;
2017-03-31 03:17:21 +02:00
require ( "fs" ) . readdirSync ( './commands/' ) . forEach ( function ( file ) {
// Load the module if it's a script.
if ( path . extname ( file ) == '.js' ) {
2017-04-08 01:36:45 +02:00
if ( file . includes ( '.disabled' ) ) {
logger . info ( ` Did not load disabled module: ${ file } ` ) ;
} else {
logger . info ( ` Loaded module: ${ file } ` ) ;
cachedModules [ file ] = require ( ` ./commands/ ${ file } ` ) ;
}
2017-03-31 03:17:21 +02:00
}
2016-12-08 04:52:37 +01:00
} ) ;
2017-03-31 03:17:21 +02:00
// Cache all triggers.
2017-03-31 03:18:23 +02:00
cachedTriggers = [ ] ;
2017-03-31 03:17:21 +02:00
require ( "fs" ) . readdirSync ( './triggers/' ) . forEach ( function ( file ) {
// Load the trigger if it's a script.
if ( path . extname ( file ) == '.js' ) {
2017-04-08 01:36:45 +02:00
if ( file . includes ( '.disabled' ) ) {
logger . info ( ` Did not load disabled trigger: ${ file } ` ) ;
} else {
logger . info ( ` Loaded trigger: ${ file } ` ) ;
cachedTriggers . push ( require ( ` ./triggers/ ${ file } ` ) ) ;
}
2017-03-31 03:17:21 +02:00
}
} ) ;
data . readWarnings ( ) ;
data . readBans ( ) ;
2017-09-30 01:21:48 +02:00
client . login ( process . env . DISCORD _LOGIN _TOKEN ) ;
2017-09-24 21:44:49 +02:00
logger . info ( 'Startup completed. Established connection to Discord.' ) ;