/[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 341 by rakin, Mon Jul 29 17:29:38 2024 UTC
# Line 1  Line 1 
1  import { BanOptions, CommandInteraction, Emoji, GuildChannel, GuildMember, Interaction, Message, TextChannel, User } from 'discord.js';  import { BanOptions, CommandInteraction, Emoji, GuildChannel, GuildMember, Interaction, Message, TextChannel, User, Permissions } from 'discord.js';
2  import BaseCommand from '../../utils/structures/BaseCommand';  import BaseCommand from '../../utils/structures/BaseCommand';
3  import DiscordClient from '../../client/Client';  import DiscordClient from '../../client/Client';
4  import CommandOptions from '../../types/CommandOptions';  import CommandOptions from '../../types/CommandOptions';
# Line 6  import InteractionOptions from '../../ty Line 6  import InteractionOptions from '../../ty
6  import MessageEmbed from '../../client/MessageEmbed';  import MessageEmbed from '../../client/MessageEmbed';
7  import getUser from '../../utils/getUser';  import getUser from '../../utils/getUser';
8  import getMember from '../../utils/getMember';  import getMember from '../../utils/getMember';
 import History from '../../automod/History';  
9  import { fetchEmoji } from '../../utils/Emoji';  import { fetchEmoji } from '../../utils/Emoji';
10  import { shouldNotModerate } from '../../utils/util';  import { hasPermission, shouldNotModerate } from '../../utils/util';
11    
12  export default class ClearCommand extends BaseCommand {  export default class ClearCommand extends BaseCommand {
13      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
14        permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
15    
16      constructor() {      constructor() {
17          super('clear', 'moderation', []);          super('clear', 'moderation', []);
# Line 94  export default class ClearCommand extend Line 94  export default class ClearCommand extend
94              try {              try {
95                  const member = await msg.guild?.members.fetch(user.id);                  const member = await msg.guild?.members.fetch(user.id);
96    
97                    if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to clear messages from this user.")))
98                        return;
99    
100                  if (member && shouldNotModerate(client, member)) {                  if (member && shouldNotModerate(client, member)) {
101                      await msg.reply({                      await msg.reply({
102                          embeds: [                          embeds: [
# Line 106  export default class ClearCommand extend Line 109  export default class ClearCommand extend
109              }              }
110              catch (e) {              catch (e) {
111                  console.log(e);                  console.log(e);
                 return;  
112              }              }
113          }          }
114    
# Line 131  export default class ClearCommand extend Line 133  export default class ClearCommand extend
133    
134              do {              do {
135                  fetched = await (channel as TextChannel).messages.fetch({ limit: 100 });                  fetched = await (channel as TextChannel).messages.fetch({ limit: 100 });
136                  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));
137                  await (channel as TextChannel).bulkDelete(fetched);                  await (channel as TextChannel).bulkDelete(fetched);
138                    count += fetched.size;
139    
140                    /*for await (const [id, m] of fetched.entries()) {
141                        try {
142                            await m.delete();
143                            count++;
144                        }
145                        catch (e) {
146                            console.log('Error deleting message', e);
147                        }
148                    }
149                    */
150                    
151                  await new Promise(r => setTimeout(r, 900));                  await new Promise(r => setTimeout(r, 900));
                 count += await fetched.size;  
152              }              }
153              while (fetched.size >= 2);              while (fetched.size >= 2);
154          }          }
# Line 219  export default class ClearCommand extend Line 233  export default class ClearCommand extend
233              catch (e) {              catch (e) {
234                  console.log(e);                                  console.log(e);                
235              }              }
236                
237              try {              try {
238                  await message!.delete();                  await message!.delete();
239              }              }

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26