/[sudobot]/branches/3.x/src/utils/Help.ts
ViewVC logotype

Annotation of /branches/3.x/src/utils/Help.ts

Parent Directory Parent Directory | Revision Log Revision Log


Revision 577 - (hide annotations)
Mon Jul 29 18:52:37 2024 UTC (8 months ago) by rakinar2
File MIME type: application/typescript
File size: 24021 byte(s)
chore: add old version archive branches (2.x to 9.x-dev)
1 rakinar2 577 /**
2     * This file is part of SudoBot.
3     *
4     * Copyright (C) 2021-2022 OSN Inc.
5     *
6     * SudoBot is free software; you can redistribute it and/or modify it
7     * under the terms of the GNU Affero General Public License as published by
8     * the Free Software Foundation, either version 3 of the License, or
9     * (at your option) any later version.
10     *
11     * SudoBot is distributed in the hope that it will be useful, but
12     * WITHOUT ANY WARRANTY; without even the implied warranty of
13     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14     * GNU Affero General Public License for more details.
15     *
16     * You should have received a copy of the GNU Affero General Public License
17     * along with SudoBot. If not, see <https://www.gnu.org/licenses/>.
18     */
19    
20     import { CommandHelpData } from "../types/CommandHelpData";
21    
22     export default <CommandHelpData[]> [
23     {
24     name: 'about',
25     shortBrief: "Show information about the bot.",
26     description: null,
27     structure: "",
28     example: "`%%about`",
29     notes: null,
30     slashCommand: true,
31     legacyCommand: true
32     },
33     {
34     name: 'addqueue',
35     shortBrief: "Add a queue job.",
36     description: 'Adds a queued command to the bot\'s memory and after the given amount of time it gets executed.',
37     structure: "<time> <command>",
38     example: "`%%addqueue 15m echo Hello world`\n`%%addqueue 12h kick 875275828247255`",
39     notes: null,
40     slashCommand: false,
41     legacyCommand: true
42     },
43     {
44     name: 'addsnippet',
45     shortBrief: "Adds a snippet.",
46     description: null,
47     structure: "<Name> <Content>",
48     example: "`%%addsnippet roles There are 2 roles`\n`%%addsnippet roles There are 2 roles\nAdmin - Administrator\nMod - Moderator`",
49     notes: null,
50     slashCommand: true,
51     legacyCommand: true
52     },
53     {
54     name: 'afk',
55     shortBrief: "Keeps track of your mentions and tells other users that you're AFK.",
56     description: null,
57     structure: "[Reason]",
58     example: "`%%afk`\n`%%afk Having dinner`",
59     notes: null,
60     slashCommand: true,
61     legacyCommand: true
62     },
63     {
64     name: 'announce',
65     shortBrief: "Announce something in the given channel.",
66     description: "Announce something in the given channel. The channel should be set in the configuration.",
67     structure: "<Content>",
68     example: "`%%announce Hello there!\nWe've just finished our job!\n@everyone`",
69     notes: null,
70     slashCommand: true,
71     legacyCommand: true
72     },
73     {
74     name: 'antijoin',
75     shortBrief: "Enable the AntiJoin shield.",
76     description: "Enables the AntiJoin shield.\nWhile AntiJoin is active, users will not be able to join the server (they will be kicked). This is useful when handling a raid.",
77     structure: "",
78     example: "`%%antijoin",
79     notes: null,
80     slashCommand: true,
81     legacyCommand: true
82     },
83     {
84     name: 'appeal',
85     shortBrief: "Send a message to staff members about a punishment appeal.",
86     description: null,
87     structure: "",
88     example: "`%%appeal`",
89     notes: null,
90     slashCommand: true,
91     legacyCommand: false
92     },
93     {
94     name: 'avatar',
95     shortBrief: "Show someone's avatar.",
96     description: null,
97     structure: "[UserID|UserTag|Mention=CURRENT_USER]",
98     example: "`%%avatar 385753607325075320`\n`%%avatar`",
99     notes: null,
100     slashCommand: true,
101     legacyCommand: true
102     },
103     {
104     name: 'avatarlookup',
105     shortBrief: "Lookup someone's avatar!",
106     description: "Lookup someone's avatar, using Google Image Search.\nThis command is a subcommand of the `/lookup` slash command.",
107     structure: "<UserID|Mention>",
108     example: "`%%avatarlookup 385753607325075320`\n`",
109     notes: null,
110     slashCommand: true,
111     legacyCommand: true
112     },
113     {
114     name: 'ban',
115     shortBrief: "Ban someone in this server.",
116     description: "Ban a user in this server.",
117     structure: "<UserID|UserTag|Mention> [-d=DAYS] [Reason]",
118     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`",
119     notes: null,
120     options: {
121     "-d": "The number of days old messages to delete. It must be in range 0-7. An argument is required.",
122     },
123     slashCommand: true,
124     legacyCommand: true
125     },
126     {
127     name: 'ballot',
128     shortBrief: "Create/view a ballot (poll) message.",
129     description: null,
130     subcommands: {
131     "create": "Create a ballot message. Argument 1 should be the ballot message content.",
132     "view": "View a ballot message stats. Argument 1 should be the ballot ID."
133     },
134     structure: "<subcommand> <subcommand-arguments>",
135     example: "`%%ballot create What do you think guys?`\n`%%ballot view 15`",
136     notes: null,
137     slashCommand: true,
138     legacyCommand: true
139     },
140     {
141     name: 'cat',
142     shortBrief: "Get a random kitty picture.",
143     description: "Fetches a random cat picture from `thecatapi.com` API.",
144     structure: "",
145     example: "`%%cat`",
146     notes: null,
147     slashCommand: true,
148     legacyCommand: true
149     },
150     {
151     name: 'clear',
152     shortBrief: "Clear all messages from a user.",
153     description: "Clear all messages from a user, in the current channel. This might take a while.",
154     structure: "<UserID|UserTag|UserMention>",
155     example: "`%%clear 83474924191884727`\n`%%clear @Someone`",
156     notes: null,
157     slashCommand: true,
158     legacyCommand: true
159     },
160     {
161     name: 'config',
162     shortBrief: "View or change the config options.",
163     description: "Configure the bot settings. This command is for advanced users.\nIf the user only gives one argument (setting key), then the value of the setting key will be shown. Otherwise the setting key will be modified with the given parameters.",
164     structure: "<key> [value]",
165     example: "`%%config spam_filter.enabled false`\n`%%config prefix -`",
166     notes: null,
167     slashCommand: true,
168     legacyCommand: true
169     },
170     {
171     name: 'delqueue',
172     shortBrief: "Delete a queue job.",
173     description: "Delete a queued command by its ID.",
174     structure: "<QueueID>",
175     example: "`%%delqueue 80`",
176     notes: null,
177     slashCommand: false,
178     legacyCommand: true
179     },
180     {
181     name: 'delsnippet',
182     shortBrief: "Deletes a snippet.",
183     description: null,
184     structure: "<Name>",
185     example: "`%%delsnippet roles`",
186     notes: null,
187     slashCommand: true,
188     legacyCommand: true
189     },
190     {
191     name: 'dog',
192     shortBrief: "Get a random doggy picture.",
193     description: "Fetches a random cat picture from `thedogapi.com` API.",
194     structure: "",
195     example: "`%%dog`",
196     notes: null,
197     slashCommand: true,
198     legacyCommand: true
199     },
200     {
201     name: 'echo',
202     shortBrief: "Echo (re-send) a message.",
203     description: "Re-send a message from the bot.",
204     structure: "<content> [channelMention]",
205     example: "`%%echo Something\nVery Cool`\n`%%echo Something\nVery Cool #general`",
206     notes: null,
207     slashCommand: true,
208     legacyCommand: true
209     },
210     {
211     name: 'embed',
212     shortBrief: "Build, send and make schemas of embeds!",
213     description: "Build, send and make schemas of embeds. Schemas are special kind of text which can be used in various commands to represent an embed.\n\n**Subcommands**:\n\n`send` - Build and send an embed from the given input.\n`schema` - Builds an embed and returns back the JSON schema of the embed so that you can use it in other places!\n`build` - Builds an embed from a JSON schema.",
214     structure: "<subcommand> <...args>",
215     example: "`/embed send title:Hello world description:This is an embed, awesome!`\n`/embed schema title:Hello world description:This is an embed, awesome!`\n`/embed build json_schema:embed:{\"title\": \"Hello world\", \"description\": \"This is an embed, awesome!\", \"fields\": []}`",
216     notes: null,
217     slashCommand: true,
218     legacyCommand: false
219     },
220     {
221     name: 'emoji',
222     shortBrief: "Get info about an emoji.",
223     description: null,
224     structure: "<GuildEmojiID|GuildEmoji|GuildEmojiName|ExternalEmoji|ExternalEmojiID>",
225     example: "`%%emoji check`\n`%%emoji error`",
226     notes: null,
227     slashCommand: false,
228     legacyCommand: true
229     },
230     {
231     name: 'eval',
232     shortBrief: "Execute raw Javascript code.\n*This command is owner-only*.",
233     description: null,
234     structure: "<code>",
235     example: "`%%eval console.log(\"Hello world!\")`",
236     notes: null,
237     slashCommand: true,
238     legacyCommand: true
239     },
240     {
241     name: 'expire',
242     shortBrief: "Echo (re-send) a message and delete it after the given time.",
243     description: "Re-send a message from the bot and delete it automatically after the given time interval.",
244     structure: "<timeInterval> <content> [channelMention]",
245     example: "`%%echo 25m Something\nVery Cool`\n`%%echo 1h Something\nVery Cool #general`",
246     notes: null,
247     slashCommand: true,
248     legacyCommand: true
249     },
250     {
251     name: 'expiresc',
252     shortBrief: "Schedule a message and delete it after the given time.",
253     description: "Schedule a message from the bot and delete it automatically after the given time interval.",
254     structure: "<scheduleTimeInterval> <expireTimeInterval> <content> [channelMention]",
255     example: "`%%echo 25m 5h Something\nVery Cool`\n`%%echo 1h 7d Something\nVery Cool #general`",
256     notes: null,
257     slashCommand: true,
258     legacyCommand: true
259     },
260     {
261     name: 'guildlookup',
262     shortBrief: "Lookup any Public Discord server/guild!",
263     description: "Lookup any Public Discord server/guild!\nThis command is a subcommand of the `/lookup` slash command.",
264     structure: "<UserID|Mention>",
265     example: "`%%guildlookup 385753607325075320`\n`",
266     notes: null,
267     slashCommand: true,
268     legacyCommand: true
269     },
270     {
271     name: 'hash',
272     shortBrief: "Generate a hash of the given text input.",
273     description: null,
274     structure: "<algorithm> <input>",
275     example: "`%%hash sha1 abc`",
276     notes: null,
277     slashCommand: true,
278     legacyCommand: true
279     },
280     {
281     name: 'help',
282     shortBrief: "Show this help and exit.",
283     description: null,
284     structure: "[command]",
285     example: "`%%help`\n`%%help mute`",
286     notes: null,
287     slashCommand: true,
288     legacyCommand: true
289     },
290     {
291     name: 'history',
292     shortBrief: "Show moderation history for a user.",
293     description: null,
294     structure: "<UserMention|UserID>",
295     example: "`%%history 27372628277272625`\n`%%history @Someone`",
296     notes: null,
297     slashCommand: true,
298     legacyCommand: true
299     },
300     {
301     name: 'httpcat',
302     shortBrief: "Get some funny cat memes related to HTTP.",
303     description: "Get some funny cat memes related to HTTP status codes, using http.cat API.",
304     structure: "<status>",
305     example: "`%%httpcat 403`",
306     notes: null,
307     slashCommand: true,
308     legacyCommand: true
309     },
310     {
311     name: 'httpdog',
312     shortBrief: "Get some funny dog memes related to HTTP.",
313     description: "Get some funny dog memes related to HTTP status codes, using http.dog API.",
314     structure: "<status>",
315     example: "`%%httpdog 403`",
316     notes: null,
317     slashCommand: true,
318     legacyCommand: true
319     },
320     {
321     name: 'joke',
322     shortBrief: "Fetch a random joke from The Joke API.",
323     description: null,
324     structure: "",
325     example: "`%%joke`",
326     notes: null,
327     slashCommand: true,
328     legacyCommand: true
329     },
330     {
331     name: 'kick',
332     shortBrief: "Kick someone from this server.",
333     description: null,
334     structure: "<UserID|UserTag|Mention> [Reason]",
335     example: "`%%kick 385753607325075320`\n`%%kick @Someone You are spamming a lot`",
336     notes: null,
337     slashCommand: true,
338     legacyCommand: true
339     },
340     {
341     name: 'lock',
342     shortBrief: "Lock a specific channel.",
343     description: "Makes the given channel read-only for the general members. If no channel is present, the current channel will be locked.",
344     structure: "[ChannelID|ChannelMention]",
345     example: "`%%lock 385753607325075320`\n`%%lock #general`\n`%%lock`",
346     notes: null,
347     slashCommand: true,
348     legacyCommand: true
349     },
350     {
351     name: 'lockall',
352     shortBrief: "Lock all given channels, in-bulk.",
353     description: "Makes the given channels read-only for the general members.",
354     structure: "<...ChannelMention|ChannelIDs> [--raid]",
355     example: "`%%lockall 2572562578247841786\n`%%lockall 2572562578247841786 2572562578247841782 2572562578247841783`\n`%%lockall 2572562578247841786 2572562578247841785`",
356     notes: null,
357     options: {
358     "--raid": "Lock all raid protected channels",
359     },
360     slashCommand: true,
361     legacyCommand: true
362     },
363     {
364     name: 'lookup',
365     shortBrief: "Lookup something.",
366     description: null,
367     structure: "[ChannelID|ChannelMention]",
368     subcommands: {
369     "user": "Lookup a user around Discord",
370     "guild": "Lookup a Public Discord Server"
371     },
372     example: "`/lookup user user:384624924565405777`",
373     notes: null,
374     slashCommand: true,
375     legacyCommand: false
376     },
377     {
378     name: 'massban',
379     shortBrief: 'Mass ban (multiple) users',
380     description: null,
381     structure: '<...UserIDs|UserMentions> [Reason]',
382     example: '`%%massban 8247282727258725258 @someone Mass Banning`',
383     notes: null,
384     slashCommand: true,
385     legacyCommand: true
386     },
387     {
388     name: 'mute',
389     shortBrief: "Mute someone in this server.",
390     description: null,
391     structure: "<UserID|UserTag|Mention> [-t=DURATION] [Reason]",
392     example: "`%%mute 385753607325075320`\n`%%mute @Someone You are spamming a lot`\n`%%mute @Someone -t 10m You are spamming a lot`",
393     options: {
394     "-t": "Set the mute duration"
395     },
396     notes: null,
397     slashCommand: true,
398     legacyCommand: true
399     },
400     {
401     name: 'mvsnippet',
402     shortBrief: "Rename a snippet.",
403     description: null,
404     structure: "<oldName> <newName>",
405     example: "`%%mvsnippet abc bca`",
406     notes: null,
407     slashCommand: true,
408     legacyCommand: true
409     },
410     {
411     name: 'note',
412     shortBrief: "Take a note about an user.",
413     description: null,
414     structure: "<UserID|UserTag|UserMention> <note>",
415     example: "`%%note @Someone Simple note.`",
416     notes: null,
417     slashCommand: true,
418     legacyCommand: true
419     },
420     {
421     name: 'notedel',
422     shortBrief: "Delete a note.",
423     description: null,
424     structure: "<NoteID>",
425     example: "`%%notedel 922`",
426     notes: null,
427     slashCommand: true,
428     legacyCommand: true
429     },
430     {
431     name: 'noteget',
432     shortBrief: "Get a note.",
433     description: null,
434     structure: "<NoteID>",
435     example: "`%%noteget 922`",
436     notes: null,
437     slashCommand: true,
438     legacyCommand: true
439     },
440     {
441     name: 'notes',
442     shortBrief: "Get all notes for a specific user.",
443     description: null,
444     structure: "<UserID|UserTag|UserMention>",
445     example: "`%%notes @Someone`",
446     notes: null,
447     slashCommand: true,
448     legacyCommand: true
449     },
450     {
451     name: 'pixabay',
452     shortBrief: "Fetch images from Pixabay.",
453     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.",
454     structure: "<subcommand> [query]",
455     example: "`%%pixabay image`\n`%%pixabay photo birds`",
456     notes: null,
457     slashCommand: true,
458     legacyCommand: true
459     },
460     {
461     name: 'profile',
462     shortBrief: 'Show the server profile.',
463     description: null,
464     structure: '[UserID|UserTag|UserMention]',
465     example: '`%%profile`\n`%%profile @Someone`',
466     notes: null,
467     slashCommand: true,
468     legacyCommand: true
469     },
470     {
471     name: 'queues',
472     shortBrief: "Show a list of all queue jobs.",
473     description: null,
474     structure: "",
475     example: "`%%queues`",
476     notes: null,
477     slashCommand: true,
478     legacyCommand: true
479     },
480     {
481     name: 'rolelist',
482     shortBrief: 'List all roles in the server',
483     description: null,
484     structure: "[Page] [Role]",
485     example: "`%%rolelist`",
486     notes: null,
487     slashCommand: true,
488     legacyCommand: false
489     },
490     {
491     name: 'schedule',
492     shortBrief: "Echo (re-send) a message after the given time.",
493     description: "Re-send a message from the bot automatically after the given time interval.",
494     structure: "<timeInterval> <content> [channelMention]",
495     example: "`%%echo 25m Something\nVery Cool`\n`%%echo 1h Something\nVery Cool #general`",
496     notes: null,
497     slashCommand: true,
498     legacyCommand: true
499     },
500     {
501     name: 'send',
502     shortBrief: "Send a DM to a user.",
503     description: null,
504     structure: "<UserID|UserTag|Mention> <content>",
505     example: "`%%send 278358918549759428 Hello world`\n`%%send @Someone Hello world`",
506     notes: null,
507     slashCommand: true,
508     legacyCommand: true
509     },
510     {
511     name: 'setchperms',
512     shortBrief: "Set channel permissions in bulk.",
513     description: null,
514     structure: "<...ChannelIDs|ChannelMentions> <Role> <PermissionKey> <null|true|false>",
515     example: "`%%setchperms 827483719415287387 24872512882472142 #general @everyone SEND_MESSAGES false`",
516     notes: null,
517     slashCommand: true,
518     legacyCommand: true
519     },
520     {
521     name: 'shot',
522     shortBrief: "Give a shot to a user.",
523     description: "Give a shot to a user. This command actually doesn't do anything.",
524     structure: "<UserID|UserTag|Mention> [Reason]",
525     example: "`%%shot 385753607325075320`\n`%%shot @Someone You are spamming a lot`",
526     notes: null,
527     slashCommand: true,
528     legacyCommand: true
529     },
530     {
531     name: 'softban',
532     shortBrief: "Softban a user.",
533     description: "A softban means banning and unbanning a user immediately so that their messages gets deleted.",
534     structure: "<UserID|UserTag|UserMention> [-d=DAYS] [Reason]",
535     example: "`%%softban @Someone`\n`%%softban 44347362235774742 Hello world`",
536     notes: null,
537     slashCommand: true,
538     legacyCommand: true
539     },
540     {
541     name: 'stats',
542     shortBrief: "Show the server stats.",
543     description: null,
544     structure: "",
545     example: "`%%stats",
546     notes: null,
547     slashCommand: true,
548     legacyCommand: true
549     },
550     {
551     name: 'system',
552     shortBrief: "Show the system status.",
553     description: null,
554     structure: "",
555     example: "`%%system",
556     notes: null,
557     slashCommand: true,
558     legacyCommand: true
559     },
560     {
561     name: 'tempban',
562     shortBrief: "Temporarily ban a user.",
563     description: null,
564     structure: "<UserID|UserTag|UserMention> <Time> [-d=DAYS] [Reason]",
565     example: "`%%softban @Someone 20m`\n`%%softban 44347362235774742 50m Hello world`",
566     notes: null,
567     slashCommand: true,
568     legacyCommand: true
569     },
570     {
571     name: 'unban',
572     shortBrief: "Unban a user from this server.",
573     description: null,
574     structure: "<UserID>",
575     example: "`%%unban 2946255269594753792`",
576     notes: null,
577     slashCommand: true,
578     legacyCommand: true
579     },
580     {
581     name: 'unlock',
582     shortBrief: "Unlock a specific channel.",
583     description: "Makes the given channel writable for the general members. If no channel is present, the current channel is unlocked.",
584     structure: "[ChannelID|ChannelMention]",
585     example: "`%%unlock 385753607325075320`\n`%%unlock #general`\n`%%unlock`",
586     notes: null,
587     slashCommand: true,
588     legacyCommand: true
589     },
590     {
591     name: 'unlockall',
592     shortBrief: "Unlock all given channels, in bulk.",
593     description: "<...ChannelMention|ChannelIDs> [--raid]",
594     structure: "[...options]",
595     example: "`%%unlockall --raid\n`%%unlockall 348764381911364631 634894637314679163795`",
596     notes: null,
597     options: {
598     "--raid": "Unlock all Raid-protected channels"
599     },
600     slashCommand: true,
601     legacyCommand: true
602     },
603     {
604     name: 'unmute',
605     shortBrief: "Unmute someone in this server.",
606     description: null,
607     structure: "<UserID|UserTag|Mention>",
608     example: "`%%unmute 385753607325075320`\n`%%unmute @Someone You are spamming a lot`",
609     notes: null,
610     slashCommand: true,
611     legacyCommand: true
612     },
613     {
614     name: 'userlookup',
615     shortBrief: "Lookup any Discord user!",
616     description: "Lookup any Discord user! Doesn't matter if they are in the server or not.\nThis command is a subcommand of the `/lookup` slash command.",
617     structure: "<UserID|Mention>",
618     example: "`%%userlookup 385753607325075320`\n`",
619     notes: null,
620     slashCommand: true,
621     legacyCommand: true
622     },
623     {
624     name: 'warn',
625     shortBrief: "Warn someone in this server.",
626     description: null,
627     structure: "<UserID|UserTag|Mention> [Reason]",
628     example: "`%%warn 385753607325075320`\n`%%warn @Someone You are spamming a lot`",
629     notes: null,
630     slashCommand: true,
631     legacyCommand: true
632     },
633     {
634     name: 'warning',
635     shortBrief: "Operations with warnings.",
636     description: null,
637     structure: "<ID>",
638     example: "`%%warning list @Someone`\n`%%warning clear @Someone`\n`%%warning remove 24`\n`%%warning view 35`",
639     notes: null,
640     slashCommand: true,
641     legacyCommand: true,
642     subcommands: {
643     "list": "List all warnings for a user",
644     "clear": "Clear all warnings for a user",
645     "remove": "Remove a warning by ID",
646     "view": "View information about a warning by ID"
647     }
648     },
649     {
650     name: 'welcomer',
651     shortBrief: "Configure the welcomer.",
652     description: "Change the settings of the welcomer.",
653     structure: "<option(s)> [...args]",
654     example: "`%%welcomer --enable`",
655     notes: null,
656     slashCommand: false,
657     legacyCommand: true,
658     options: {
659     "--enable": "Enables the welcomer",
660     "--disable": "Disables the welcomer",
661     "--toggle": "Toggles the welcomer",
662     "--msg, --message, --custom": "Set custom welcome message. The welcome message as an argument is required.",
663     "--rm-msg, --remove-message": "Remove the custom welcome message.",
664     "--rand, --randomize": "Toggle random welcome messages.",
665     "--preview": "Preview the welcome message embed.",
666     }
667     },
668     ]

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26