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

Contents of /trunk/commands/help.js

Parent Directory Parent Directory | Revision Log Revision Log


Revision 47 - (show 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 const { MessageActionRow, MessageButton } = require("discord.js");
2 const MessageEmbed = require("../src/MessageEmbed");
3 const { escapeRegex } = require("../src/util");
4
5 module.exports = {
6 version: "1.9.0",
7 commands: [
8 {
9 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 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 name: 'stats',
315 shortBrief: "Show the server stats.",
316 description: null,
317 structure: "",
318 example: "`%%stats",
319 notes: null
320 },
321 {
322 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 shortBrief: "Unlock a specific channel.",
332 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 "--raid": "Unlock all Raid-locked channels"
350 }
351 },
352 {
353 name: 'unmute',
354 shortBrief: "Unmute someone in this server.",
355 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 .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 .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 .setDescription("`<...>` means required argument, `[...]` means optional argument.\n\n" + (cmd.description !== null ? cmd.description : cmd.shortBrief))
466 .addFields(fields)
467 ]
468 });
469 }
470 };

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26