/[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 186 by rakin, Mon Jul 29 17:28:56 2024 UTC revision 428 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 { clearTimeoutv2, getTimeouts, setTimeoutv2 } from '../../utils/setTimeout';
32  import { shouldNotModerate } from '../../utils/util';  import { hasPermission, shouldNotModerate } from '../../utils/util';
33    import UnbanQueue from '../../queues/UnbanQueue';
34    
35  export default class tempBanCommand extends BaseCommand {  export default class TempBanCommand extends BaseCommand {
36      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
37        permissions = [Permissions.FLAGS.BAN_MEMBERS];
38    
39      constructor() {      constructor() {
40          super('tempban', 'moderation', []);          super('tempban', 'moderation', []);
# Line 136  export default class tempBanCommand exte Line 156  export default class tempBanCommand exte
156              try {              try {
157                  const member = await msg.guild?.members.fetch(user.id);                  const member = await msg.guild?.members.fetch(user.id);
158    
159                    if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to tempban this user."))) {
160                        return;
161                    }
162    
163                  if (member && shouldNotModerate(client, member)) {                  if (member && shouldNotModerate(client, member)) {
164                      await msg.reply({                      await msg.reply({
165                          embeds: [                          embeds: [
# Line 152  export default class tempBanCommand exte Line 176  export default class tempBanCommand exte
176                  console.log(e);                  console.log(e);
177              }              }
178                    
179              await msg.guild?.bans.create(user, banOptions);              await msg.guild?.bans.create(user, { ...banOptions, reason: `[TEMPBAN] ${banOptions.reason ?? '**No reason provided**'}` });
180    
181              const punishment = await Punishment.create({              const punishment = await Punishment.create({
182                  type: PunishmentType.TEMPBAN,                  type: PunishmentType.TEMPBAN,
# Line 164  export default class tempBanCommand exte Line 188  export default class tempBanCommand exte
188                  meta: {                  meta: {
189                      days: banOptions.days,                      days: banOptions.days,
190                      time                      time
191                  }                  },
192                    createdAt: new Date()
193              });              });
194    
195              const timeouts = getTimeouts();              // const timeouts = getTimeouts();
196                            
197              for (const timeout of timeouts.values()) {              // for (const timeout of timeouts.values()) {
198                  if (timeout.row.params) {              //     if (timeout.row.params) {
199                      try {              //         try {
200                          const json = JSON.parse(timeout.row.params);              //             const json = JSON.parse(timeout.row.params);
201    
202                          if (json) {              //             if (json) {
203                              if (json[1] === user.id && timeout.row.filePath.endsWith('tempban-remove')) {              //                 if (json[1] === user.id && timeout.row.filePath.endsWith('tempban-remove')) {
204                                  await clearTimeoutv2(timeout);              //                     await clearTimeoutv2(timeout);
205                              }              //                 }
206                          }              //             }
207                      }              //         }
208                      catch (e) {              //         catch (e) {
209                          console.log(e);                                  //             console.log(e);                    
210                      }              //         }
211                //     }
212                // }
213    
214                // await setTimeoutv2('tempban-remove', time, msg.guild!.id, 'unban ' + user.id, user.id, msg.guild!.id);
215    
216                for await (const queue of client.queueManager.queues.values()) {
217                    if (queue instanceof UnbanQueue && queue.data!.userID === user.id && queue.data!.guildID === msg.guild!.id) {
218                        await queue.cancel();
219                  }                  }
220              }              }
221    
222              await setTimeoutv2('tempban-remove', time, msg.guild!.id, 'unban ' + user.id, user.id, msg.guild!.id);              await client.queueManager.addQueue(UnbanQueue, {
223                    data: {
224                        userID: user.id,
225                        guildID: msg.guild!.id
226                    },
227                    runAt: new Date(Date.now() + time)
228                });
229    
230              await client.logger.logTempBan(banOptions, msg.guild!, user, punishment);              await client.logger.logTempBan(banOptions, msg.guild!, user, punishment);
231    

Legend:
Removed from v.186  
changed lines
  Added in v.428

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26