/[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 194 by rakin, Mon Jul 29 17:28:58 2024 UTC
# 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 { shouldNotModerate } from '../../utils/util';  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;
# 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 hasPermissions(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.194

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26