|
|
|
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());
|