/[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 80 by rakin, Mon Jul 29 17:28:30 2024 UTC revision 206 by rakin, Mon Jul 29 17:29:01 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 8  import getUser from '../../utils/getUser Line 8  import getUser from '../../utils/getUser
8  import getMember from '../../utils/getMember';  import getMember from '../../utils/getMember';
9  import History from '../../automod/History';  import History from '../../automod/History';
10  import { fetchEmoji } from '../../utils/Emoji';  import { fetchEmoji } from '../../utils/Emoji';
11    import { hasPermission, shouldNotModerate } from '../../utils/util';
12    
13  export default class ClearCommand extends BaseCommand {  export default class ClearCommand extends BaseCommand {
14      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
15        permissions = [Permissions.FLAGS.MANAGE_MESSAGES];
16    
17      constructor() {      constructor() {
18          super('clear', 'moderation', []);          super('clear', 'moderation', []);
# Line 89  export default class ClearCommand extend Line 91  export default class ClearCommand extend
91              return;              return;
92          }          }
93    
94            if (user) {
95                try {
96                    const member = await msg.guild?.members.fetch(user.id);
97    
98                    if (member && !(await hasPermission(client, member, msg, null, "You don't have permission to clear messages from this user.")))
99                        return;
100    
101                    if (member && shouldNotModerate(client, member)) {
102                        await msg.reply({
103                            embeds: [
104                                { description: "Cannot clear messages from this user: Operation not permitted" }
105                            ]
106                        });
107                        
108                        return;
109                    }
110                }
111                catch (e) {
112                    console.log(e);
113                }
114            }
115    
116          let count = 0;          let count = 0;
117          (global as any).deletingMessages = true;          (global as any).deletingMessages = true;
118    
# Line 110  export default class ClearCommand extend Line 134  export default class ClearCommand extend
134    
135              do {              do {
136                  fetched = await (channel as TextChannel).messages.fetch({ limit: 100 });                  fetched = await (channel as TextChannel).messages.fetch({ limit: 100 });
137                  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));
138                  await (channel as TextChannel).bulkDelete(fetched);                  await (channel as TextChannel).bulkDelete(fetched);
139                    count += fetched.size;
140    
141                    /*for await (const [id, m] of fetched.entries()) {
142                        try {
143                            await m.delete();
144                            count++;
145                        }
146                        catch (e) {
147                            console.log('Error deleting message', e);
148                        }
149                    }
150                    */
151                    
152                  await new Promise(r => setTimeout(r, 900));                  await new Promise(r => setTimeout(r, 900));
                 count += await fetched.size;  
153              }              }
154              while (fetched.size >= 2);              while (fetched.size >= 2);
155          }          }
# Line 190  export default class ClearCommand extend Line 226  export default class ClearCommand extend
226              await message!.edit(messageOptions);              await message!.edit(messageOptions);
227          }          }
228    
229            setTimeout(async () => {
230                try {
231                    if (msg instanceof Message)
232                        await msg.delete();
233                }
234                catch (e) {
235                    console.log(e);                
236                }
237                
238                try {
239                    await message!.delete();
240                }
241                catch (e) {
242                    console.log(e);                
243                }
244            }, 5500);
245    
246          (global as any).deletingMessages = false;          (global as any).deletingMessages = false;
247      }      }
 }  
248    }

Legend:
Removed from v.80  
changed lines
  Added in v.206

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26