/[sudobot]/branches/5.x/src/commands/moderation/NoteViewCommand.ts
ViewVC logotype

Contents of /branches/5.x/src/commands/moderation/NoteViewCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 3544 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
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 { EmbedBuilder, PermissionsBitField } from "discord.js";
22 import Command, { BasicCommandContext, CommandMessage, CommandReturn, ValidationRule } from "../../core/Command";
23
24 export default class NoteViewCommand extends Command {
25 public readonly name = "note__view";
26 public readonly validationRules: ValidationRule[] = [];
27 public readonly permissions = [PermissionsBitField.Flags.ModerateMembers, PermissionsBitField.Flags.ViewAuditLog];
28 public readonly permissionMode = "or";
29 public readonly description = "Show a note";
30 public readonly argumentSyntaxes = ["<id>"];
31
32 async execute(message: CommandMessage, context: BasicCommandContext): Promise<CommandReturn> {
33 if (context.isLegacy && context.args[0] === undefined) {
34 await this.error(message, "Please specify the ID of the note to delete!");
35 return;
36 }
37
38 let id = context.isLegacy ? undefined : context.options.getInteger("id", true);
39
40 if (context.isLegacy) {
41 id = parseInt(context.args[0]);
42
43 if (isNaN(id)) {
44 await this.error(message, "Invalid note ID given - note IDs must be valid numbers!");
45 return;
46 }
47 }
48
49 await this.deferIfInteraction(message);
50
51 const note = await this.client.prisma.infraction.findFirst({
52 where: {
53 id,
54 guildId: message.guildId!,
55 type: InfractionType.NOTE
56 }
57 });
58
59 if (!note) {
60 await this.error(message, "No such note found with that ID!");
61 return;
62 }
63
64 const user = await this.client.fetchUserSafe(note.userId);
65
66 await this.deferredReply(message, {
67 embeds: [
68 new EmbedBuilder({
69 author: {
70 name: user?.username ?? "*Unknown*",
71 iconURL: user?.displayAvatarURL()
72 },
73 color: 0x007bff,
74 description: note.reason ?? "*No content*",
75 fields: [
76 {
77 name: "Created by",
78 value: `<@${note.moderatorId}> (${note.moderatorId})`,
79 inline: true
80 },
81 {
82 name: "User",
83 value: `<@${note.userId}> (${note.userId})`,
84 inline: true
85 },
86 {
87 name: "ID",
88 value: `${id}`
89 }
90 ]
91 }).setTimestamp()
92 ]
93 });
94 }
95 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26