/[sudobot]/branches/4.x/src/commands/moderation/NoteCommand.ts
ViewVC logotype

Contents of /branches/4.x/src/commands/moderation/NoteCommand.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: 3975 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-2022 OSN Inc.
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 { CommandInteraction, GuildMember, Message, Permissions, User } from 'discord.js';
21 import BaseCommand from '../../utils/structures/BaseCommand';
22 import DiscordClient from '../../client/Client';
23 import CommandOptions from '../../types/CommandOptions';
24 import InteractionOptions from '../../types/InteractionOptions';
25 import MessageEmbed from '../../client/MessageEmbed';
26 import getUser from '../../utils/getUser';
27 import { fetchEmoji } from '../../utils/Emoji';
28
29 export async function note(user: GuildMember | User, content: string, msg: Message | CommandInteraction) {
30 const { default: Note } = await import('../../models/Note');
31
32 return await Note.create({
33 content,
34 author: msg.member!.user.id,
35 mod_tag: (msg.member!.user as User).tag,
36 user_id: user.id,
37 guild_id: msg.guild!.id,
38 createdAt: new Date(),
39 });
40 }
41
42 export default class NoteCommand extends BaseCommand {
43 supportsInteractions: boolean = true;
44 permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
45
46 constructor() {
47 super('note', 'moderation', []);
48 }
49
50 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
51 if (!options.isInteraction && typeof options.args[1] === 'undefined') {
52 await msg.reply({
53 embeds: [
54 new MessageEmbed()
55 .setColor('#f14a60')
56 .setDescription(`This command requires at least two arguments.`)
57 ]
58 });
59
60 return;
61 }
62
63 let user: User;
64 let content: string | undefined;
65
66 if (options.isInteraction) {
67 user = await <User> options.options.getUser('user');
68
69 if (!user) {
70 await msg.reply({
71 embeds: [
72 new MessageEmbed()
73 .setColor('#f14a60')
74 .setDescription("Invalid user given.")
75 ]
76 });
77
78 return;
79 }
80
81 content = <string> options.options.getString('note');
82 }
83 else {
84 try {
85 const user2 = await getUser(client, (msg as Message), options);
86
87 if (!user2) {
88 throw new Error('Invalid user');
89 }
90
91 user = user2;
92 }
93 catch (e) {
94 await msg.reply({
95 embeds: [
96 new MessageEmbed()
97 .setColor('#f14a60')
98 .setDescription(`Invalid user given.`)
99 ]
100 });
101
102 return;
103 }
104
105 console.log(user);
106
107 await options.args.shift();
108 content = options.args.join(' ');
109 }
110
111 const n = await note(user, content as string, msg);
112
113 await msg.reply({
114 embeds: [
115 new MessageEmbed()
116 .setDescription(`${(await fetchEmoji('check'))?.toString()} A note has been added for ${user.tag}`)
117 .setFooter({
118 text: `ID: ${n.id}`
119 })
120 ]
121 });
122 }
123 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26