/[sudobot]/trunk/commands/help.js
ViewVC logotype

Annotation of /trunk/commands/help.js

Parent Directory Parent Directory | Revision Log Revision Log


Revision 47 - (hide annotations)
Mon Jul 29 17:28:21 2024 UTC (8 months, 1 week ago) by rakin
File MIME type: text/javascript
File size: 17642 byte(s)
Added clearTimeoutv2() function
1 rakin 11 const { MessageActionRow, MessageButton } = require("discord.js");
2     const MessageEmbed = require("../src/MessageEmbed");
3     const { escapeRegex } = require("../src/util");
4    
5     module.exports = {
6 rakin 47 version: "1.9.0",
7 rakin 11 commands: [
8     {
9 rakin 47 name: 'about',
10     shortBrief: "Show information about the bot.",
11     description: null,
12     structure: "",
13     example: "`%%about`",
14     notes: null
15     },
16     {
17     name: 'addqueue',
18     shortBrief: "Add a queue job.",
19     description: 'Adds a queued command to the bot\'s memory and after the given amount of time it gets executed.',
20     structure: "<time> <command>",
21     example: "`%%addqueue 15m echo Hello world`\n`%%addqueue 12h kick 875275828247255`",
22     notes: null
23     },
24     {
25 rakin 11 name: 'addsnippet',
26     shortBrief: "Adds a snippet.",
27     description: null,
28     structure: "<Name> <Content>",
29     example: "`%%addsnippet roles There are 2 roles`\n`%%addsnippet roles There are 2 roles\nAdmin - Administrator\nMod - Moderator`",
30     notes: null
31     },
32     {
33 rakin 30 name: 'afk',
34     shortBrief: "Keeps track of your mentions and tells other users that you're AFK.",
35     description: null,
36     structure: "[Reason]",
37     example: "`%%afk`\n`%%afk Having dinner`",
38     notes: null
39     },
40     {
41 rakin 11 name: 'announce',
42     shortBrief: "Announce something in the given channel.",
43     description: "Announce something in the given channel. The channel should be set in the configuration.",
44     structure: "<Content>",
45     example: "`%%announce Hello there!\nWe've just finished our job!\n@everyone`",
46     notes: null
47     },
48     {
49     name: 'ban',
50     shortBrief: "Ban someone in this server.",
51 rakin 37 description: "Ban a user. `-d` is the number days old messages to delete. It must be in range 0-7. If `-d` is passed then an argument after it is required.",
52     structure: "<UserID|Mention> [-d=DAYS] [Reason]",
53     example: "`%%ban 385753607325075320`\n`%%ban @Someone You are spamming a lot`\n`%%ban @Someone -d 5`\n`%%ban 385753607325075320 -d 5 You are spamming a lot`",
54 rakin 11 notes: null
55     },
56     {
57     name: 'bean',
58     shortBrief: "Bean someone in this server.",
59     description: "Bean someone. It doesn't do anything except pretending.",
60     structure: "<UserID|Mention> [Reason]",
61     example: "`%%bean 385753607325075320`\n`%%bean @Someone You are spamming a lot`",
62     notes: null
63     },
64     {
65     name: 'cat',
66     shortBrief: "Get a random kitty picture.",
67     description: "Fetches a random cat picture from `thecatapi.com` API.",
68     structure: "",
69     example: "`%%cat`",
70     notes: null
71     },
72     {
73 rakin 26 name: 'clear',
74     shortBrief: "Clear all messages from a user.",
75     description: "Clear all messages from a user, in the current channel. This might take a while.",
76     structure: "<UserID|UserMention>",
77     example: "`%%clear 83474924191884727`\n`%%clear @Someone`",
78     notes: null
79     },
80     {
81 rakin 47 name: 'Delete a queue job.',
82     shortBrief: "Delete a queued command by its ID.",
83     description: null,
84     structure: "<QueueID>",
85     example: "`%%delqueue 80`",
86     notes: null
87     },
88     {
89 rakin 11 name: 'delsnippet',
90     shortBrief: "Deletes a snippet.",
91     description: null,
92     structure: "<Name>",
93     example: "`%%delsnippet roles`",
94     notes: null
95     },
96     {
97     name: 'dog',
98     shortBrief: "Get a random doggy picture.",
99     description: "Fetches a random cat picture from `thedogapi.com` API.",
100     structure: "",
101     example: "`%%dog`",
102     notes: null
103     },
104     {
105     name: 'echo',
106     shortBrief: "Echo (re-send) a message.",
107     description: "Re-send a message from the bot.",
108     structure: "<content> [channelMention]",
109     example: "`%%echo Something\nVery Cool`\n`%%echo Something\nVery Cool #general`",
110     notes: null
111     },
112     {
113 rakin 45 name: 'expire',
114     shortBrief: "Echo (re-send) a message and delete it after the given time.",
115     description: "Re-send a message from the bot and delete it automatically after the given time interval.",
116     structure: "<timeInterval> <content> [channelMention]",
117     example: "`%%echo 25m Something\nVery Cool`\n`%%echo 1h Something\nVery Cool #general`",
118     notes: null
119     },
120     {
121     name: 'expiresc',
122     shortBrief: "Schedule a message and delete it after the given time.",
123     description: "Schedule a message from the bot and delete it automatically after the given time interval.",
124     structure: "<scheduleTimeInterval> <expireTimeInterval> <content> [channelMention]",
125     example: "`%%echo 25m 5h Something\nVery Cool`\n`%%echo 1h 7d Something\nVery Cool #general`",
126     notes: null
127     },
128     {
129 rakin 11 name: 'general-role',
130     shortBrief: "Set the general role.",
131     description: null,
132     structure: "<RoleID|RoleMention>",
133     example: "`%%general-role 937923625698638`\n`%%general-role @General`",
134     notes: null
135     },
136     {
137     name: 'help',
138     shortBrief: "Show this help and exit.",
139     description: null,
140     structure: "[command]",
141     example: "`%%help`\n`%%help mute`",
142     notes: null
143     },
144     {
145 rakin 26 name: 'history',
146     shortBrief: "Show moderation history for a user.",
147     description: null,
148     structure: "<UserMention|UserID>",
149     example: "`%%history 27372628277272625`\n`%%history @Someone`",
150     notes: null
151     },
152     {
153 rakin 11 name: 'httpcat',
154     shortBrief: "Get some funny cat memes related to HTTP.",
155     description: "Get some funny cat memes related to HTTP status codes, using http.cat API.",
156     structure: "<status>",
157     example: "`%%httpcat 403`",
158     notes: null
159     },
160     {
161     name: 'httpdog',
162     shortBrief: "Get some funny dog memes related to HTTP.",
163     description: "Get some funny dog memes related to HTTP status codes, using http.dog API.",
164     structure: "<status>",
165     example: "`%%httpdog 403`",
166     notes: null
167     },
168     {
169     name: 'kick',
170     shortBrief: "Kick someone from this server.",
171     description: null,
172     structure: "<UserID|Mention> [Reason]",
173     example: "`%%kick 385753607325075320`\n`%%kick @Someone You are spamming a lot`",
174     notes: null
175     },
176     {
177     name: 'lock',
178     shortBrief: "Lock a specific channel.",
179     description: "Makes the given channel read-only for the general members. If no channel is present, the current channel will be locked.",
180     structure: "[ChannelID|ChannelMention] [...options]",
181     example: "`%%lock 385753607325075320`\n`%%lock #general`\n`%%lock`",
182     notes: null,
183     options: {
184     "--no-send": "Do not send a confirmation message to the locked channel",
185     }
186     },
187     {
188     name: 'lockall',
189     shortBrief: "Lock all the channels given in the configuration.",
190     description: "Makes the given channels read-only for the general members.",
191     structure: "[...options]",
192     example: "`%%lockall --no-send\n`%%lockall`\n`%%lockall --everyone`",
193     notes: null,
194     options: {
195     "--no-send": "Do not send a confirmation message to the locked channel",
196     }
197     },
198     {
199     name: 'mod-role',
200     shortBrief: "Set the moderator role.",
201     description: null,
202     structure: "<RoleID|RoleMention>",
203     example: "`%%mod-role 937923625698638`\n`%%mod-role @Moderator`",
204     notes: null
205     },
206     {
207     name: 'mute',
208     shortBrief: "Mute someone in this server.",
209     description: null,
210     structure: "<UserID|Mention> [-t=DURATION] [Reason]",
211     example: "`%%mute 385753607325075320`\n`%%mute @Someone You are spamming a lot`\n`%%mute @Someone -t 10m You are spamming a lot`",
212     options: {
213     "-t": "Set the mute duration"
214     },
215     notes: null
216     },
217     {
218     name: 'muted-role',
219     shortBrief: "Set the muted role.",
220     description: null,
221     structure: "<RoleID|RoleMention>",
222     example: "`%%muted-role 937923625698638`\n`%%muted-role @Muted`",
223     notes: null
224     },
225     {
226     name: 'mvsnippet',
227     shortBrief: "Rename a snippet.",
228     description: null,
229     structure: "<oldName> <newName>",
230     example: "`%%mvsnippet abc bca`",
231     notes: null
232     },
233     {
234     name: 'note',
235     shortBrief: "Take a note about an user.",
236     description: null,
237     structure: "<UserID|UserMention> <note>",
238     example: "`%%note @Someone Simple note.`",
239     notes: null
240     },
241     {
242     name: 'notedel',
243     shortBrief: "Delete a note.",
244     description: null,
245     structure: "<NoteID>",
246     example: "`%%notedel 922`",
247     notes: null
248     },
249     {
250     name: 'noteget',
251     shortBrief: "Get a note.",
252     description: null,
253     structure: "<NoteID>",
254     example: "`%%noteget 922`",
255     notes: null
256     },
257     {
258     name: 'notes',
259     shortBrief: "Get all notes for a specific user.",
260     description: null,
261     structure: "<UserID|UserMention>",
262     example: "`%%notes @Someone`",
263     notes: null
264     },
265     {
266     name: 'pixabay',
267     shortBrief: "Fetch images from Pixabay.",
268     description: "Search & fetch images from Pixabay API.\n\nAvailable Subcommands:\n\tphoto - Fetch photos only.\n\tvector - Fetch vectors only.\n\tillustration - Fetch illustrations only\n\timage - Fetch any image.",
269     structure: "<subcommand> [query]",
270     example: "`%%pixabay image`\n`%%pixabay photo birds`",
271     notes: null
272     },
273     {
274     name: 'prefix',
275     shortBrief: "Change the bot prefix.",
276     description: null,
277     structure: "<NewPrefix>",
278     example: "`%%prefix -`",
279     notes: null
280     },
281     {
282 rakin 45 name: 'schedule',
283     shortBrief: "Echo (re-send) a message after the given time.",
284     description: "Re-send a message from the bot automatically after the given time interval.",
285     structure: "<timeInterval> <content> [channelMention]",
286     example: "`%%echo 25m Something\nVery Cool`\n`%%echo 1h Something\nVery Cool #general`",
287     notes: null
288     },
289     {
290 rakin 11 name: 'setconfig',
291     shortBrief: "Change the bot configuration keys.",
292     description: null,
293     structure: "<key> <value>",
294     example: "`%%setconfig debug true`",
295     notes: null
296     },
297     {
298 rakin 27 name: 'send',
299     shortBrief: "Send a DM to a user.",
300     description: null,
301     structure: "<UserID|Mention> <content>",
302     example: "`%%send 278358918549759428 Hello world`\n`%%send @Someone Hello world`",
303     notes: null
304     },
305     {
306 rakin 11 name: 'spamfilter',
307     shortBrief: "Change the spam filter configuration keys.",
308     description: null,
309     structure: "<key> <value>",
310     example: "`%%spamfilter include #general`",
311     notes: null
312     },
313     {
314 rakin 31 name: 'stats',
315     shortBrief: "Show the server stats.",
316     description: null,
317     structure: "",
318     example: "`%%stats",
319     notes: null
320     },
321     {
322 rakin 11 name: 'unban',
323     shortBrief: "Unban a user from this server.",
324     description: null,
325     structure: "<UserID>",
326     example: "`%%unban 2946255269594753792`",
327     notes: null
328     },
329     {
330     name: 'unlock',
331 rakin 16 shortBrief: "Unlock a specific channel.",
332 rakin 11 description: "Makes the given channel writable for the general members. If no channel is present, the current channel is unlocked.",
333     structure: "[ChannelID|ChannelMention] [...options]",
334     example: "`%%unlock 385753607325075320`\n`%%unlock #general`\n`%%unlock`",
335     notes: null,
336     options: {
337     "--no-send": "Do not send a confirmation message to the locked channel",
338     }
339     },
340     {
341     name: 'unlockall',
342     shortBrief: "Unlock all the channels given in the configuration.",
343     description: "Makes the given channels writable for the general members.",
344     structure: "[...options]",
345     example: "`%%unlockall --no-send\n`%%unlockall`\n`%%unlockall --everyone`",
346     notes: null,
347     options: {
348     "--no-send": "Do not send a confirmation message to the locked channel",
349 rakin 21 "--raid": "Unlock all Raid-locked channels"
350 rakin 11 }
351     },
352     {
353     name: 'unmute',
354 rakin 16 shortBrief: "Unmute someone in this server.",
355 rakin 11 description: null,
356     structure: "<UserID|Mention>",
357     example: "`%%unmute 385753607325075320`\n`%%unmute @Someone You are spamming a lot`",
358     notes: null
359     },
360     {
361     name: 'warn',
362     shortBrief: "Warn someone in this server.",
363     description: null,
364     structure: "<UserID|Mention> [Reason]",
365     example: "`%%warn 385753607325075320`\n`%%warn @Someone You are spamming a lot`",
366     notes: null
367     },
368     {
369     name: 'warndel',
370     shortBrief: "Delete a warning.",
371     description: null,
372     structure: "<ID>",
373     example: "`%%warndel 39`",
374     notes: null
375     },
376     {
377     name: 'warning',
378     shortBrief: "Show a warning.",
379     description: null,
380     structure: "<ID>",
381     example: "`%%warning 39`",
382     notes: null
383     },
384     {
385     name: 'warnings',
386     shortBrief: "Show all warnings.",
387     description: "Show all warnings in this server. Passing an user will only show their warnings.",
388     structure: "[UserId|Mention]",
389     example: "`%%warnings`\n`%%warnings 948489127957979253978538`",
390     notes: null
391     },
392     ],
393     async render() {
394     let string = '';
395    
396     for (let cmd of this.commands) {
397     string += `\n\n**${cmd.name}**\n${cmd.shortBrief}`;
398     }
399    
400     return string;
401     },
402     async handle(msg, cm) {
403     if (typeof cm.args[0] === 'undefined') {
404     await msg.reply({
405     embeds: [
406     new MessageEmbed()
407 rakin 45 .setDescription("The command list.\n\n`<...>` means required argument, `[...]` means optional argument.\n\nRun `" + app.config.get('prefix') + "help <commandName>` for more information about a specific command.\n" + await this.render())
408 rakin 11 .setTitle('Help')
409     ],
410     });
411    
412     return;
413     }
414    
415     const cmd = this.commands.find(c => c.name === cm.args[0]);
416    
417     if (!cmd) {
418     await msg.reply({
419     embeds: [
420     new MessageEmbed()
421     .setColor('#f14a60')
422     .setDescription(`Invalid command \`${cm.args[0]}\`.`)
423     ]
424     });
425    
426     return;
427     }
428    
429     let fields = [
430     {
431     name: "Usage",
432     value: `\`${app.config.get('prefix')}${cmd.name}\`` + (cmd.structure.trim() !== '' ? ` \`${cmd.structure}\`` : '')
433     },
434     {
435     name: 'Examples',
436     value: cmd.example.replace(/\%\%/g, app.config.get('prefix'))
437     }
438     ];
439    
440     if (cmd.options !== undefined) {
441     let str = '';
442    
443     for (let opt in cmd.options)
444     str += `\`${opt}\` - ${cmd.options[opt]}\n`;
445    
446     str = str.substring(0, str.length - 1);
447    
448     fields.push({
449     name: 'Options',
450     value: str
451     });
452     }
453    
454     if (cmd.notes !== null) {
455     fields.push({
456     name: "Notes",
457     value: cmd.notes
458     });
459     }
460    
461     await msg.reply({
462     embeds: [
463     new MessageEmbed()
464     .setTitle(`${app.config.get('prefix')}${cmd.name}`)
465 rakin 45 .setDescription("`<...>` means required argument, `[...]` means optional argument.\n\n" + (cmd.description !== null ? cmd.description : cmd.shortBrief))
466 rakin 11 .addFields(fields)
467     ]
468     });
469     }
470     };

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26