|
|
|
@ -1,8 +1,13 @@
|
|
|
|
import { AuditLogEvent, GuildAuditLogsEntry, Webhook } from "discord.js";
|
|
|
|
import { AuditLogEvent, GuildAuditLogsEntry, GuildChannel, Webhook } from "discord.js";
|
|
|
|
import type Discord from "discord.js";
|
|
|
|
import type Discord from "discord.js";
|
|
|
|
import type { NucleusClient } from "../utils/client.js";
|
|
|
|
import type { NucleusClient } from "../utils/client.js";
|
|
|
|
export const event = "webhookUpdate";
|
|
|
|
export const event = "webhookUpdate";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
interface accType {
|
|
|
|
|
|
|
|
before: Record<string, string>;
|
|
|
|
|
|
|
|
after: Record<string, string>;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
export async function callback(client: NucleusClient, channel: Discord.GuildChannel) {
|
|
|
|
export async function callback(client: NucleusClient, channel: Discord.GuildChannel) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
const { getAuditLog, log, NucleusColors, entry, renderUser, renderChannel, renderDelta } = client.logger;
|
|
|
|
const { getAuditLog, log, NucleusColors, entry, renderUser, renderChannel, renderDelta } = client.logger;
|
|
|
|
@ -18,77 +23,65 @@ export async function callback(client: NucleusClient, channel: Discord.GuildChan
|
|
|
|
let action: "Create" | "Update" | "Delete" = "Create";
|
|
|
|
let action: "Create" | "Update" | "Delete" = "Create";
|
|
|
|
let list: Record<string, ReturnType<typeof entry> | string> = {};
|
|
|
|
let list: Record<string, ReturnType<typeof entry> | string> = {};
|
|
|
|
if (auditUpdate && auditUpdate.createdTimestamp > audit.createdTimestamp) {
|
|
|
|
if (auditUpdate && auditUpdate.createdTimestamp > audit.createdTimestamp) {
|
|
|
|
const { before, after } = auditUpdate.changes.reduce(
|
|
|
|
const { before, after } = auditUpdate.changes.reduce((acc: accType, change) => {
|
|
|
|
(
|
|
|
|
acc.before[change.key] = change.old?.toString()!;
|
|
|
|
acc: { before: Record<string, string>; after: Record<string, string> },
|
|
|
|
acc.after[change.key] = change.new?.toString()!;
|
|
|
|
change: { key: string; new: string; old: string }
|
|
|
|
|
|
|
|
) => {
|
|
|
|
|
|
|
|
acc.before[change.key] = change.old;
|
|
|
|
|
|
|
|
acc.after[change.key] = change.new;
|
|
|
|
|
|
|
|
return acc;
|
|
|
|
return acc;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{ before: {}, after: {} }
|
|
|
|
{ before: {}, after: {} }
|
|
|
|
);
|
|
|
|
);
|
|
|
|
if (before.name !== after.name)
|
|
|
|
if (before["name"] !== after["name"])
|
|
|
|
list["name"] = entry([before.name, after.name], `${before.name} -> ${after.name}`);
|
|
|
|
list["name"] = entry([before["name"]!, after["name"]!], `${before["name"]} -> ${after["name"]}`);
|
|
|
|
if (before.channel_id !== after.channel_id)
|
|
|
|
if (before["channel_id"] !== after["channel_id"])
|
|
|
|
list["channel"] = entry(
|
|
|
|
list["channel"] = entry(
|
|
|
|
[before.channel_id, after.channel_id],
|
|
|
|
[before["channel_id"]!, after["channel_id"]!],
|
|
|
|
renderChannel(await client.channels.fetch(before.channel_id)) +
|
|
|
|
renderChannel(await client.channels.fetch(before["channel_id"]!) as GuildChannel) +
|
|
|
|
" -> " +
|
|
|
|
" -> " +
|
|
|
|
renderChannel(await client.channels.fetch(after.channel_id))
|
|
|
|
renderChannel(await client.channels.fetch(after["channel_id"]!) as GuildChannel)
|
|
|
|
);
|
|
|
|
);
|
|
|
|
if (!Object.keys(list).length) return;
|
|
|
|
if (!Object.keys(list).length) return;
|
|
|
|
list["created"] = entry(
|
|
|
|
list["created"] = entry(
|
|
|
|
auditUpdate.target.createdTimestamp,
|
|
|
|
(auditUpdate.target! as Extract<GuildAuditLogsEntry, {createdTimestamp: number}>).createdTimestamp,
|
|
|
|
renderDelta(auditUpdate.target.createdTimestamp)
|
|
|
|
renderDelta((auditUpdate.target! as Extract<GuildAuditLogsEntry, {createdTimestamp: number}>).createdTimestamp)
|
|
|
|
);
|
|
|
|
);
|
|
|
|
list["edited"] = entry(after.editedTimestamp, renderDelta(new Date().getTime()));
|
|
|
|
list["edited"] = entry(after["editedTimestamp"]!, renderDelta(new Date().getTime()));
|
|
|
|
list["editedBy"] = entry(auditUpdate.executor.id, renderUser(auditUpdate.executor));
|
|
|
|
list["editedBy"] = entry(auditUpdate.executor!.id, renderUser(auditUpdate.executor!));
|
|
|
|
audit = auditUpdate;
|
|
|
|
audit = auditUpdate;
|
|
|
|
action = "Update";
|
|
|
|
action = "Update";
|
|
|
|
} else if (auditDelete && auditDelete.createdTimestamp > audit.createdTimestamp) {
|
|
|
|
} else if (auditDelete && auditDelete.createdTimestamp > audit.createdTimestamp) {
|
|
|
|
const { before } = auditDelete.changes.reduce(
|
|
|
|
const { before } = auditDelete.changes.reduce((acc: accType, change) => {
|
|
|
|
(
|
|
|
|
acc.before[change.key] = change.old?.toString()!;
|
|
|
|
acc: { before: Record<string, string>; after: Record<string, string> },
|
|
|
|
acc.after[change.key] = change.new?.toString()!;
|
|
|
|
change: { key: string; new: string; old: string }
|
|
|
|
|
|
|
|
) => {
|
|
|
|
|
|
|
|
acc.before[change.key] = change.old;
|
|
|
|
|
|
|
|
acc.after[change.key] = change.new;
|
|
|
|
|
|
|
|
return acc;
|
|
|
|
return acc;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{ before: {}, after: {} }
|
|
|
|
{ before: {}, after: {} }
|
|
|
|
);
|
|
|
|
);
|
|
|
|
list = {
|
|
|
|
list = {
|
|
|
|
name: entry(before.name, `${before.name}`),
|
|
|
|
name: entry(before["name"]!, `${before["name"]}`),
|
|
|
|
channel: entry(before.channel_id, renderChannel(await client.channels.fetch(before.channel_id))),
|
|
|
|
channel: entry(before["channel_id"]!, renderChannel((await client.channels.fetch(before["channel_id"]!)) as GuildChannel)),
|
|
|
|
created: entry(auditDelete.target.createdTimestamp, renderDelta(auditDelete.target.createdTimestamp)),
|
|
|
|
created: entry((auditUpdate.target! as Extract<GuildAuditLogsEntry, {createdTimestamp: number}>).createdTimestamp, renderDelta((auditUpdate.target! as Extract<GuildAuditLogsEntry, {createdTimestamp: number}>).createdTimestamp)),
|
|
|
|
deleted: entry(new Date().getTime(), renderDelta(new Date().getTime())),
|
|
|
|
deleted: entry(new Date().getTime(), renderDelta(new Date().getTime())),
|
|
|
|
deletedBy: entry(
|
|
|
|
deletedBy: entry(
|
|
|
|
auditDelete.executor.id,
|
|
|
|
auditDelete.executor!.id,
|
|
|
|
renderUser((await channel.guild.members.fetch(auditDelete.executor.id)).user)
|
|
|
|
renderUser((await channel.guild.members.fetch(auditDelete.executor!.id)).user)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
};
|
|
|
|
};
|
|
|
|
audit = auditDelete;
|
|
|
|
audit = auditDelete;
|
|
|
|
action = "Delete";
|
|
|
|
action = "Delete";
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
const { before } = auditDelete.changes.reduce(
|
|
|
|
const { before } = auditDelete.changes.reduce((acc: accType, change) => {
|
|
|
|
(
|
|
|
|
acc.before[change.key] = change.old?.toString()!;
|
|
|
|
acc: { before: Record<string, string>; after: Record<string, string> },
|
|
|
|
acc.after[change.key] = change.new?.toString()!;
|
|
|
|
change: { key: string; new: string; old: string }
|
|
|
|
|
|
|
|
) => {
|
|
|
|
|
|
|
|
acc.before[change.key] = change.old;
|
|
|
|
|
|
|
|
acc.after[change.key] = change.new;
|
|
|
|
|
|
|
|
return acc;
|
|
|
|
return acc;
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{ before: {}, after: {} }
|
|
|
|
{ before: {}, after: {} }
|
|
|
|
);
|
|
|
|
);
|
|
|
|
list = {
|
|
|
|
list = {
|
|
|
|
name: entry(before.name, `${before.name}`),
|
|
|
|
name: entry(before["name"]!, `${before["name"]}`),
|
|
|
|
channel: entry(before.channel_id, renderChannel(await client.channels.fetch(before.channel_id))),
|
|
|
|
channel: entry(before["channel_id"]!, renderChannel(await client.channels.fetch(before["channel_id"]!) as GuildChannel)),
|
|
|
|
createdBy: entry(
|
|
|
|
createdBy: entry(
|
|
|
|
auditCreate.executor.id,
|
|
|
|
auditCreate.executor!.id,
|
|
|
|
renderUser((await channel.guild.members.fetch(auditCreate.executor.id)).user)
|
|
|
|
renderUser((await channel.guild.members.fetch(auditCreate.executor!.id)).user)
|
|
|
|
),
|
|
|
|
),
|
|
|
|
created: entry(new Date().getTime(), renderDelta(new Date().getTime()))
|
|
|
|
created: entry(new Date().getTime(), renderDelta(new Date().getTime()))
|
|
|
|
};
|
|
|
|
};
|
|
|
|
@ -103,7 +96,7 @@ export async function callback(client: NucleusClient, channel: Discord.GuildChan
|
|
|
|
type: "webhook" + action,
|
|
|
|
type: "webhook" + action,
|
|
|
|
displayName: `Webhook ${action}d`,
|
|
|
|
displayName: `Webhook ${action}d`,
|
|
|
|
calculateType: "webhookUpdate",
|
|
|
|
calculateType: "webhookUpdate",
|
|
|
|
color: NucleusColors[cols[action]],
|
|
|
|
color: (NucleusColors as any)[cols[action]],
|
|
|
|
emoji: "WEBHOOK." + action.toUpperCase(),
|
|
|
|
emoji: "WEBHOOK." + action.toUpperCase(),
|
|
|
|
timestamp: new Date().getTime()
|
|
|
|
timestamp: new Date().getTime()
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|