/[sudobot]/trunk/src/commands/moderation/ClearCommand.ts
ViewVC logotype

Diff of /trunk/src/commands/moderation/ClearCommand.ts

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 153 by rakin, Mon Jul 29 17:28:48 2024 UTC revision 393 by rakin, Mon Jul 29 17:29:59 2024 UTC
# Line 1  Line 1 
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', []);
# Line 94  export default class ClearCommand extend Line 112  export default class ClearCommand extend
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: [
# Line 106  export default class ClearCommand extend Line 127  export default class ClearCommand extend
127              }              }
128              catch (e) {              catch (e) {
129                  console.log(e);                  console.log(e);
                 return;  
130              }              }
131          }          }
132    
# Line 131  export default class ClearCommand extend Line 151  export default class ClearCommand extend
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          }          }
# Line 219  export default class ClearCommand extend Line 251  export default class ClearCommand extend
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              }              }

Legend:
Removed from v.153  
changed lines
  Added in v.393

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26