/[sudobot]/trunk/src/commands/moderation/TempBanCommand.ts
ViewVC logotype

Diff of /trunk/src/commands/moderation/TempBanCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 106 by rakin, Mon Jul 29 17:28:37 2024 UTC revision 429 by rakin, Mon Jul 29 17:30:11 2024 UTC
# Line 1  Line 1 
1  import { BanOptions, CommandInteraction, GuildMember, Interaction, Message, User } from 'discord.js';  /**
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';  import BaseCommand from '../../utils/structures/BaseCommand';
22  import DiscordClient from '../../client/Client';  import DiscordClient from '../../client/Client';
23  import CommandOptions from '../../types/CommandOptions';  import CommandOptions from '../../types/CommandOptions';
24  import InteractionOptions from '../../types/InteractionOptions';  import InteractionOptions from '../../types/InteractionOptions';
25  import MessageEmbed from '../../client/MessageEmbed';  import MessageEmbed from '../../client/MessageEmbed';
26  import getUser from '../../utils/getUser';  import getUser from '../../utils/getUser';
 import History from '../../automod/History';  
27  import Punishment from '../../models/Punishment';  import Punishment from '../../models/Punishment';
28  import PunishmentType from '../../types/PunishmentType';  import PunishmentType from '../../types/PunishmentType';
29  import { fetchEmojiStr } from '../../utils/Emoji';  import { fetchEmojiStr } from '../../utils/Emoji';
30  import ms from 'ms';  import ms from 'ms';
31  import { clearTimeoutv2, getTimeouts, setTimeoutv2 } from '../../utils/setTimeout';  import { hasPermission, shouldNotModerate } from '../../utils/util';
32    import UnbanQueue from '../../queues/UnbanQueue';
33    
34  export default class tempBanCommand extends BaseCommand {  export default class TempBanCommand extends BaseCommand {
35      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
36        permissions = [Permissions.FLAGS.BAN_MEMBERS];
37    
38      constructor() {      constructor() {
39          super('tempban', 'moderation', []);          super('tempban', 'moderation', []);
# Line 132  export default class tempBanCommand exte Line 152  export default class tempBanCommand exte
152          time = ms(time);          time = ms(time);
153            
154          try {          try {
155              await msg.guild?.bans.create(user, banOptions);              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({              const punishment = await Punishment.create({
181                  type: PunishmentType.TEMPBAN,                  type: PunishmentType.TEMPBAN,
# Line 144  export default class tempBanCommand exte Line 187  export default class tempBanCommand exte
187                  meta: {                  meta: {
188                      days: banOptions.days,                      days: banOptions.days,
189                      time                      time
190                  }                  },
191                    createdAt: new Date()
192              });              });
193    
194              const timeouts = getTimeouts();              // const timeouts = getTimeouts();
195                            
196              for (const timeout of timeouts.values()) {              // for (const timeout of timeouts.values()) {
197                  if (timeout.row.params) {              //     if (timeout.row.params) {
198                      try {              //         try {
199                          const json = JSON.parse(timeout.row.params);              //             const json = JSON.parse(timeout.row.params);
200    
201                          if (json) {              //             if (json) {
202                              if (json[1] === user.id && timeout.row.filePath.endsWith('tempban-remove')) {              //                 if (json[1] === user.id && timeout.row.filePath.endsWith('tempban-remove')) {
203                                  await clearTimeoutv2(timeout);              //                     await clearTimeoutv2(timeout);
204                              }              //                 }
205                          }              //             }
206                      }              //         }
207                      catch (e) {              //         catch (e) {
208                          console.log(e);                                  //             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 setTimeoutv2('tempban-remove', time, msg.guild!.id, 'unban ' + user.id, user.id, msg.guild!.id);              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                });
228    
229              await client.logger.logTempBan(banOptions, msg.guild!, user, punishment);              await client.logger.logTempBan(banOptions, msg.guild!, user, punishment);
230    
# Line 204  export default class tempBanCommand exte Line 262  export default class tempBanCommand exte
262              return;              return;
263          }          }
264      }      }
 }  
265    }

Legend:
Removed from v.106  
changed lines
  Added in v.429

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26