/[sudobot]/branches/3.x/src/commands/moderation/MassBanCommand.ts
ViewVC logotype

Contents of /branches/3.x/src/commands/moderation/MassBanCommand.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: 6630 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 { fetchEmoji } from '../../utils/Emoji';
27 import Punishment from '../../models/Punishment';
28 import PunishmentType from '../../types/PunishmentType';
29 import { hasPermission, shouldNotModerate } from '../../utils/util';
30
31 export default class MassBanCommand extends BaseCommand {
32 supportsInteractions: boolean = true;
33
34 permissions = [Permissions.FLAGS.BAN_MEMBERS];
35
36 constructor() {
37 super('massban', 'moderation', []);
38 }
39
40 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
41 if (!options.isInteraction && typeof options.args[0] === 'undefined') {
42 await msg.reply({
43 embeds: [
44 new MessageEmbed()
45 .setColor('#f14a60')
46 .setDescription(`This command requires at least one argument.`)
47 ]
48 });
49
50 return;
51 }
52
53 if (msg instanceof CommandInteraction)
54 await msg.deferReply();
55
56 let arr: (string | User)[] = [];
57 let reasonStart = false;
58 let banOptions: BanOptions = {};
59
60 if (options.isInteraction) {
61 arr = (<string> options.options.getString('users')).split(' ');
62
63 if (options.options.getString('reason'))
64 banOptions.reason = <string> options.options.getString('reason');
65
66 if (options.options.getInteger('days'))
67 banOptions.days = <number> options.options.getInteger('days');
68 }
69 else {
70 let i = 0;
71
72 for await (const arg of options.args) {
73 if (!/^\d+$/g.test(arg) && !(arg.startsWith('<@') && arg.endsWith('>'))) {
74 reasonStart = true;
75 }
76
77 if (reasonStart) {
78 banOptions.reason = banOptions.reason ?? '';
79 banOptions.reason += arg + ' ';
80 }
81 else {
82 if (/^\d+$/g.test(arg)) {
83 arr.push(arg);
84 }
85 else if ((msg as Message).mentions.users.at(i)) {
86 arr.push((msg as Message).mentions.users.at(i)! as User);
87 console.log((msg as Message).mentions.users.at(i)!);
88
89 i++;
90 }
91 }
92 }
93
94 if (banOptions.reason) {
95 banOptions.reason = banOptions.reason.trim();
96 }
97 }
98
99 if (arr.length < 1) {
100 await this.deferReply(msg, {
101 embeds: [
102 new MessageEmbed()
103 .setColor('#f14a60')
104 .setDescription(`Invalid user(s) given.`)
105 ]
106 });
107
108 return;
109 }
110
111 let usersStr = '';
112
113 for await (const uid of arr) {
114 try {
115 console.log(uid);
116
117 const user = typeof uid === 'string' ? await client.users.fetch(uid) : uid;
118
119 try {
120 console.log(banOptions.reason);
121
122 try {
123 const member = await msg.guild?.members.fetch(user.id);
124
125 if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to ban " + user.tag + ".")))
126 break;
127
128 if (member && shouldNotModerate(client, member)) {
129 await msg.reply({
130 embeds: [
131 new MessageEmbed()
132 .setColor('#f14a60')
133 .setDescription('The user ' + user.tag + ' is not bannable.')
134 ]
135 });
136
137 return;
138 }
139 }
140 catch (e) {
141 console.log(e);
142 }
143
144 await Punishment.create({
145 type: PunishmentType.BAN,
146 user_id: user.id,
147 guild_id: msg.guild!.id,
148 mod_id: msg.member!.user.id,
149 mod_tag: (msg.member!.user as User).tag,
150 reason: banOptions.reason ?? undefined,
151 createdAt: new Date()
152 });
153
154 await msg.guild!.bans.create(user, banOptions);
155
156 usersStr += user.tag + ' (' + user.id + ')\n';
157 }
158 catch (e) {
159 console.log(e);
160
161 await this.deferReply(msg, {
162 content: 'Failed to ban ' + user.tag + ' (' + user.id + ').'
163 });
164
165 return;
166 }
167 }
168 catch (e) {
169 console.log(e);
170
171 await this.deferReply(msg, {
172 content: 'Invalid ID(s) given. (' + uid.toString() + ')'
173 });
174
175 return;
176 }
177 }
178
179 await this.deferReply(msg, {
180 embeds: [
181 new MessageEmbed()
182 .setAuthor({
183 name: 'Mass Ban'
184 })
185 .setDescription(`${(await fetchEmoji('check'))?.toString()} Mass banned the following users:\n\n${usersStr}`)
186 .addField('Reason', banOptions.reason ?? '*No reason provided*')
187 ]
188 });
189 }
190 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26