blob: dd723d3884287a4f5af8dd55eca62aa4eb384960 [file] [log] [blame]
import { purgeByUser } from "../actions/tickets/delete.js";
import { callback as statsChannelRemove } from "../reflex/statsChannelUpdate.js";
export const event = "guildBanAdd";
export async function callback(client, ban) {
await statsChannelRemove(client, ban.user);
purgeByUser(ban.user.id, ban.guild);
const { log, NucleusColors, entry, renderUser, renderDelta, getAuditLog } =
ban.user.client.logger;
const auditLog = await getAuditLog(ban.guild, "MEMBER_BAN_ADD");
const audit = auditLog.entries
.filter((entry) => entry.target.id === ban.user.id)
.first();
if (audit.executor.id === client.user.id) return;
await client.database.history.create(
"ban",
ban.guild.id,
ban.user,
audit.executor,
audit.reason
);
const data = {
meta: {
type: "memberBan",
displayName: "Member Banned",
calculateType: "guildMemberPunish",
color: NucleusColors.red,
emoji: "PUNISH.BAN.RED",
timestamp: new Date().getTime()
},
list: {
memberId: entry(ban.user.id, `\`${ban.user.id}\``),
name: entry(ban.user.id, renderUser(ban.user)),
banned: entry(
new Date().getTime(),
renderDelta(new Date().getTime())
),
bannedBy: entry(audit.executor.id, renderUser(audit.executor)),
reason: entry(
audit.reason,
audit.reason ? `\n> ${audit.reason}` : "*No reason provided.*"
),
accountCreated: entry(
ban.user.createdAt,
renderDelta(ban.user.createdAt)
),
serverMemberCount: ban.guild.memberCount
},
hidden: {
guild: ban.guild.id
}
};
log(data);
}