thaldrin/src/discord/events/message.ts

145 lines
6.6 KiB
TypeScript

// @ts-nocheck
import { Client, Collection, Message, MessageEmbed } from "discord.js";
import Logger from "../../utils/logger";
import supabase from "../../utils/database";
import { Command, Server, Usage } from "../../utils/types";
import config from "../../../config";
import { Commands, Shortlink, SourceFinder } from "../../utils/wrapper.features";
import mod from "../../utils/database";
import language from "../../utils/language";
import replace from "../../utils/replace";
import chalk from "chalk";
// import Prom from "../utils/init.prometheus";
export = {
name: "message",
run: async (client: Client, message: Message) => {
// Prom.messagesSeen.inc()
if (message.author.bot) return
if (message.channel.type === "dm") return
// // ! Messages seen
// let { data: usage_data, error: usage_error } = await supabase.from<Usage>("usage").select().eq('name', "message")
// if (usage_data?.length === 0) {
// let { data: a, error: b } = await supabase.from<Usage>("usage").insert({ name: "message", type: "event" }).select()
// usage_data = a
// }
// let { data: updated_usage_data, error } = await supabase.from<Usage>('usage').update({ amount: usage_data[0].amount + 1 }).select().eq("name", "message")
// // ! Messages seen
// // ? Check if Server exists in DB
// let { data: check_data, error: check_error } = await supabase.from<Server>("servers").select().eq(`server_id`, message.guild.id).limit(1)
// if (check_data?.length === 0) {
// let { data: c, error: d } = await supabase.from<Server>('servers').insert({
// server_id: message.guild?.id
// })
// }
// // ? Get Server Config
// let { data: server_data, error: server_error } = await supabase.from<Server>("servers").select().eq(`server_id`, message.guild.id).limit(1)
let server_data = await mod.server(message.guild.id)
// ? Check if Message includes Shortlinks
await Shortlink(message, server_data.shortlinks)
// ? Check if Message includes E621 Image Links
await SourceFinder(message, server_data.sourcefinder)
// ? Check if Channel Topic allows Commands
if (await Commands(message)) return;
// ! Prefix
let PrefixArray: string[] = [...config.variables.prefix, [(server_data.prefix ? server_data.prefix : [])]].flat(Infinity)
let Prefix: string
let Exists: boolean
for (const p in PrefixArray) {
if (message.content.startsWith(PrefixArray[p])) {
Prefix = p
Exists = true
}
}
// ! If Prefix doesn't exist in Message Content, return
if (!Exists) return;
const args = message.content.slice(PrefixArray[Prefix].length).trim().split(/ +/g)
const command = args.shift()?.toLowerCase()
const cmd: Command = client.commands.find((c) => (c.name as string).toLowerCase() == command || (c.aliases && c.aliases.includes(command)))
if (!cmd) return;
if (!client.cooldowns.has(cmd.name)) {
client.cooldowns.set(cmd.name, new Collection())
}
const ctx = {
client,
args,
guild: message.guild,
message, channel: message.channel,
author: message.author,
member: message.member,
modulus: mod,
language,
settings: server_data,
config,
isDeveloper: config.variables.developers.find(dev => dev.id === message.author.id)
}
// ! Override Command Restrictions if Message Author is on list of Developers
if (ctx.isDeveloper) cmd.AuthorPermissions = "NONE"
// ! If Command is NSFW and channel is not marked as such, return
if (cmd.nsfw && !ctx.channel.nsfw) return ctx.channel.send(
lingua[ctx.settings.locale].CHANNEL_NOT_NSFW
)
if (cmd.AuthorPermissions !== "NONE" && ctx.member?.permissions.has(cmd.AuthorPermissions)) return ctx.channel.send(replace(/PERMISSIONS/gm, cmd.AuthorPermissions.join(", "), language.get(ctx.settings.locale).error.permissions))
const now = Date.now()
const timestamps = client.cooldowns.get(cmd.name)
const cooldown = (cmd.cooldown || 1) * 1000
if (timestamps.has(ctx.author.id)) {
const time = timestamps.get(ctx.author.id) + cooldown
if (now < time) {
let CooldownEmbed = new MessageEmbed()
const left = (time - now) / 1000
let title = replace(/COMMAND/g, cmd.name, language.get(ctx.settings.locale).error.cooldown.name)
let description = replace(/COMMAND/g, cmd.name, replace(/COOLDOWN/g, `${cmd.cooldown}s`, replace(/TIME/g, left, language.get(ctx.settings.locale).error.cooldown.desc)))
CooldownEmbed.setTitle(title)
.setDescription(description)
.setColor("ORANGE")
return ctx.channel.send(CooldownEmbed)
}
} else {
timestamps.set(ctx.author.id, now)
setTimeout(() => timestamps.delete(ctx.author.id), cooldown)
try {
await cmd.command(ctx)
// // ? Check if Comnand exists in DB
// let { data: usage_check_data, error: usage_check_error } = await supabase.from<Usage>("usage").select().eq(`name`, cmd.name).limit(1)
// if (usage_check_data?.length == 0) {
// let { data: c, error: d } = await supabase.from<Usage>('usage').insert({
// name: cmd.name,
// type: "command",
// // amount: 1
// })
// }
// Prom.commandsExecuted.inc()
// let { data: command_usage_data, command_usage_error } = await supabase.from<Usage>('usage').update({ amount: (usage_check_data[0] || { amount: 0 }).amount + 1 }).select().eq("name", cmd.name)
Logger.info({
type: "command:executed",
command: cmd.name,
message: args.join(' ') || `${cmd.name} was executed in ${chalk.red('[')}${ctx.guild.name}${chalk.red(']')}(${ctx.guild?.id})`
})
} catch (error) {
// Logger.error(error)
console.log(error)
let ErrorEmbed = new MessageEmbed().setTitle(replace(/COMMAND/g, cmd.name, language.get(ctx.settings.locale).error.error)).setDescription(`\`${error.message}\`\n\n\`${error}\``).setColor("RED")
ctx.channel.send(ErrorEmbed)
}
}
}
}