blob: 924ec3e7015003cd8734975b23f1ec4cf75808ff [file] [log] [blame]
TheCodedProfa16d1672023-01-18 18:58:34 -05001import { AuditLogEvent, Guild, GuildAuditLogsEntry, Role } from "discord.js";
PineaFan752af462022-12-31 21:59:38 +00002import type { NucleusClient } from "../utils/client.js";
pineafan32767212022-03-14 21:27:39 +00003import getEmojiByName from "../utils/getEmojiByName.js";
4
pineafan63fc5e22022-08-04 22:04:10 +01005export const event = "roleUpdate";
pineafan32767212022-03-14 21:27:39 +00006
TheCodedProfa16d1672023-01-18 18:58:34 -05007export async function callback(client: NucleusClient, oldRole: Role, newRole: Role) {
Skyler Grey11236ba2022-08-08 21:13:33 +01008 const { getAuditLog, log, NucleusColors, entry, renderDelta, renderUser, renderRole } = client.logger;
pineafan32767212022-03-14 21:27:39 +00009
TheCodedProfa16d1672023-01-18 18:58:34 -050010 const auditLog = (await getAuditLog(newRole.guild as Guild, AuditLogEvent.RoleUpdate))
11 .filter((entry: GuildAuditLogsEntry) => (entry.target as Role)!.id === newRole.id)[0]!;
12 if (auditLog.executor!.id === client.user!.id) return;
pineafan32767212022-03-14 21:27:39 +000013
pineafan0f5cc782022-08-12 21:55:42 +010014 const changes: Record<string, ReturnType<typeof entry>> = {
TheCodedProfa16d1672023-01-18 18:58:34 -050015 roleId: entry(newRole.id, `\`${newRole.id}\``),
16 role: entry(newRole.id, renderRole(newRole)),
pineafan63fc5e22022-08-04 22:04:10 +010017 edited: entry(new Date().getTime(), renderDelta(new Date().getTime())),
TheCodedProfa16d1672023-01-18 18:58:34 -050018 editedBy: entry(auditLog.executor!.id, renderUser((await newRole.guild.members.fetch(auditLog.executor!.id)).user))
pineafan63fc5e22022-08-04 22:04:10 +010019 };
20 const mentionable = ["", ""];
21 const hoist = ["", ""];
TheCodedProfa16d1672023-01-18 18:58:34 -050022 mentionable[0] = oldRole.mentionable ? `${getEmojiByName("CONTROL.TICK")} Yes` : `${getEmojiByName("CONTROL.CROSS")} No`;
23 mentionable[1] = newRole.mentionable ? `${getEmojiByName("CONTROL.TICK")} Yes` : `${getEmojiByName("CONTROL.CROSS")} No`;
24 hoist[0] = oldRole.hoist ? `${getEmojiByName("CONTROL.TICK")} Yes` : `${getEmojiByName("CONTROL.CROSS")} No`;
25 hoist[1] = newRole.hoist ? `${getEmojiByName("CONTROL.TICK")} Yes` : `${getEmojiByName("CONTROL.CROSS")} No`;
26 if (oldRole.name !== newRole.name) changes["name"] = entry([oldRole.name, newRole.name], `${oldRole.name} -> ${newRole.name}`);
27 if (oldRole.position !== newRole.position)
28 changes["position"] = entry([oldRole.position.toString(), newRole.position.toString()], `${oldRole.position} -> ${newRole.position}`);
29 if (oldRole.hoist !== newRole.hoist) changes["showInMemberList"] = entry([oldRole.hoist, newRole.hoist], `${hoist[0]} -> ${hoist[1]}`);
30 if (oldRole.mentionable !== newRole.mentionable)
31 changes["mentionable"] = entry([oldRole.mentionable, newRole.mentionable], `${mentionable[0]} -> ${mentionable[1]}`);
32 if (oldRole.hexColor !== newRole.hexColor)
33 changes["color"] = entry([oldRole.hexColor, newRole.hexColor], `\`${oldRole.hexColor}\` -> \`${newRole.hexColor}\``);
pineafan63fc5e22022-08-04 22:04:10 +010034
35 if (Object.keys(changes).length === 4) return;
36
37 const data = {
Skyler Grey75ea9172022-08-06 10:22:23 +010038 meta: {
pineafan63fc5e22022-08-04 22:04:10 +010039 type: "roleUpdate",
40 displayName: "Role Edited",
41 calculateType: "guildRoleUpdate",
42 color: NucleusColors.yellow,
43 emoji: "GUILD.ROLES.EDIT",
TheCodedProfa16d1672023-01-18 18:58:34 -050044 timestamp: auditLog.createdTimestamp
pineafan63fc5e22022-08-04 22:04:10 +010045 },
46 list: changes,
47 hidden: {
TheCodedProfa16d1672023-01-18 18:58:34 -050048 guild: newRole.guild.id
pineafane625d782022-05-09 18:04:32 +010049 }
pineafan63fc5e22022-08-04 22:04:10 +010050 }; // TODO: show perms changed (webpage)
51 log(data);
Skyler Grey75ea9172022-08-06 10:22:23 +010052}