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

Contents of /branches/4.x/src/commands/moderation/LockallCommand.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: 7115 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 { Collection, CommandInteraction, Message, Permissions, Role, TextChannel, User } from 'discord.js';
21 import BaseCommand from '../../utils/structures/BaseCommand';
22 import CommandOptions from '../../types/CommandOptions';
23 import InteractionOptions from '../../types/InteractionOptions';
24 import DiscordClient from '../../client/Client';
25 import MessageEmbed from '../../client/MessageEmbed';
26
27 export async function lockAll(client: DiscordClient, role: Role, channels: Collection <string, TextChannel> | TextChannel[], user: User, send: boolean = true, reason?: string) {
28 if (role) {
29 // const gen = await channels.first()!.guild.roles.fetch(client.config.props[channels.first()!.guild.id].gen_role);
30
31 try {
32 return await client.channelLock.lockAll(channels instanceof Collection ? [...channels.values()] : channels, user, {
33 role,
34 sendConfirmation: send,
35 reason
36 });
37 }
38 catch (e) {
39 console.log(e);
40 }
41 }
42 }
43
44 export default class LockallCommand extends BaseCommand {
45 supportsInteractions: boolean = true;
46 permissions = [Permissions.FLAGS.MANAGE_CHANNELS];
47
48 constructor() {
49 super('lockall', 'moderation', []);
50 }
51
52 async run(client: DiscordClient, msg: Message | CommandInteraction, options: CommandOptions | InteractionOptions) {
53 if (!options.isInteraction && typeof options.args[0] === 'undefined') {
54 await msg.reply({
55 embeds: [
56 new MessageEmbed()
57 .setColor('#f14a60')
58 .setDescription(`This command requires at least one argument.`)
59 ]
60 });
61
62 return;
63 }
64
65 if (msg instanceof CommandInteraction) {
66 await msg.deferReply({ ephemeral: true });
67 }
68
69 const raid = options.isInteraction ? options.options.getBoolean('raid') === true : (options.options.indexOf('--raid') !== -1);
70
71 let role: Role = <Role> msg.guild!.roles.everyone;
72 let lockall: string[] = [], lockallChannels: TextChannel[] = [];
73 let reason: string | undefined;
74 // const force = options.isInteraction ? options.options.getBoolean('force') === true : (options.options.indexOf('--force') !== -1);
75
76 if (options.isInteraction) {
77 if (options.options.getString('channels'))
78 lockall = options.options.getString('channels')!.split(' ').filter(a => /^\d+$/gi.test(a) || a.startsWith('<#'));
79
80 if (options.options.getRole('role')) {
81 role = await <Role> options.options.getRole('role');
82 }
83
84 if (options.options.getString('reason')) {
85 reason = await <string> options.options.getString('reason');
86 }
87 }
88 else {
89 if ((msg as Message).mentions.roles.first()) {
90 role = await <Role> (msg as Message).mentions.roles.first();
91 }
92
93 if (!role) {
94 await msg.reply({
95 embeds: [
96 new MessageEmbed()
97 .setColor('#f14a60')
98 .setDescription(`Invalid role given.`)
99 ],
100 ephemeral: true
101 });
102
103 return;
104 }
105
106 if (!raid) {
107 lockall = options.normalArgs.filter(a => /^\d+$/gi.test(a) || a.startsWith('<#'));
108 }
109 else {
110 if (msg.guild!.channels.cache.size < 2) {
111 await msg.guild?.channels.fetch();
112 }
113
114 const raidChannels = client.config.get('raid').channels;
115
116 if (client.config.get('raid').exclude) {
117 lockall = [];
118
119 for await (const [id, { parent, type }] of msg.guild!.channels.cache) {
120 if (type === 'GUILD_CATEGORY')
121 continue;
122
123 if ((raidChannels.includes(id) || raidChannels.includes(parent?.id))) {
124 continue;
125 }
126
127 lockall.push(id);
128 }
129 }
130 else {
131 // for await (const [id, { parent, type }] of msg.guild!.channels.cache) {
132 // if (type === 'GUILD_CATEGORY')
133 // continue;
134
135 // if ((!raidChannels.includes(id) && !raidChannels.includes(parent?.id))) {
136 // continue;
137 // }
138
139 // lockall.push(id);
140 // }
141
142 lockall = raidChannels;
143 }
144
145 console.log("Raid", lockall);
146 console.log("Raid 1", client.config.get('raid').channels);
147 }
148 }
149
150 if (lockall.length === 0 && !raid) {
151 await this.deferReply(msg, {
152 content: "No channel specified!"
153 });
154
155 return;
156 }
157
158 if (msg.guild!.channels.cache.size < 2) {
159 await msg.guild?.channels.fetch();
160 }
161
162 for await (const c of lockall) {
163 console.log(c);
164 const id = c.startsWith('<#') ? c.substring(2, c.length - 1) : c;
165
166 if (lockallChannels.find(c => c.id === id))
167 continue;
168
169 const channel = msg.guild?.channels.cache.get(id);
170
171 if (!channel) {
172 continue;
173 }
174
175 if (!channel.isText()) {
176 lockallChannels = [...lockallChannels, ...(msg.guild?.channels.cache.filter(c => c.parent?.id === id) as Collection<string, TextChannel>).values()!];
177 continue;
178 }
179
180 lockallChannels.push(channel as TextChannel);
181 }
182
183 console.log("Array: ", lockallChannels, lockall);
184
185 const [success, failure] = (await lockAll(client, role, lockallChannels, msg.member!.user as User, true, reason))!;
186
187 if (options.isInteraction) {
188 await this.deferReply(msg, {
189 content: "Locked " + lockallChannels.length + " channel(s)." + (failure > 0 ? ` ${success} successful locks and ${failure} failed locks.` : '')
190 });
191 }
192 else {
193 await (msg as Message).react('🔒');
194 }
195 }
196 }

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26