/[sudobot]/branches/8.x/src/commands/moderation/UserNoteViewCommand.ts
ViewVC logotype

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26