You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Natsuki/events/messageCreate.js

179 lines
12 KiB

const Discord = require('discord.js');
const chalk = require('chalk');
const wait = require('../util/wait');
const UserData = require('../models/user');
const AR = require('../models/ar');
const LXP = require('../models/localxp');
const Monitors = require('../models/monitor');
const Monners = require('../models/monners');
3 years ago
const RP = require('../models/rpch');
const channelTypes = ["GUILD_MESSAGE", "DM", "GUILD_NEWS_THREAD", "GUILD_PRIVATE_THREAD", "GUILD_PUBLIC_THREAD", "GUILD_NEWS", "GROUP_DM", "GUILD_STORE", "GUILD_TEXT"];
3 years ago
module.exports = async (client, message) => {
if (!client.misc.fullyReady) {return;}
3 years ago
if (message.partial) {await message.fetch();}
if (message.channel.partial) {await message.channel.fetch();}
if (!message.author || message.author.bot) {return undefined;}
3 years ago
if (!channelTypes.includes(message.channel.type)) {return undefined;}
if (message.guild && !message.member.permissions.has("SEND_MESSAGES")) {return undefined;}
let defaultPrefix = client.misc.config.dev ? 'n!' : 'n?';
let prefix = message.guild ? client.guildconfig.prefixes.has(message.guild.id) ? client.guildconfig.prefixes.get(message.guild.id) !== null ? client.guildconfig.prefixes.get(message.guild.id) : defaultPrefix : defaultPrefix : defaultPrefix;
let msg = message.content.toLowerCase().replace('\u200E', '');
let mention = message.mentions.users.first();
let args = msg.startsWith(prefix)
? message.content.slice(prefix.length).trim().replace('\u200E', '').split(/\s+/g)
: msg.startsWith('<@!')
? message.content.slice(4 + client.user.id.length).trim().replace('\u200E', '').split(/\s+/g)
: message.content.slice(3 + client.user.id.length).trim().replace('\u200E', '').split(/\s+/g);
let cmd = args.shift().toLowerCase().trim();
message.misc = {mn: message.guild ? (client.misc.cache.monnersNames.get(message.guild.id) || 'Monners') : 'Monners'};
4 years ago
if (message.content.includes("@everyone")) {return;}
if ([`<@${client.user.id}>`, `<@!${client.user.id}>`].includes(msg)) {
3 years ago
return message.channel.send({embeds: [new Discord.MessageEmbed()
.setTitle(["Yep, that's me!", "^^ Hiya!", "Oh, hi there!", "Sure, what's up?", "How can I help!", "Natsuki is busy, but I can take a message for you!", "Teehee that's me!", "You were looking for Natsuki Tivastl, right?", "Sure! What's up?", "Pong!"][Math.floor(Math.random() * 10)])
.setDescription(`My prefix here is \`${prefix}\`. Use \`${prefix}help\` to see what commands you can use.`)
3 years ago
.setColor('c375f0')]}).catch(() => {});
}
if (mention && message.guild) {require('../util/mention')(message, msg, args, cmd, prefix, mention, client);}
UserData.findOne({uid: message.author.id}).then(async (tu) => {
if (tu && tu.statusmsg.length && tu.statusclearmode === 'auto') {
tu.statusmsg = '';
tu.statustype = '';
require('../util/siftstatuses')(client, message.author.id, true);
3 years ago
message.reply(
tu.statusSleeping
? tu.statussetat && (new Date().getTime() - tu.statussetat < 60 * 45 * 1000)
? [
"Did you even sleep?! Well I cleared your status, but c'mon now!",
">:( That was hardly even sleep.",
"You should really go back to bed.",
"Burning the midnight oil are we? Go back to bed!"
][Math.floor(Math.random() *4)]
: [
"Good morning dear!",
"Heyo! Rise and shine!",
"Welcome! Hope you slept well.",
"Good morning awesome wonderful person. Ready to start the day?"
][Math.floor(Math.random() *4)]
: 'Hey there! You asked me to clear your status when you send a message next, so I went ahead and did that for you.'
).then(m => {setTimeout(() => {m.delete().catch(() => {});}, 5000);}).catch(() => {});
if (tu.statusSleeping) {
tu.statusSleeping = false; tu.markModified('statusSleeping');
if (tu.statussetat && (new Date().getTime() - tu.statussetat < 60 * 45 * 1000)) {client.misc.cache.returnToSleep.set(message.author.id, new Date().getTime());}
}
tu.save();
}});
3 years ago
if (message.guild && client.misc.cache.rp.has(message.guild.id) && client.misc.cache.rp.get(message.guild.id).includes(message.channel.id)) {
if (msg.match(/^\w+:/m)) {
const rp = await RP.findOne({uid: message.author.id});
if (rp && rp.chars[msg.split(':')[0]]) {
const webhooks = await message.channel.fetchWebhooks();
const webhook = await webhooks.find(wh => wh.token);
if (webhook) {
const char = rp.chars[msg.split(':')[0]];
webhook.send({content: message.content.slice(char.prefix.length + 1), avatarURL: char.image, username: char.name}).catch(() => {});
message.delete().catch(() => {});
}
}
}
3 years ago
}
if (message.guild && client.misc.cache.ar.has(message.guild.id) && client.misc.cache.ar.get(message.guild.id).includes(msg.trim()) && !(client.misc.cache.arIgnore.has(message.guild.id) && client.misc.cache.arIgnore.get(message.guild.id).includes(message.channel.id))) {
AR.findOne({gid: message.guild.id}).then(ar => {
3 years ago
if (ar && ar.triggers.length && ar.triggers.includes(msg.trim())) {return message.channel.send(require('../util/response/filterresponse')(message.member, client, ar.ars[ar.triggers.indexOf(msg.trim())])).catch(() => {});}
});
}
if (message.guild && client.misc.cache.lxp.enabled.includes(message.guild.id)) {
3 years ago
if (!client.misc.cache.lxp.disabledChannels.has(message.guild.id) || !client.misc.cache.lxp.disabledChannels.get(message.guild.id).includes(message.channel.id)) {
if (!client.misc.cache.lxp.xp[message.guild.id]) {client.misc.cache.lxp.xp[message.guild.id] = {};}
if (!client.misc.cache.lxp.xp[message.guild.id][message.author.id]) {
LXP.findOne({gid: message.guild.id}).then(xp => {
client.misc.cache.lxp.xp[message.guild.id][message.author.id] = {
xp: xp.xp[message.author.id] ? xp.xp[message.author.id][0] : 0,
level: xp.xp[message.author.id] ? xp.xp[message.author.id][1] : 1,
lastXP: new Date().getTime() - 60000
};
3 years ago
require('../util/lxp/gainxp')(client, message.member.id, message.channel);
});
}
3 years ago
else if (new Date().getTime() - client.misc.cache.lxp.xp[message.guild.id][message.author.id].lastXP > 60000) {
require('../util/lxp/gainxp')(client, message.member.id, message.channel);
}
}
}
if (message.guild && client.misc.cache.chests.enabled.includes(message.guild.id)) {require('../util/lxp/spawnchest')(client, message.member, message.channel, prefix);}
if (!client.misc.cache.monners[message.author.id]) {
let tmonners = await Monners.findOne({uid: message.author.id}) || new Monners({uid: message.author.id});
client.misc.cache.monners[message.author.id] = tmonners.currency;
client.misc.cache.lastMonners[message.author.id] = new Date().getTime() - (62 * 1000);
}
if (message.guild && client.misc.cache.lastMonners[message.author.id] && new Date().getTime() - client.misc.cache.lastMonners[message.author.id] > 60000) {
client.misc.cache.monners[message.author.id] += (Math.floor(
(client.misc.cache.lxp.xp[message.guild.id] && client.misc.cache.lxp.xp[message.guild.id][message.author.id]
? client.misc.cache.lxp.xp[message.guild.id][message.member.id].level
: 35)
/ 35
) + 1);
client.misc.cache.lastMonners[message.author.id] = new Date().getTime();
}
if (message.guild && client.misc.cache.monitEnabled.includes(message.guild.id)) {
if (!client.misc.cache.monit[message.guild.id]) {
let tm = await Monitors.findOne({gid: message.guild.id});
client.misc.cache.monit[tm.gid] = {
messages: tm.messages,
voice: tm.voice,
expiry: new Date()
};
}
if (!client.misc.cache.monit) {client.misc.cache.monit = {};}
if (!client.misc.cache.monit[message.guild.id].messages.channels[message.channel.id]) {client.misc.cache.monit[message.guild.id].messages.channels[message.channel.id] = 0;}
if (!client.misc.cache.monit[message.guild.id].messages.members[message.author.id]) {client.misc.cache.monit[message.guild.id].messages.members[message.author.id] = 0;}
client.misc.cache.monit[message.guild.id].messages.channels[message.channel.id] += 1;
client.misc.cache.monit[message.guild.id].messages.members[message.author.id] += 1;
client.misc.cache.monit[message.guild.id].messages.total += 1;
client.misc.cache.monit[message.guild.id].expiry.setTime(Date.now());
}
try {
if (msg.startsWith(prefix) || msg.startsWith(`<@${client.user.id}>`) || msg.startsWith(`<@!${client.user.id}>`)) {
let command = client.commands.get(cmd) || client.commands.get(client.aliases.get(cmd));
if (command && command.name !== "blacklist") {
3 years ago
if (message.guild && client.misc.cache.bl.guild.includes(message.guild.id)) {return message.channel.send("Your server has been blacklisted from using my commands! Shame, tsk tsk").catch(() => {});}
if (client.misc.cache.bl.user.includes(message.author.id)) {return message.channel.send("You've been blacklisted from using my commands! Now what'd ya do to deserve that??").catch(() => {});}
}
if (!command) {let trigger; for (trigger of client.responses.triggers) {if (await trigger[1](message, msg, args, cmd, prefix, mention, client)) {await client.responses.commands.get(trigger[0]).execute(message, msg, args, cmd, prefix, mention, client); break;}} return;}
3 years ago
if (message.guild && !message.channel.permissionsFor(client.user.id).has('SEND_MESSAGES')) {return message.author.send(`You tried to run the \`${command.name}\` command, but I don't seem to be able to send messages in <#${message.channel.id}>, so I can't do that!`).catch(() => {});};
3 years ago
await message.channel.sendTyping().catch(() => {});
if (!require('../util/cooldownhandler')(client, message, command)) {return;}
3 years ago
if (command.meta && command.meta.guildOnly && !message.guild) {return message.channel.send("You must be in a server to use this command!").catch(() => {});}
require('../util/oncommand')(message, msg, args, cmd, prefix, mention, client);
if (client.misc.loggers.cmds) {client.misc.loggers.cmds.send(`${chalk.gray("[CMDL]")} >> ${chalk.white("Command")} ${chalk.blue(command.name)} ${message.guild ? `|| ${chalk.blue("Guild ID: ")} ${chalk.blueBright(message.guild.id)}` : ''} || ${chalk.blue("User ID: ")} ${chalk.blueBright(message.author.id)}`);}
return command.execute(message, msg, args, cmd, prefix, mention, client);
}
let trigger; for (trigger of client.responses.triggers) {if (await trigger[1](message, msg, args, cmd, prefix, mention, client)) {await client.responses.commands.get(trigger[0]).execute(message, msg, args, cmd, prefix, mention, client); break;}}
} 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}] | In ${message.guild ? message.guild.name : `a DM with ${message.author.username}`}\n`)}`, e);
}
};