/[sudobot]/branches/6.x/src/commands/settings/BlockedMessageCommand.ts
ViewVC logotype

Contents of /branches/6.x/src/commands/settings/BlockedMessageCommand.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: 9742 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 { EmbedBuilder, PermissionFlagsBits, SlashCommandBuilder, Snowflake, escapeMarkdown } from "discord.js";
21 import Command, { ArgumentType, BasicCommandContext, CommandMessage, CommandReturn, ValidationRule } from "../../core/Command";
22 import Pagination from "../../utils/Pagination";
23
24 export default class BlockedMessageCommand extends Command {
25 public readonly subcommandsCustom = ["add", "remove", "has", "list"];
26 public readonly name = "blockedmessage";
27 public readonly validationRules: ValidationRule[] = [
28 {
29 types: [ArgumentType.String],
30 errors: {
31 required: `Please provide a subcommand! The valid subcommands are: \`${this.subcommandsCustom.join("`, `")}\`.`,
32 "type:invalid": `Please provide a __valid__ subcommand! The valid subcommands are: \`${this.subcommandsCustom.join(
33 "`, `"
34 )}\`.`
35 },
36 name: "subcommand"
37 }
38 ];
39 public readonly permissions = [PermissionFlagsBits.ManageGuild, PermissionFlagsBits.BanMembers];
40 public readonly permissionMode = "or";
41
42 public readonly description = "Manage blocked messages.";
43
44 public readonly detailedDescription = [
45 "Add/remove/check/view the blocked messages. All arguments, separated by spaces will be treated as different messages.\n",
46 "**Subcommands**",
47 "* `add <...messages>` - Add blocked message(s)",
48 "* `remove <...messages>` - Remove blocked message(s)",
49 "* `has <message>` - Check if the given message is blocked",
50 "* `list` - List all the blocked messages"
51 ].join("\n");
52
53 public readonly argumentSyntaxes = ["<subcommand> [...args]"];
54
55 public readonly slashCommandBuilder = new SlashCommandBuilder()
56 .addSubcommand(subcommand =>
57 subcommand
58 .setName("add")
59 .setDescription("Add a blocked message")
60 .addStringOption(option => option.setName("message").setDescription("The message to block").setRequired(true))
61 )
62 .addSubcommand(subcommand =>
63 subcommand
64 .setName("remove")
65 .setDescription("Remove blocked message")
66 .addStringOption(option =>
67 option.setName("message").setDescription("The message to remove from blocklist").setRequired(true)
68 )
69 )
70 .addSubcommand(subcommand =>
71 subcommand
72 .setName("has")
73 .setDescription("Check if a blocked message exists in the blocklist")
74 .addStringOption(option => option.setName("message").setDescription("The message to check").setRequired(true))
75 )
76 .addSubcommand(subcommand => subcommand.setName("list").setDescription("Show the blocked message list"));
77 public readonly aliases = ["blockedmessages"];
78
79 createConfigIfNotExists(guildId: Snowflake) {
80 this.client.configManager.config[guildId!]!.message_filter ??= {
81 enabled: true,
82 delete_message: true,
83 send_logs: true
84 } as any;
85
86 this.client.configManager.config[guildId!]!.message_filter!.data ??= {
87 blocked_tokens: [],
88 blocked_words: [],
89 blocked_messages: []
90 };
91
92 this.client.configManager.config[guildId!]!.message_filter!.data!.blocked_messages ??= [];
93 }
94
95 async execute(message: CommandMessage, context: BasicCommandContext): Promise<CommandReturn> {
96 const subcommand = (
97 context.isLegacy ? context.parsedNamedArgs.subcommand : context.options.getSubcommand(true)
98 )?.toString();
99
100 if (!this.subcommandsCustom.includes(subcommand)) {
101 await this.error(
102 message,
103 `Invalid subcommand provided. The valid subcommands are: \`${this.subcommandsCustom.join("`, `")}\`.`
104 );
105 return;
106 }
107
108 if (context.isLegacy && context.args[1] === undefined && subcommand !== "list") {
109 await this.error(
110 message,
111 `You must specify a message ${
112 subcommand === "add" ? "to block" : subcommand === "remove" ? "to remove" : "to check"
113 }!`
114 );
115 return;
116 }
117
118 if (!this.client.configManager.config[message.guildId!]) {
119 return;
120 }
121
122 await this.deferIfInteraction(message);
123
124 if (context.isLegacy) {
125 context.args.shift();
126 }
127
128 this.createConfigIfNotExists(message.guildId!);
129
130 switch (subcommand) {
131 case "add":
132 const messageToBlock = context.isLegacy ? context.args[0] : context.options.getString("message", true);
133
134 if (
135 !this.client.configManager.config[message.guildId!]?.message_filter?.data?.blocked_messages.includes(
136 messageToBlock
137 )
138 ) {
139 this.client.configManager.config[message.guildId!]?.message_filter?.data?.blocked_messages.push(
140 messageToBlock
141 );
142 }
143
144 await this.client.configManager.write();
145 await this.success(message, `The given message has been blocked.`);
146 break;
147
148 case "has":
149 const messageToCheck = context.isLegacy ? context.args[0] : context.options.getString("message", true);
150
151 if (
152 this.client.configManager.config[message.guildId!]?.message_filter?.data?.blocked_messages.includes(
153 messageToCheck
154 )
155 ) {
156 await this.success(message, `This message is in the blocklist.`);
157 } else {
158 await this.error(message, `This message is not in the blocklist.`);
159 }
160
161 return;
162
163 case "remove":
164 const messageToRemove = context.isLegacy ? context.args[0] : context.options.getString("message", true);
165
166 const index =
167 this.client.configManager.config[message.guildId!]?.message_filter?.data?.blocked_messages.indexOf(
168 messageToRemove
169 );
170
171 if (!index || index === -1) {
172 return;
173 }
174
175 this.client.configManager.config[message.guildId!]?.message_filter?.data?.blocked_messages.splice(index, 1);
176
177 await this.client.configManager.write();
178 await this.success(message, `The given message has been unblocked.`);
179 break;
180
181 case "list":
182 {
183 const messages: string[] =
184 this.client.configManager.config[message.guildId!]?.message_filter?.data?.blocked_messages ?? [];
185 const safeMessages: string[][] = [];
186 let length = 0;
187
188 for (const unsafeMessage of messages) {
189 if (safeMessages.length === 0) safeMessages.push([]);
190
191 const theMessage = escapeMarkdown(unsafeMessage);
192
193 if (length + theMessage.length >= 3000) {
194 safeMessages.push([theMessage]);
195 length = theMessage.length;
196 continue;
197 }
198
199 const index = safeMessages.length - 1;
200
201 safeMessages[index].push(theMessage);
202 length += theMessage.length;
203 }
204
205 const pagination = new Pagination(safeMessages, {
206 channelId: message.channelId!,
207 guildId: message.guildId!,
208 limit: 1,
209 timeout: 120_000,
210 userId: message.member!.user.id,
211 client: this.client,
212 embedBuilder({ currentPage, data, maxPages }) {
213 return new EmbedBuilder({
214 author: {
215 name: `Blocked messages in ${message.guild!.name}`,
216 iconURL: message.guild!.iconURL() ?? undefined
217 },
218 color: 0x007bff,
219 description: "`" + data[0].join("`, `") + "`",
220 footer: {
221 text: `Page ${currentPage} of ${maxPages}`
222 }
223 });
224 }
225 });
226
227 let reply = await this.deferredReply(message, await pagination.getMessageOptions());
228 await pagination.start(reply);
229 }
230
231 break;
232 }
233 }
234 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26