/**************************************** * * AleeBot: Made for discord servers * Copyright (C) 2018 AleeCorp * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * * *************************************/ const Discord = require('discord.js'); const moment = require('moment'); const readline = require('readline'); const colors = require('colors'); const DBL = require("dblapi.js"); const client = new Discord.Client({ disableEveryone: true }); const settings = require('./storage/settings.json') const fs = require('fs'); const db = require('quick.db'); const log = message => { console.log(`[${moment().format('YYYY-MM-DD HH:mm:ss')}] ${message}`.white); }; const rl = readline.createInterface({ input: process.stdin, output: process.stdout, prompt: '> '.gray }); console.log(`AleeBot ${settings.abVersion}: Copyright (C) 2018 AleeCorp`.gray); console.log('This program comes with ABSOLUTELY NO WARRANTY; for details type `show w\'.'.gray); console.log ('This is free software, and you are welcome to redistribute it'.gray); console.log ('under certain conditions; type `show c\' for details.\n'.gray) if (process.argv.indexOf("--debug") == -1) { console.log("Running AleeBot without --debug command line flag. Debug output disabled.\n".yellow); } else { console.log('[!] Entering debug mode...'.yellow) client.on('debug', function(info) { log(info.gray); }); client.on('warn', function(info) { log(info.red); }); } client.commands = new Discord.Collection(); client.aliases = new Discord.Collection(); fs.readdir('./commands', (err, files) => { if (err) console.error(err); log(`[!] Attempting to load a total of ${files.length} commands into the memory.`.cyan); files.forEach(file => { try { const command = require(`./commands/${file}`); log(`[!] Attempting to load the command "${command.help.name}".`.cyan); client.commands.set(command.help.name, command); command.conf.aliases.forEach(alias => { client.aliases.set(alias, command.help.name); log(`[!] Attempting to load "${alias}" as an alias for "${command.help.name}"`.cyan); }); } catch (err) { log('[X] An error has occured trying to load a command. Here is the error.'.red); console.log(err.stack); } }); log('[>] Command Loading complete!'.green); console.log('\n'); }); client.on('ready', () => { log('[>] AleeBot is now ready!'.green); log(`[i] Logged in as ${client.user.tag}`.green); log(`[i] Default Prefix: ${settings.prefix}`.green) log(`[i] Bot ID: ${client.user.id}`.green); log(`[i] Token: ${api.abtoken}`.green); log(`[i] Running version ${settings.abVersion} and in ${client.guilds.size} guilds`.green); client.setInterval(function() { const games = [ 'AleeBot ' + settings.abVersion + ' | ' + settings.prefix + 'help', 'Annoying Alee', 'Coding stuff', 'Drawing shapes', 'Fighting AstralMod', ]; setInterval(() => { dbl.postStats(client.guilds.size, client.shards.Id, client.shards.total); }, 1800000); db.createWebview('password', 3000); client.user.setPresence({ status: 'online', afk: false, game: { type: 0, name: games[Math.floor(Math.random() * games.length)], }, }); }, 200000); client.user.setStatus('online'); }); client.on('guildCreate', guild => { log(`[i] New guild joined: ${guild.name} (id: ${guild.id}). This guild has ${guild.memberCount} members!`.blue); }); client.on('guildDelete', guild => { log(`[i] I have been removed from: ${guild.name} (id: ${guild.id})`.red); }); client.on('message', (msg) => { if (msg.author.bot) return; let prefixes = JSON.parse(fs.readFileSync("./storage/prefixes.json", "utf8")); if(!prefixes[msg.guild.id]){ prefixes[msg.guild.id] = { prefixes: settings.prefix }; } let prefix = prefixes[msg.guild.id].prefixes if (!msg.content.startsWith(prefix)) return; const args = msg.content.slice(prefix.length).trim().split(/ +/g); const command = args.shift(); let cmd; if (client.commands.has(command)) { cmd = client.commands.get(command); } else if (client.aliases.has(command)) { cmd = client.commands.get(client.aliases.get(command)); } if (cmd) { if (cmd.conf.guildOnly == true) { if (!msg.channel.guild) { return msg.channel.createMessage('This command can only be ran in a guild.'); } } try { cmd.run(client, msg, args); } catch (e) { console.error(e); } } }); process.on('unhandledRejection', function(err, p) { log("[X | UNCAUGHT PROMISE] " + err.stack.red); }); process.on('uncaughtException', function (exception) { log(exception.red); });