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

Contents of /branches/4.x/src/commands/moderation/TempBanCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (show annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months, 1 week ago) by rakinar2
File MIME type: application/typescript
File size: 9060 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 { BanOptions, CommandInteraction, Message, User, Permissions } 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 Punishment from '../../models/Punishment';
28 import PunishmentType from '../../types/PunishmentType';
29 import { fetchEmojiStr } from '../../utils/Emoji';
30 import ms from 'ms';
31 import { hasPermission, shouldNotModerate } from '../../utils/util';
32 import UnbanQueue from '../../queues/UnbanQueue';
33
34 export default class TempBanCommand extends BaseCommand {
35 supportsInteractions: boolean = true;
36 permissions = [Permissions.FLAGS.BAN_MEMBERS];
37
38 constructor() {
39 super('tempban', 'moderation', []);
40 }
41
42 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
43 if (!options.isInteraction && typeof options.args[1] === 'undefined') {
44 await msg.reply({
45 embeds: [
46 new MessageEmbed()
47 .setColor('#f14a60')
48 .setDescription(`This command requires at least two arguments.`)
49 ]
50 });
51
52 return;
53 }
54
55 let user: User;
56 let banOptions: BanOptions = {
57 days: 7
58 };
59 let time;
60
61 if (options.isInteraction) {
62 user = await <User> options.options.getUser('user');
63 time = await <string> options.options.getString('time');
64
65 if (options.options.getString('reason')) {
66 banOptions.reason = await <string> options.options.getString('reason');
67 }
68
69 if (options.options.getInteger('days')) {
70 banOptions.days = await <number> options.options.getInteger('days');
71 }
72 }
73 else {
74 const user2 = await getUser(client, (msg as Message), options);
75
76 if (!user2) {
77 await msg.reply({
78 embeds: [
79 new MessageEmbed()
80 .setColor('#f14a60')
81 .setDescription(`Invalid user given.`)
82 ]
83 });
84
85 return;
86 }
87
88 user = user2;
89
90 options.args.shift();
91
92 time = options.args[0];
93
94 const index = await options.args.indexOf('-d');
95
96 if (options.args[1]) {
97 const args = [...options.args];
98 args.shift();
99
100 if (index !== -1) {
101 args.splice(index - 1, 2)
102 }
103
104 banOptions.reason = await args.join(' ');
105 }
106
107 if (index !== -1) {
108 const days = await options.args[index + 1];
109
110 if (days === undefined) {
111 await msg.reply({
112 embeds: [
113 new MessageEmbed()
114 .setColor('#f14a60')
115 .setDescription(`Option \`-d\` (days) requires an argument.`)
116 ]
117 });
118
119 return;
120 }
121
122 if (!parseInt(days) || parseInt(days) < 0 || parseInt(days) > 7) {
123 await msg.reply({
124 embeds: [
125 new MessageEmbed()
126 .setColor('#f14a60')
127 .setDescription(`Option \`-d\` (days) requires an argument which must be a valid number and in range of 0-7.`)
128 ]
129 });
130
131 return;
132 }
133
134 banOptions.days = await parseInt(days);
135 }
136 }
137
138 console.log(time);
139
140 if (!time || !ms(time)) {
141 await msg.reply({
142 embeds: [
143 new MessageEmbed()
144 .setColor('#f14a60')
145 .setDescription(`The time must be a valid time identifier.`)
146 ]
147 });
148
149 return;
150 }
151
152 time = ms(time);
153
154 try {
155 try {
156 const member = await msg.guild?.members.fetch(user.id);
157
158 if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to tempban this user."))) {
159 return;
160 }
161
162 if (member && shouldNotModerate(client, member)) {
163 await msg.reply({
164 embeds: [
165 new MessageEmbed()
166 .setColor('#f14a60')
167 .setDescription(`This user cannot be tempbanned.`)
168 ]
169 });
170
171 return;
172 }
173 }
174 catch (e) {
175 console.log(e);
176 }
177
178 await msg.guild?.bans.create(user, { ...banOptions, reason: `[TEMPBAN] ${banOptions.reason ?? '**No reason provided**'}` });
179
180 const punishment = await Punishment.create({
181 type: PunishmentType.TEMPBAN,
182 user_id: user.id,
183 guild_id: msg.guild!.id,
184 mod_id: msg.member!.user.id,
185 mod_tag: (msg.member!.user as User).tag,
186 reason: banOptions.reason ?? undefined,
187 meta: {
188 days: banOptions.days,
189 time
190 },
191 createdAt: new Date()
192 });
193
194 // const timeouts = getTimeouts();
195
196 // for (const timeout of timeouts.values()) {
197 // if (timeout.row.params) {
198 // try {
199 // const json = JSON.parse(timeout.row.params);
200
201 // if (json) {
202 // if (json[1] === user.id && timeout.row.filePath.endsWith('tempban-remove')) {
203 // await clearTimeoutv2(timeout);
204 // }
205 // }
206 // }
207 // catch (e) {
208 // console.log(e);
209 // }
210 // }
211 // }
212
213 // await setTimeoutv2('tempban-remove', time, msg.guild!.id, 'unban ' + user.id, user.id, msg.guild!.id);
214
215 for await (const queue of client.queueManager.queues.values()) {
216 if (queue instanceof UnbanQueue && queue.data!.userID === user.id && queue.data!.guildID === msg.guild!.id) {
217 await queue.cancel();
218 }
219 }
220
221 await client.queueManager.addQueue(UnbanQueue, {
222 data: {
223 userID: user.id,
224 guildID: msg.guild!.id
225 },
226 runAt: new Date(Date.now() + time),
227 guild: msg.guild!.id
228 });
229
230 await client.logger.onTempBan(banOptions, msg.guild!, user, punishment);
231
232 await msg.reply({
233 embeds: [
234 new MessageEmbed({
235 author: {
236 name: user.tag,
237 iconURL: user.displayAvatarURL()
238 },
239 description: `${await fetchEmojiStr('check')} Temporarily banned user ${user.tag}`,
240 fields: [
241 {
242 name: 'Banned by',
243 value: (<User> msg.member?.user).tag
244 },
245 {
246 name: 'Reason',
247 value: banOptions.reason ?? '*No reason provided*'
248 }
249 ]
250 })
251 ]
252 });
253 }
254 catch (e) {
255 await msg.reply({
256 embeds: [
257 new MessageEmbed()
258 .setColor('#f14a60')
259 .setDescription("Failed to ban this user. Maybe missing permisions or I'm not allowed to ban this user?")
260 ]
261 });
262
263 return;
264 }
265 }
266 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26