/[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 78 by rakin, Mon Jul 29 17:28:30 2024 UTC revision 153 by rakin, Mon Jul 29 17:28:48 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';
12    
13  export default class ClearCommand extends BaseCommand {  export default class ClearCommand extends BaseCommand {
14      supportsInteractions: boolean = true;      supportsInteractions: boolean = true;
# Line 89  export default class ClearCommand extend Line 90  export default class ClearCommand extend
90              return;              return;
91          }          }
92    
93            if (user) {
94                try {
95                    const member = await msg.guild?.members.fetch(user.id);
96    
97                    if (member && shouldNotModerate(client, member)) {
98                        await msg.reply({
99                            embeds: [
100                                { description: "Cannot clear messages from this user: Operation not permitted" }
101                            ]
102                        });
103                        
104                        return;
105                    }
106                }
107                catch (e) {
108                    console.log(e);
109                    return;
110                }
111            }
112    
113          let count = 0;          let count = 0;
114          (global as any).deletingMessages = true;          (global as any).deletingMessages = true;
115    
# Line 110  export default class ClearCommand extend Line 131  export default class ClearCommand extend
131    
132              do {              do {
133                  fetched = await (channel as TextChannel).messages.fetch({ limit: 100 });                  fetched = await (channel as TextChannel).messages.fetch({ limit: 100 });
134                  fetched = await fetched.filter(m => m.author.id === user!.id && m.id !== message!.id);                  fetched = await fetched.filter(m => m.author.id === user!.id && m.id !== message!.id && (Date.now() - m.createdTimestamp) <= (2 * 7 * 24 * 60 * 60));
135                  await (channel as TextChannel).bulkDelete(fetched);                  await (channel as TextChannel).bulkDelete(fetched);
136                  await new Promise(r => setTimeout(r, 900));                  await new Promise(r => setTimeout(r, 900));
137                  count += await fetched.size;                  count += await fetched.size;
# Line 141  export default class ClearCommand extend Line 162  export default class ClearCommand extend
162                                  continue;                                  continue;
163                              }                              }
164    
165                              if (message!.id === m.id)                              if (message!.id === m.id || (Date.now() - m.createdTimestamp) > (2 * 7 * 24 * 60 * 60 * 1000))
166                                  continue;                                  continue;
167    
168                              if (m.deletable) {                              if (m.deletable) {
# Line 160  export default class ClearCommand extend Line 181  export default class ClearCommand extend
181                          }                          }
182                          catch(e) {                          catch(e) {
183                              console.log(e);                              console.log(e);
                               
184                              safeLimit2 += 100;                              safeLimit2 += 100;
185                          }                          }
186                      }                      }
# Line 191  export default class ClearCommand extend Line 211  export default class ClearCommand extend
211              await message!.edit(messageOptions);              await message!.edit(messageOptions);
212          }          }
213    
214            setTimeout(async () => {
215                try {
216                    if (msg instanceof Message)
217                        await msg.delete();
218                }
219                catch (e) {
220                    console.log(e);                
221                }
222    
223                try {
224                    await message!.delete();
225                }
226                catch (e) {
227                    console.log(e);                
228                }
229            }, 5500);
230    
231          (global as any).deletingMessages = false;          (global as any).deletingMessages = false;
232      }      }
 }  
233    }

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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26