blob: 1908b7fe9790be9fb4793b6e6c3cae9f1f269a2d [file] [log] [blame]
pineafan0f5cc782022-08-12 21:55:42 +01001import type { GuildAuditLogsEntry, ThreadChannel } from "discord.js";
2// @ts-expect-error
pineafan63fc5e22022-08-04 22:04:10 +01003import humanizeDuration from "humanize-duration";
pineafan0f5cc782022-08-12 21:55:42 +01004// @ts-expect-error
5import type { HaikuClient } from "jshaiku"
pineafan63fc5e22022-08-04 22:04:10 +01006export const event = "threadDelete";
pineafane625d782022-05-09 18:04:32 +01007
pineafan0f5cc782022-08-12 21:55:42 +01008export async function callback(client: HaikuClient, thread: ThreadChannel) {
9 const { getAuditLog, log, NucleusColors, entry, renderUser, renderDelta, renderChannel } = client.logger;
pineafan63fc5e22022-08-04 22:04:10 +010010 const auditLog = await getAuditLog(thread.guild, "THREAD_UPDATE");
pineafan0f5cc782022-08-12 21:55:42 +010011 const audit = auditLog.entries.filter((entry: GuildAuditLogsEntry) => entry.target!.id === thread.id).first();
pineafane23c4ec2022-07-27 21:56:27 +010012 if (audit.executor.id === client.user.id) return;
pineafan0f5cc782022-08-12 21:55:42 +010013 const category = thread.parent ? entry(
14 thread.parent.parent ? thread.parent.parent.name : "None",
15 thread.parent.parent ? renderChannel(thread.parent.parent) : "None"
16 ) : entry(null, "Uncategorised")
pineafan63fc5e22022-08-04 22:04:10 +010017 const data = {
pineafane625d782022-05-09 18:04:32 +010018 meta: {
pineafan63fc5e22022-08-04 22:04:10 +010019 type: "channelDelete",
20 displayName: "Thread Deleted",
21 calculateType: "channelUpdate",
pineafane625d782022-05-09 18:04:32 +010022 color: NucleusColors.red,
23 emoji: "CHANNEL.TEXT.DELETE",
24 timestamp: new Date().getTime()
25 },
26 list: {
Skyler Grey75ea9172022-08-06 10:22:23 +010027 threadId: entry(thread.id, `\`${thread.id}\``),
pineafane625d782022-05-09 18:04:32 +010028 name: entry(thread.name, thread.name),
pineafan0f5cc782022-08-12 21:55:42 +010029 parentChannel: entry(thread.parentId, thread.parent ? renderChannel(thread.parent) : "*None*"),
30 category: category,
Skyler Grey75ea9172022-08-06 10:22:23 +010031 autoArchiveDuration: entry(
32 thread.autoArchiveDuration,
pineafan0f5cc782022-08-12 21:55:42 +010033 humanizeDuration((thread.autoArchiveDuration ?? 0) * 60 * 1000, {
Skyler Grey75ea9172022-08-06 10:22:23 +010034 round: true
35 })
36 ),
pineafane625d782022-05-09 18:04:32 +010037 membersInThread: entry(thread.memberCount, thread.memberCount),
38 deletedBy: entry(audit.executor.id, renderUser(audit.executor)),
Skyler Grey11236ba2022-08-08 21:13:33 +010039 created: entry(thread.createdTimestamp, renderDelta(thread.createdTimestamp)),
40 deleted: entry(new Date().getTime(), renderDelta(new Date().getTime()))
pineafane625d782022-05-09 18:04:32 +010041 },
42 hidden: {
43 guild: thread.guild.id
44 }
pineafan63fc5e22022-08-04 22:04:10 +010045 };
pineafan4edb7762022-06-26 19:21:04 +010046 log(data);
pineafane625d782022-05-09 18:04:32 +010047}