const Discord = require('discord.js'); const spinnies = require('dreidels'); const gs = require('gradient-string'); const chalk = require('chalk'); const ora = require('ora'); const mongoose = require('mongoose'); const readline = require('readline'); const {SlashManager} = require('./util/slashmanager'); const {Tag} = require('./util/tag'); const {TagFilter} = require('./util/tagfilter'); const wait = require('./util/wait'); const flags = Discord.Intents.FLAGS; let fl = []; Object.keys(flags).forEach(flag => fl.push(flags[flag])); let client = new Discord.Client({intents: fl, partials: ["CHANNEL", "REACTION", "MESSAGE"]}); let botReadyResolver; client.misc = { savers: ['497598953206841375', '480535078150340609', '468903364533420074'], activeDMs: new Discord.Collection(), statusPings: new Discord.Collection(), startup: new Date(), startupNoConnect: null, cache: { ar: new Map(), arIgnore: new Map(), bl: { guild: [], user: [] }, lxp: { enabled: [], xp: {}, hasLevelRoles: [], disabledChannels: new Map() }, chestsTimeout: new Map(), chests: { enabled: [], timeout: new Map(), waiting: new Map() }, monit: {}, monitEnabled: [], inVC: [], VCG: {}, activeVC: [], chars: new Discord.Collection(), anime: new Discord.Collection(), charsID: new Discord.Collection(), animeID: new Discord.Collection(), charsNum: 0, charsLove: new Discord.Collection(), monners: {}, lastMonners: {}, monnersNames: new Map(), spin: new spinnies(), rp: new Map(), returnToSleep: new Map(), marriageRequests: new Discord.Collection() }, loggers: {}, rl: readline.createInterface({input: process.stdin, output: process.stdout}), cooldown: new Discord.Collection(), config: { nocli: false, dev: false, logs: 'normal', lightstartup: false, ignorecmds: [], gradients: false, spinners: false }, botFinished: new Promise(r => {botReadyResolver = r;}), fullyReady: false }; let waitAmount = 1000 * 10; function testConnection() { return new Promise(async r => { require('dns').lookup('www.google.com', async e => { if (e) { await wait(waitAmount); waitAmount *= 2; await testConnection(); r(); } else {r();} }) }); } const auth = require('./auth.json'); async function init() { const cliargs = new TagFilter([ new Tag(['cli', 'c', 'nc', 'nocli'], 'nocli', 'toggle'), new Tag(['dev', 'd', 'development', 'test'], 'dev', 'toggle'), new Tag(['logs', 'l', 'loglevel', 'll'], 'logs', 'append'), new Tag(['lightstart', 'lightstartup', 'ls'], 'lightstartup', 'toggle'), new Tag(['i', 'ignore', 'icmd', 'ignorecmd'], 'ignorecmds', 'listAppend'), new Tag(['g', 'gradient', 'gradients'], 'gradients', 'toggle'), new Tag(['s', 'sp', 'spinners', 'spin'], 'spinners', 'toggle') ]).test(process.argv.slice(2).join(" ")); if (Object.keys(cliargs).length) { console.log(`${chalk.gray('[ARGS]')} >> ${chalk.gray.bold("Arguments detected.\n")}`); Object.keys(cliargs).forEach(arg => { client.misc.config[arg] = cliargs[arg]; console.log(`${chalk.gray('[ARGS]')} >> ${chalk.gray.bold(arg)}${chalk.gray(':')} ${chalk.blue(cliargs[arg])}`); }); console.log(''); } let cloginsp = ora(chalk.magentaBright('Connecting Discord client...')).start(); let pclc = new Date().getTime(); await client.login(auth.token); cloginsp.stop(); cloginsp.clear(); console.log(`${chalk.green('[BOOT]')} >> ${chalk.greenBright(`Connected to Discord in `)}${chalk.white(`${new Date().getTime() - pclc}ms`)}`); client.misc.startupNoConnect = new Date(); client.config = auth; let mloginsp = ora(chalk.magentaBright('Connecting to Mongo client...')).start(); let pmcc = new Date().getTime(); const config = client.config; try { await mongoose.connect(`mongodb+srv://${config.database.user}:${config.database.password}@${config.database.cluster}.3jpp4.mongodb.net/test`, { useFindAndModify: false, useNewUrlParser: true, dbName: 'Natsuki-Main', useUnifiedTopology: true, useCreateIndex: true }).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}] | Occurred while trying to connect to Mongo Cluster`)}`, e); mloginsp.stop(); mloginsp.clear(); }); mloginsp.stop(); mloginsp.clear(); console.log(`${chalk.green('[BOOT]')} >> ${chalk.greenBright(`Connected to Mongo Database in `)}${chalk.white(`${new Date().getTime() - pmcc}ms`)}`); } 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}] | Occurred while trying to connect to Mongo Cluster`)}`, e); mloginsp.stop(); mloginsp.clear(); } client.developers = ["330547934951112705", "673477059904929802"]; client.utils = {}; client.utils.s = num => num === 1 ? '' : 's'; client.utils.as = (num, text) => `${text}${client.utils.s(num)}`; client.utils.an = (text, caps) => `${caps ? 'A' : 'a'}${['a', 'e', 'i', 'o', 'u'].includes(text.toLowerCase().trim().slice(0, 1)) ? 'n' : ''} ${text}`; client.utils.c = (text, a=true) => `${text.slice(0, 1).toUpperCase()}${a ? text.slice(1).toLowerCase() : text.slice(1)}`; client.utils.ca = (text, a=true) => text.split(/\s+/gm).map(t => client.utils.c(t, a)).join(" "); client.utils.sm = (mpr, ago=true) => `${mpr.years ? `${mpr.years} year${client.utils.s(mpr.years)} ` : ''}${mpr.months ? `${mpr.months} month${client.utils.s(mpr.months)} ` : ''}${mpr.days} day${client.utils.s(mpr.days)}${ago ? ' ago' : ''}`; client.utils.p = (text) => text.endsWith('s') ? "'" : "'s"; client.utils.ps = (text) => `${text}${client.utils.p(text)}`; ['commands', 'aliases', 'executables'].forEach(x => client[x] = new Discord.Collection()); client.responses = {triggers: [], commands: new Discord.Collection()}; let iters = ['command', 'event', 'response']; if (client.misc.config.spinners) { console.log(''); client.misc.cache.spinLog = []; iters.map(i => `Loading ${i.slice(0, 1).toUpperCase()}${i.slice(1)}s`) .map(i => client.misc.config.gradients ? gs.instagram(i) : chalk.blue(i)) .forEach((i, ind) => client.misc.cache.spin.add(iters[ind], {text: i})); } for (let i = 0; i < iters.length; i++) {let x = iters[i]; await require(`./handle/${x}`)(client);} const spl = client.misc.config.spinners ? (i) => client.misc.cache.spinLog.push(i) : (i) => console.log(i); spl(`\n${chalk.gray('[BOOT]')} >> ${chalk.blue('Getting Slash Commands...')}\n`); client.slash = new SlashManager(client) .setTestServer('691122844339404800') .importCommands(false, undefined, (cmd) => spl(`${chalk.gray('[LOAD]')} >> ${chalk.blueBright('Loaded Slash Command')} ${chalk.white(cmd.name)}`)) .init(); if (client.misc.config.dev) {await client.slash.devRegister();} else {await client.slash.register();} client = client.slash.client; spl(`\n${chalk.gray('[BOOT]')} >> ${chalk.blue('Loaded all Slash Commands')}`); if (client.misc.config.spinners) { client.misc.cache.spinLog.forEach(log => console.log(log)); } if (!client.misc.config.nocli) {require('./handle/console')(client);} client.utils.logch = async () => {return client.guilds.cache.get('762707532417335296').channels.cache.get('762732961753595915');}; client.guildconfig = {}; client.guildconfig.prefixes = new Map(); client.guildconfig.logs = new Map(); botReadyResolver(0); await require('./util/wait')(5000); if (!client.misc.readied) {client.misc.forcedReady = true; await require('./events/ready')(client);} } testConnection().then(() => init());