require('dotenv').config(); const { XIAO_TOKEN, OWNERS, XIAO_PREFIX, INVITE } = process.env; const path = require('path'); const Client = require('./structures/Client'); const client = new Client({ commandPrefix: XIAO_PREFIX, owner: OWNERS.split(','), invite: INVITE, disableMentions: 'everyone', disabledEvents: ['TYPING_START'] }); const { formatNumber } = require('./util/Util'); client.registry .registerDefaultTypes() .registerTypesIn(path.join(__dirname, 'types')) .registerGroups([ ['util', 'Utility'], ['info', 'Discord Information'], ['random-res', 'Random Response'], ['random-img', 'Random Image'], ['random-seed', 'Seeded Randomizers'], ['single', 'Single Response'], ['auto', 'Automatic Response'], ['events', 'Events'], ['search', 'Search'], ['analyze', 'Analyzers'], ['games-sp', 'Single-Player Games'], ['games-mp', 'Multi-Player Games'], ['edit-image', 'Image Manipulation'], ['edit-avatar', 'Avatar Manipulation'], ['edit-meme', 'Meme Generators'], ['edit-text', 'Text Manipulation'], ['edit-number', 'Number Manipulation'], ['voice', 'Voice-Based'], ['other', 'Other'], ['roleplay', 'Roleplay'], ['readme', 'README Generators'] ]) .registerDefaultCommands({ help: false, ping: false, prefix: false, commandState: false, unknownCommand: false }) .registerCommandsIn(path.join(__dirname, 'commands')); client.on('ready', () => { client.logger.info(`[READY] Logged in as ${client.user.tag}! ID: ${client.user.id}`); client.activities.push( { text: () => `${formatNumber(client.guilds.cache.size)} servers`, type: 'WATCHING' }, { text: () => `with ${formatNumber(client.registry.commands.size)} commands`, type: 'PLAYING' }, { text: () => `${formatNumber(client.users.cache.size)} users`, type: 'WATCHING' }, { text: () => `${formatNumber(client.channels.cache.size)} channels`, type: 'WATCHING' } ); client.setInterval(() => { const activity = client.activities[Math.floor(Math.random() * client.activities.length)]; const text = typeof activity.text === 'function' ? activity.text() : activity.text; client.user.setActivity(text, { type: activity.type }); }, 60000); if (client.memePoster.id && client.memePoster.token) { client.setInterval(() => client.memePoster.post(), client.memePoster.time); } }); client.on('message', async msg => { if (!msg.channel.topic || !msg.channel.topic.includes('')) return; const hasText = Boolean(msg.content); const hasImage = msg.attachments.size !== 0; const hasEmbed = msg.embeds.length !== 0; if (msg.author.bot || (!hasText && !hasImage && !hasEmbed)) return; const origin = client.phone.find(call => call.origin.id === msg.channel.id); const recipient = client.phone.find(call => call.recipient.id === msg.channel.id); if (!origin && !recipient) return; const call = origin || recipient; if (!call.active) return; try { await call.send(origin ? call.recipient : call.origin, msg, hasText, hasImage, hasEmbed); } catch { return; // eslint-disable-line no-useless-return } }); client.on('guildMemberRemove', async member => { if (member.id === client.user.id) return null; const channel = member.guild.systemChannel; if (!channel || !channel.permissionsFor(client.user).has('SEND_MESSAGES')) return null; if (channel.topic && channel.topic.includes('')) return null; try { const leaveMessage = client.leaveMessages[Math.floor(Math.random() * client.leaveMessages.length)]; await channel.send(leaveMessage.replace(/{{user}}/gi, `**${member.user.tag}**`)); return null; } catch { return null; } }); client.on('disconnect', event => { client.logger.error(`[DISCONNECT] Disconnected with code ${event.code}.`); process.exit(0); }); client.on('error', err => client.logger.error(err.stack)); client.on('warn', warn => client.logger.warn(warn)); client.on('commandError', (command, err) => client.logger.error(`[COMMAND:${command.name}]\n${err.stack}`)); client.login(XIAO_TOKEN);