1 |
import { BanOptions, CommandInteraction, Emoji, GuildChannel, GuildMember, Interaction, Message, TextChannel, 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 { CommandInteraction, Emoji, GuildChannel, Message, TextChannel, 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 getMember from '../../utils/getMember'; |
|
|
import History from '../../automod/History'; |
|
27 |
import { fetchEmoji } from '../../utils/Emoji'; |
import { fetchEmoji } from '../../utils/Emoji'; |
28 |
import { shouldNotModerate } from '../../utils/util'; |
import { hasPermission, shouldNotModerate } from '../../utils/util'; |
29 |
|
|
30 |
export default class ClearCommand extends BaseCommand { |
export default class ClearCommand extends BaseCommand { |
31 |
supportsInteractions: boolean = true; |
supportsInteractions: boolean = true; |
32 |
|
permissions = [Permissions.FLAGS.MANAGE_MESSAGES]; |
33 |
|
|
34 |
constructor() { |
constructor() { |
35 |
super('clear', 'moderation', []); |
super('clear', 'moderation', []); |
112 |
try { |
try { |
113 |
const member = await msg.guild?.members.fetch(user.id); |
const member = await msg.guild?.members.fetch(user.id); |
114 |
|
|
115 |
|
if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to clear messages from this user."))) |
116 |
|
return; |
117 |
|
|
118 |
if (member && shouldNotModerate(client, member)) { |
if (member && shouldNotModerate(client, member)) { |
119 |
await msg.reply({ |
await msg.reply({ |
120 |
embeds: [ |
embeds: [ |
127 |
} |
} |
128 |
catch (e) { |
catch (e) { |
129 |
console.log(e); |
console.log(e); |
|
return; |
|
130 |
} |
} |
131 |
} |
} |
132 |
|
|
151 |
|
|
152 |
do { |
do { |
153 |
fetched = await (channel as TextChannel).messages.fetch({ limit: 100 }); |
fetched = await (channel as TextChannel).messages.fetch({ limit: 100 }); |
154 |
fetched = await fetched.filter(m => m.author.id === user!.id && m.id !== message!.id && (Date.now() - m.createdTimestamp) <= (2 * 7 * 24 * 60 * 60)); |
fetched = await fetched.filter(m => m.author.id === user!.id && m.id !== message!.id && (Date.now() - m.createdTimestamp) <= (2 * 7 * 24 * 60 * 60 * 1000)); |
155 |
await (channel as TextChannel).bulkDelete(fetched); |
await (channel as TextChannel).bulkDelete(fetched); |
156 |
|
count += fetched.size; |
157 |
|
|
158 |
|
/*for await (const [id, m] of fetched.entries()) { |
159 |
|
try { |
160 |
|
await m.delete(); |
161 |
|
count++; |
162 |
|
} |
163 |
|
catch (e) { |
164 |
|
console.log('Error deleting message', e); |
165 |
|
} |
166 |
|
} |
167 |
|
*/ |
168 |
|
|
169 |
await new Promise(r => setTimeout(r, 900)); |
await new Promise(r => setTimeout(r, 900)); |
|
count += await fetched.size; |
|
170 |
} |
} |
171 |
while (fetched.size >= 2); |
while (fetched.size >= 2); |
172 |
} |
} |
251 |
catch (e) { |
catch (e) { |
252 |
console.log(e); |
console.log(e); |
253 |
} |
} |
254 |
|
|
255 |
try { |
try { |
256 |
await message!.delete(); |
await message!.delete(); |
257 |
} |
} |