1 |
/** |
2 |
* This file is part of SudoBot. |
3 |
* |
4 |
* Copyright (C) 2021-2023 OSN Developers. |
5 |
* |
6 |
* SudoBot is free software; you can redistribute it and/or modify it |
7 |
* under the terms of the GNU Affero General Public License as published by |
8 |
* the Free Software Foundation, either version 3 of the License, or |
9 |
* (at your option) any later version. |
10 |
* |
11 |
* SudoBot is distributed in the hope that it will be useful, but |
12 |
* WITHOUT ANY WARRANTY; without even the implied warranty of |
13 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
14 |
* GNU Affero General Public License for more details. |
15 |
* |
16 |
* You should have received a copy of the GNU Affero General Public License |
17 |
* along with SudoBot. If not, see <https://www.gnu.org/licenses/>. |
18 |
*/ |
19 |
|
20 |
import { InfractionType } from "@prisma/client"; |
21 |
import { AuditLogEvent, ClientEvents, GuildBan } from "discord.js"; |
22 |
import Event from "../../core/Event"; |
23 |
import { logError } from "../../utils/logger"; |
24 |
|
25 |
export default class GuildBanAddEvent extends Event { |
26 |
public name: keyof ClientEvents = "guildBanAdd"; |
27 |
|
28 |
async execute(ban: GuildBan) { |
29 |
setTimeout(async () => { |
30 |
try { |
31 |
const auditLog = ( |
32 |
await ban.guild.fetchAuditLogs({ |
33 |
limit: 1, |
34 |
type: AuditLogEvent.MemberBanAdd |
35 |
}) |
36 |
).entries.first(); |
37 |
|
38 |
if (auditLog?.executor?.id && auditLog.executor.id !== this.client.user?.id) { |
39 |
const infraction = await this.client.prisma.infraction.create({ |
40 |
data: { |
41 |
guildId: ban.guild.id, |
42 |
moderatorId: auditLog.executor.id, |
43 |
type: InfractionType.BAN, |
44 |
userId: ban.user.id, |
45 |
reason: ban.reason ?? undefined |
46 |
} |
47 |
}); |
48 |
|
49 |
await this.client.logger.logUserBan({ |
50 |
moderator: auditLog.executor, |
51 |
user: ban.user, |
52 |
guild: ban.guild, |
53 |
id: infraction.id.toString(), |
54 |
includeDeleteMessageSeconds: false, |
55 |
reason: ban.reason ?? undefined |
56 |
}); |
57 |
} |
58 |
} catch (e) { |
59 |
logError(e); |
60 |
} |
61 |
}, 3500); |
62 |
} |
63 |
} |