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

Contents of /branches/4.x/src/commands/moderation/FakeBanCommand.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: 7534 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, ChatInputApplicationCommandData, CommandInteraction, Message, Permissions, User } 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 { shouldNotModerate, hasPermission, generateInfractionDescription } from '../../utils/util';
28
29 export default class FakeBanCommand extends BaseCommand {
30 supportsInteractions: boolean = true;
31 permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
32
33 constructor() {
34 super('fakeban', 'moderation', ['fban']);
35 }
36
37 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
38 if (!options.isInteraction && typeof options.args[0] === 'undefined') {
39 await msg.reply({
40 embeds: [
41 new MessageEmbed()
42 .setColor('#f14a60')
43 .setDescription(`This command requires at least one argument.`)
44 ]
45 });
46
47 return;
48 }
49
50 let user: User;
51 let banOptions: BanOptions = {};
52
53 if (options.isInteraction) {
54 user = await <User> options.options.getUser('user');
55
56 if (options.options.getString('reason')) {
57 banOptions.reason = await <string> options.options.getString('reason');
58 }
59
60 if (options.options.getInteger('days')) {
61 banOptions.days = await <number> options.options.getInteger('days');
62 }
63 }
64 else {
65 const user2 = await getUser(client, (msg as Message), options);
66
67 if (!user2) {
68 await msg.reply({
69 embeds: [
70 new MessageEmbed()
71 .setColor('#f14a60')
72 .setDescription(`Invalid user given.`)
73 ]
74 });
75
76 return;
77 }
78
79 user = user2;
80
81 const index = await options.args.indexOf('-d');
82
83 if (options.args[1]) {
84 const args = [...options.args];
85 args.shift();
86
87 if (index !== -1) {
88 args.splice(index - 1, 2)
89 }
90
91 banOptions.reason = await args.join(' ');
92 }
93
94 if (index !== -1) {
95 const days = await options.args[index + 1];
96
97 if (days === undefined) {
98 await msg.reply({
99 embeds: [
100 new MessageEmbed()
101 .setColor('#f14a60')
102 .setDescription(`Option \`-d\` (days) requires an argument.`)
103 ]
104 });
105
106 return;
107 }
108
109 if (!parseInt(days) || parseInt(days) < 0 || parseInt(days) > 7) {
110 await msg.reply({
111 embeds: [
112 new MessageEmbed()
113 .setColor('#f14a60')
114 .setDescription(`Option \`-d\` (days) requires an argument which must be a valid number and in range of 0-7.`)
115 ]
116 });
117
118 return;
119 }
120
121 banOptions.days = await parseInt(days);
122 }
123 }
124
125 try {
126 const member = await msg.guild?.members.fetch(user.id);
127
128 if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to ban this user."))) {
129 return;
130 }
131
132 if (member && shouldNotModerate(client, member)) {
133 await msg.reply({
134 embeds: [
135 new MessageEmbed()
136 .setColor('#f14a60')
137 .setDescription('Cannot ban this user: Operation not permitted')
138 ]
139 });
140
141 return;
142 }
143 }
144 catch (e) {
145 console.log(e);
146 }
147
148 try {
149 const id = Math.round(Math.random() * 10000);
150
151 user.send({
152 embeds: [
153 new MessageEmbed({
154 author: {
155 name: `You have been banned in ${msg.guild!.name}`,
156 iconURL: msg.guild!.iconURL() ?? undefined
157 },
158 color: 0xf14a60,
159 description: generateInfractionDescription(client, msg.guildId!, 'ban_message') + "\n||This was just a joke. You were not banned.||",
160 fields: [
161 {
162 name: 'Reason',
163 value: banOptions.reason === undefined ? "*No reason provided*" : banOptions.reason
164 },
165 {
166 name: 'Infraction ID',
167 value: id + ''
168 }
169 ]
170 })
171 ]
172 }).catch(console.error);
173
174 await msg.reply({
175 embeds: [
176 new MessageEmbed()
177 .setAuthor({
178 name: user.tag,
179 iconURL: user.displayAvatarURL(),
180 })
181 .setDescription(user.tag + " has been banned from this server. || This is fake :joy: ||")
182 .addFields([
183 {
184 name: "Banned by",
185 value: (msg.member!.user as User).tag
186 },
187 {
188 name: "Reason",
189 value: banOptions.reason === undefined ? "*No reason provided*" : banOptions.reason
190 },
191 {
192 name: "Days of message deletion",
193 value: banOptions.days === undefined ? "*No message will be deleted*" : (banOptions.days + '')
194 },
195 {
196 name: 'Infraction ID',
197 value: id + ''
198 }
199 ])
200 ]
201 });
202 }
203 catch (e) {
204 await msg.reply({
205 embeds: [
206 new MessageEmbed()
207 .setColor('#f14a60')
208 .setDescription("Failed to ban this user. Maybe missing permisions or I'm not allowed to ban this user?")
209 ]
210 });
211
212 return;
213 }
214 }
215 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26