blob: c5d269bf6365ecce16088d0e2d2565171185ea50 [file] [log] [blame]
pineafan63fc5e22022-08-04 22:04:10 +01001import { purgeByUser } from "../actions/tickets/delete.js";
2import { callback as statsChannelRemove } from "../reflex/statsChannelUpdate.js";
pineafane625d782022-05-09 18:04:32 +01003
pineafan63fc5e22022-08-04 22:04:10 +01004export const event = "guildBanAdd";
pineafane625d782022-05-09 18:04:32 +01005
6export async function callback(client, ban) {
pineafan63fc5e22022-08-04 22:04:10 +01007 await statsChannelRemove(client, ban.user);
8 purgeByUser(ban.user.id, ban.guild);
9 const { log, NucleusColors, entry, renderUser, renderDelta, getAuditLog } = ban.user.client.logger;
10 const auditLog = await getAuditLog(ban.guild, "MEMBER_BAN_ADD");
11 const audit = auditLog.entries.filter(entry => entry.target.id === ban.user.id).first();
12 if (audit.executor.id === client.user.id) return;
13 await client.database.history.create("ban", ban.guild.id, ban.user, audit.executor, audit.reason);
14 const data = {
15 meta: {
16 type: "memberBan",
17 displayName: "Member Banned",
18 calculateType: "guildMemberPunish",
19 color: NucleusColors.red,
20 emoji: "PUNISH.BAN.RED",
21 timestamp: new Date().getTime()
22 },
23 list: {
24 memberId: entry(ban.user.id, `\`${ban.user.id}\``),
25 name: entry(ban.user.id, renderUser(ban.user)),
26 banned: entry(new Date().getTime(), renderDelta(new Date().getTime())),
27 bannedBy: entry(audit.executor.id, renderUser(audit.executor)),
28 reason: entry(audit.reason, audit.reason ? `\n> ${audit.reason}` : "*No reason provided.*"),
29 accountCreated: entry(ban.user.createdAt, renderDelta(ban.user.createdAt)),
30 serverMemberCount: ban.guild.memberCount
31 },
32 hidden: {
33 guild: ban.guild.id
pineafane625d782022-05-09 18:04:32 +010034 }
pineafan63fc5e22022-08-04 22:04:10 +010035 };
36 log(data);
pineafane625d782022-05-09 18:04:32 +010037}