/[sudobot]/trunk/deploy-commands.js
ViewVC logotype

Annotation of /trunk/deploy-commands.js

Parent Directory Parent Directory | Revision Log Revision Log


Revision 336 - (hide annotations)
Mon Jul 29 17:29:36 2024 UTC (8 months ago) by rakin
File MIME type: text/javascript
File size: 24532 byte(s)
refactor(moderation): use mongodb
1 rakin 57 #!/bin/node
2 rakin 51
3 rakin 125 const { SlashCommandBuilder, ContextMenuCommandBuilder } = require('@discordjs/builders');
4 rakin 57 const { REST } = require('@discordjs/rest');
5     const { Routes } = require('discord-api-types/v9');
6     const { config } = require('dotenv');
7     const { existsSync } = require('fs');
8 rakin 125 const { Permissions, ApplicationCommand } = require('discord.js');
9 rakin 57 const path = require('path');
10 rakin 125 const { ActivityType, ApplicationCommandType } = require('discord-api-types/v10');
11 rakin 51
12     if (existsSync(path.join(__dirname, '.env'))) {
13     config();
14     }
15     else {
16     process.env.ENV = 'prod';
17     }
18    
19     const { CLIENT_ID, GUILD_ID, TOKEN } = process.env;
20    
21 rakin 67 let commands = [
22 rakin 54 // SETTINGS
23     new SlashCommandBuilder().setName('help').setDescription('A short documentation about the commands')
24     .addStringOption(option => option.setName('command').setDescription("The command")),
25 rakin 51 new SlashCommandBuilder().setName('about').setDescription('Show information about the bot'),
26 rakin 268 new SlashCommandBuilder().setName('eval').setDescription('Execute raw code in the runtime environment')
27     .addStringOption(option => option.setName('code').setDescription('The code to be executed').setRequired(true)),
28 rakin 51 new SlashCommandBuilder().setName('system').setDescription('Show the system status'),
29 rakin 58 new SlashCommandBuilder().setName('restart').setDescription('Restart the system'),
30 rakin 71 new SlashCommandBuilder().setName('setstatus').setDescription('Set status for the bot system')
31     .addStringOption(option => option.setName('activity').setDescription('The activity').setRequired(true))
32     .addStringOption(option => option.setName('status').setDescription('The status').setChoices(...[
33     {
34     name: 'Online',
35     value: 'online'
36     },
37     {
38     name: 'Idle',
39     value: 'idle'
40     },
41     {
42     name: 'DND',
43     value: 'dnd'
44     },
45     {
46     name: 'Invisible',
47     value: 'invisible'
48     }
49     ]))
50     .addStringOption(option => option.setName('type').setDescription('The activity type').setChoices(...[
51     {
52     name: 'Playing',
53     value: 'PLAYING'
54     },
55     {
56     name: 'Watching',
57     value: 'WATCHING'
58     },
59     {
60     name: 'Competing',
61     value: 'COMPETING'
62     }
63     ])),
64 rakin 215 new SlashCommandBuilder().setName('config').setDescription('View/change the system settings for this server')
65     .addStringOption(option => option.setName('key').setDescription('The setting key (e.g. spam_filter.enabled)').setRequired(true))
66     .addStringOption(option => option.setName('value').setDescription('New value for the setting')),
67 rakin 51
68     // INFORMATION
69     new SlashCommandBuilder().setName('stats').setDescription('Show the server statistics'),
70 rakin 290 new SlashCommandBuilder().setName('lookup').setDescription('Lookup something')
71     .addSubcommand(subcommand => subcommand.setName("user").setDescription("User lookup")
72     .addUserOption(option => option.setName("user").setDescription("The user to search").setRequired(true))
73 rakin 297 )
74     .addSubcommand(subcommand => subcommand.setName("guild").setDescription("Server/Guild lookup")
75     .addStringOption(option => option.setName("guild_id").setDescription("The ID of the server/guild to lookup").setRequired(true))
76     )
77     .addSubcommand(subcommand => subcommand.setName("avatar").setDescription("Avatar lookup using Google Image Search")
78     .addUserOption(option => option.setName("user").setDescription("The user to lookup").setRequired(true))
79     ),
80 rakin 290
81 rakin 54 new SlashCommandBuilder().setName('profile').setDescription('Show someone\'s profile')
82     .addUserOption(option => option.setName('user').setDescription('The user')),
83     new SlashCommandBuilder().setName('avatar').setDescription('Show someone\'s avatar')
84     .addUserOption(option => option.setName('user').setDescription('The user')),
85 rakin 60 new SlashCommandBuilder().setName('rolelist').setDescription('List all roles or show info about a role')
86 rakin 75 .addRoleOption(option => option.setName('role').setDescription('The role'))
87 rakin 74 .addIntegerOption(option => option.setName('page').setDescription('The page number')),
88 rakin 51
89     // AUTOMATION
90 rakin 55 new SlashCommandBuilder().setName('ballot').setDescription('Ballot engine')
91     .addSubcommand(subcommand =>
92     subcommand
93     .setName('create')
94     .setDescription('Send a ballot/poll message for collecting votes')
95     .addStringOption(option => option.setName('content').setDescription('Message content').setRequired(true))
96     .addBooleanOption(option => option.setName('anonymous').setDescription('If this is set to true then the syetem won\'t show your username'))
97     .addChannelOption(option => option.setName('channel').setDescription('The channel where the message should be sent')))
98     .addSubcommand(subcommand =>
99     subcommand
100     .setName('view')
101     .setDescription('Get information/stats about a ballot')
102 rakin 328 .addStringOption(option => option.setName('id').setDescription('The ballot ID'))),
103 rakin 55
104 rakin 252 new SlashCommandBuilder().setName('embed').setDescription('Make an embed')
105     .addSubcommand(subcmd =>
106     subcmd.setName("send").setDescription("Make and send an embed")
107     .addStringOption(option => option.setName('author_name').setDescription('The embed author name'))
108     .addStringOption(option => option.setName('author_iconurl').setDescription('The embed author icon URL'))
109     .addStringOption(option => option.setName('title').setDescription('The embed title'))
110     .addStringOption(option => option.setName('description').setDescription('The embed description'))
111     .addStringOption(option => option.setName('thumbnail').setDescription('The embed thumbnail URL'))
112     .addStringOption(option => option.setName('image').setDescription('The embed image attachment URL'))
113     .addStringOption(option => option.setName('video').setDescription('The embed video attachment URL'))
114     .addStringOption(option => option.setName('footer_text').setDescription('The embed footer text'))
115     .addStringOption(option => option.setName('footer_iconurl').setDescription('The embed footer icon URL'))
116     .addStringOption(option => option.setName('timestamp').setDescription('The embed timestamp, use \'current\' to set current date'))
117     .addStringOption(option => option.setName('color').setDescription('The embed color (default is #007bff)'))
118     .addStringOption(option => option.setName('url').setDescription('The embed URL'))
119     .addStringOption(option => option.setName('fields').setDescription('The embed fields, should be in `Field 1: Value 1, Field 2: Value 2` format'))
120     )
121     .addSubcommand(subcmd =>
122     subcmd.setName("schema").setDescription("Make and send an embed schema representation")
123     .addStringOption(option => option.setName('author_name').setDescription('The embed author name'))
124     .addStringOption(option => option.setName('author_iconurl').setDescription('The embed author icon URL'))
125     .addStringOption(option => option.setName('title').setDescription('The embed title'))
126     .addStringOption(option => option.setName('description').setDescription('The embed description'))
127     .addStringOption(option => option.setName('thumbnail').setDescription('The embed thumbnail URL'))
128     .addStringOption(option => option.setName('image').setDescription('The embed image attachment URL'))
129     .addStringOption(option => option.setName('video').setDescription('The embed video attachment URL'))
130     .addStringOption(option => option.setName('footer_text').setDescription('The embed footer text'))
131     .addStringOption(option => option.setName('footer_iconurl').setDescription('The embed footer icon URL'))
132     .addStringOption(option => option.setName('timestamp').setDescription('The embed timestamp, use \'current\' to set current date'))
133     .addStringOption(option => option.setName('color').setDescription('The embed color (default is #007bff)'))
134     .addStringOption(option => option.setName('url').setDescription('The embed URL'))
135     .addStringOption(option => option.setName('fields').setDescription('The embed fields, should be in `Field 1: Value 1, Field 2: Value 2` format'))
136     )
137     .addSubcommand(subcmd =>
138     subcmd.setName("build").setDescription("Build an embed from schema")
139 rakin 254 .addStringOption(option => option.setName('json_schema').setDescription('The embed JSON schema'))
140 rakin 252 ),
141 rakin 248
142 rakin 51 new SlashCommandBuilder().setName('queues').setDescription('List all queued jobs'),
143    
144     new SlashCommandBuilder().setName('schedule').setDescription('Schedule a message for sending later')
145     .addStringOption(option => option.setName('time').setDescription('The time interval').setRequired(true))
146     .addStringOption(option => option.setName('content').setDescription('Message content').setRequired(true))
147     .addChannelOption(option => option.setName('channel').setDescription('The channel where the message should be sent')),
148    
149     new SlashCommandBuilder().setName('expire').setDescription('Expire (delete) a message after a certain amount of time')
150     .addStringOption(option => option.setName('time').setDescription('The time interval').setRequired(true))
151     .addStringOption(option => option.setName('content').setDescription('Message content').setRequired(true))
152     .addChannelOption(option => option.setName('channel').setDescription('The channel where the message should be sent')),
153    
154     new SlashCommandBuilder().setName('expiresc').setDescription('Schedule and expire (delete) a message after a certain amount of time')
155     .addStringOption(option => option.setName('send-after').setDescription('The time after the message should be sent').setRequired(true))
156     .addStringOption(option => option.setName('delete-after').setDescription('The time after the message should be deleted').setRequired(true)) // (the system will start counting this after the message gets sent)
157     .addStringOption(option => option.setName('content').setDescription('Message content').setRequired(true))
158     .addChannelOption(option => option.setName('channel').setDescription('The channel where the message should be sent')),
159    
160     // FUN
161     new SlashCommandBuilder().setName('cat').setDescription('Fetch a random kitty image'),
162    
163     new SlashCommandBuilder().setName('dog').setDescription('Fetch a random doggy image'),
164    
165     new SlashCommandBuilder().setName('joke').setDescription('Fetch a random joke from the Joke API'),
166    
167     new SlashCommandBuilder().setName('httpcat').setDescription('Fetch a funny cat meme associated with an HTTP status code')
168     .addIntegerOption(option => option.setName('status').setDescription('The HTTP status Code').setRequired(true).setMinValue(100).setMaxValue(599)),
169    
170     new SlashCommandBuilder().setName('httpdog').setDescription('Fetch a funny dog meme associated with an HTTP status code')
171     .addIntegerOption(option => option.setName('status').setDescription('The HTTP status Code').setRequired(true).setMinValue(100).setMaxValue(599)),
172    
173     new SlashCommandBuilder().setName('pixabay').setDescription('Search & fetch images from the Pixabay API')
174     .addSubcommand(subcommand =>
175     subcommand
176     .setName('image')
177     .setDescription('Get any type of image')
178     .addStringOption(option => option.setName('query').setDescription('Search query')))
179     .addSubcommand(subcommand =>
180     subcommand
181     .setName('photo')
182     .setDescription('Get photos')
183     .addStringOption(option => option.setName('query').setDescription('Search query')))
184     .addSubcommand(subcommand =>
185     subcommand
186     .setName('illustration')
187     .setDescription('Get illustrations')
188     .addStringOption(option => option.setName('query').setDescription('Search query')))
189     .addSubcommand(subcommand =>
190     subcommand
191     .setName('vector')
192     .setDescription('Get vectors')
193     .addStringOption(option => option.setName('query').setDescription('Search query'))),
194    
195     // UTILS
196     new SlashCommandBuilder().setName('snippet').setDescription('Snippets are instant custom messages')
197     .addSubcommand(subcommand =>
198     subcommand
199     .setName('get')
200     .setDescription('Get a snippet')
201     .addStringOption(option => option.setName('name').setDescription('The snippet name').setRequired(true)))
202     .addSubcommand(subcommand =>
203     subcommand
204     .setName('create')
205     .setDescription('Create a snippet')
206     .addStringOption(option => option.setName('name').setDescription('The snippet name').setRequired(true))
207     .addStringOption(option => option.setName('content').setDescription('Snippet message content').setRequired(true))
208     .addAttachmentOption(option => option.setName('file').setDescription('Snippet message file')))
209     .addSubcommand(subcommand =>
210     subcommand
211     .setName('rename')
212     .setDescription('Rename a snippet')
213     .addStringOption(option => option.setName('old-name').setDescription('The old snippet name').setRequired(true))
214     .addStringOption(option => option.setName('new-name').setDescription('The new name').setRequired(true)))
215     .addSubcommand(subcommand =>
216     subcommand
217     .setName('delete')
218     .setDescription('Delete a snippet')
219     .addStringOption(option => option.setName('name').setDescription('The snippet name').setRequired(true))),
220    
221     new SlashCommandBuilder().setName('afk').setDescription('Set your AFK status')
222     .addStringOption(option => option.setName('reason').setDescription("The reason for going AFK")),
223    
224 rakin 261 new SlashCommandBuilder().setName('hash').setDescription('Generate hash for a string (text) data')
225     .addStringOption(option => option.setName('content').setDescription("The content to be hashed").setRequired(true))
226     .addStringOption(option =>
227     option
228     .setName('algorithm')
229     .setDescription("Hash algorithm")
230     .setChoices(
231     {
232     name: 'SHA1',
233     value: 'sha1'
234     },
235     {
236     name: 'SHA256',
237     value: 'sha256'
238     },
239     {
240     name: 'SHA512',
241     value: 'sha512'
242     },
243     {
244     name: 'MD5',
245     value: 'md5'
246     },
247     )
248     )
249     .addStringOption(option =>
250     option
251     .setName('digest')
252     .setDescription("Digest mode")
253     .setChoices(
254     {
255     name: 'HEX',
256     value: 'hex'
257     },
258     {
259     name: 'Base64',
260     value: 'base64'
261     },
262     {
263     name: 'Base64 URL',
264     value: 'base64url'
265     },
266     )
267     ),
268    
269 rakin 51 new SlashCommandBuilder().setName('announce').setDescription('Announce something')
270     .addStringOption(option => option.setName('content').setDescription("The announcemnt message content")),
271    
272     // MODERATION
273 rakin 225 new SlashCommandBuilder().setName('antijoin').setDescription('Enable antijoin system which will kick any new users joining the server'),
274    
275 rakin 51 new SlashCommandBuilder().setName('ban').setDescription('Ban a user')
276     .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true))
277     .addStringOption(option => option.setName('reason').setDescription("The reason for banning this user"))
278     .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of this user").setMinValue(0).setMaxValue(7)),
279    
280 rakin 106 new SlashCommandBuilder().setName('softban').setDescription('Softban a user')
281     .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true))
282     .addStringOption(option => option.setName('reason').setDescription("The reason for softbanning this user"))
283     .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of this user (default is 7)").setMinValue(0).setMaxValue(7)),
284    
285     new SlashCommandBuilder().setName('tempban').setDescription('Temporarily ban a user')
286     .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true))
287     .addStringOption(option => option.setName('time').setDescription("TBan duration").setRequired(true))
288     .addStringOption(option => option.setName('reason').setDescription("The reason for softbanning this user"))
289     .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of this user (default is 7)").setMinValue(0).setMaxValue(7)),
290    
291 rakin 61 new SlashCommandBuilder().setName('massban').setDescription('Ban multiple users')
292     .addStringOption(option => option.setName('users').setDescription("The user IDs (separated by spaces)").setRequired(true))
293     .addStringOption(option => option.setName('reason').setDescription("The reason for banning"))
294     .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of these users").setMinValue(0).setMaxValue(7)),
295    
296 rakin 51 new SlashCommandBuilder().setName('kick').setDescription('Kick a member')
297     .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true))
298     .addStringOption(option => option.setName('reason').setDescription("The reason for kicking this user")),
299    
300 rakin 197 new SlashCommandBuilder().setName('shot').setDescription('Give a shot to a member')
301 rakin 51 .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true))
302 rakin 197 .addStringOption(option => option.setName('reason').setDescription("The reason for giving shot to this user")),
303 rakin 51
304     new SlashCommandBuilder().setName('warn').setDescription('Warn a member')
305     .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true))
306     .addStringOption(option => option.setName('reason').setDescription("The reason for warning this user")),
307    
308 rakin 86 new SlashCommandBuilder().setName('note').setDescription('Take a note for a user')
309     .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true))
310 rakin 51 .addStringOption(option => option.setName('note').setDescription("The note content").setRequired(true)),
311    
312     new SlashCommandBuilder().setName('mute').setDescription('Mute a member')
313     .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true))
314     .addStringOption(option => option.setName('reason').setDescription("The reason for muting this user"))
315 rakin 124 .addStringOption(option => option.setName('time').setDescription("Mute duration"))
316     .addBooleanOption(option => option.setName('hardmute').setDescription("Specify if the system should take out all roles of the user during the mute")),
317 rakin 51
318     new SlashCommandBuilder().setName('unmute').setDescription('Unmute a member')
319     .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true)),
320    
321     new SlashCommandBuilder().setName('unban').setDescription('Unban a user')
322     .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true)),
323    
324 rakin 85 new SlashCommandBuilder().setName('warning').setDescription('Clear, remove or view warnings')
325     .addSubcommand(subcmd => {
326 rakin 336 return subcmd.setName('view').setDescription('View information about a warning').addStringOption(option => option.setName('id').setDescription("The warning ID").setRequired(true));
327 rakin 85 })
328     .addSubcommand(subcmd => {
329 rakin 336 return subcmd.setName('remove').setDescription('Remove a warning').addStringOption(option => option.setName('id').setDescription("The warning ID").setRequired(true));
330 rakin 85 })
331     .addSubcommand(subcmd => {
332     return subcmd.setName('list').setDescription('List warnings for a user').addUserOption(option => option.setName('user').setDescription("The user").setRequired(true));
333     })
334     .addSubcommand(subcmd => {
335     return subcmd.setName('clear').setDescription('Clear all warnings for a user').addUserOption(option => option.setName('user').setDescription("The user").setRequired(true));
336     }),
337 rakin 51
338     new SlashCommandBuilder().setName('noteget').setDescription('Get information about a note')
339     .addNumberOption(option => option.setName('id').setDescription("The note ID").setRequired(true)),
340    
341     new SlashCommandBuilder().setName('notedel').setDescription('Delete a note')
342     .addNumberOption(option => option.setName('id').setDescription("The note ID").setRequired(true)),
343    
344     new SlashCommandBuilder().setName('notes').setDescription('Fetch all notes for a user')
345 rakin 86 .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true)),
346 rakin 51
347     new SlashCommandBuilder().setName('history').setDescription('Fetch all moderation history for a user')
348     .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true)),
349    
350 rakin 79 new SlashCommandBuilder().setName('clear').setDescription('Clear messages in bulk')
351 rakin 78 .addUserOption(option => option.setName('user').setDescription("The user"))
352     .addIntegerOption(option => option.setName('count').setDescription("The amount of messages to delete").setMaxValue(400).setMinValue(0))
353     .addChannelOption(option => option.setName('channel').setDescription("The channel where the messages will be deleted")),
354 rakin 51
355     new SlashCommandBuilder().setName('echo').setDescription('Re-send a message from the bot system')
356     .addStringOption(option => option.setName('content').setDescription("The message content").setRequired(true))
357     .addChannelOption(option => option.setName('channel').setDescription("The channel where the message should be sent")),
358    
359     new SlashCommandBuilder().setName('lock').setDescription('Lock a channel')
360     .addRoleOption(option => option.setName('role').setDescription("Lock channel for the given role. Default is @everyone"))
361     .addChannelOption(option => option.setName('channel').setDescription("The channel that will be locked. Default is the current channel")),
362    
363 rakin 63 new SlashCommandBuilder().setName('setchperms').setDescription('Set permissions for channels')
364     .addChannelOption(option => option.setName('channel').setDescription("The channel that (or its children) will be updated").setRequired(true))
365     .addRoleOption(option => option.setName('role').setDescription("Lock channel for the given role.").setRequired(true))
366 rakin 64 .addStringOption(option => option.setName('permission').setDescription("The permission codename").setRequired(true).setAutocomplete(true))
367 rakin 63 .addStringOption(option => option.setName('value').setDescription("The permission value").addChoices(...[
368     {
369     name: 'Allow',
370     value: 'true'
371     },
372     {
373     name: 'Deny',
374     value: 'false',
375     },
376     {
377     name: 'Default',
378     value: 'null',
379     }
380     ]).setRequired(true)),
381    
382 rakin 51 new SlashCommandBuilder().setName('lockall').setDescription('Lock multiple channels')
383 rakin 244 .addStringOption(option => option.setName('channels').setDescription("The channels, must be separated by spaces"))
384 rakin 51 .addRoleOption(option => option.setName('role').setDescription("Lock channels for the given role. Default is @everyone"))
385     .addBooleanOption(option => option.setName('raid').setDescription("The raid protected channels will be locked. Default is `false`")),
386    
387     new SlashCommandBuilder().setName('unlockall').setDescription('Unlock multiple channels')
388 rakin 244 .addStringOption(option => option.setName('channels').setDescription("The channels, must be separated by spaces"))
389 rakin 51 .addRoleOption(option => option.setName('role').setDescription("Unlock channels for the given role. Default is @everyone"))
390     .addBooleanOption(option => option.setName('force').setDescription("Force set the channel permissions to `true`"))
391     .addBooleanOption(option => option.setName('raid').setDescription("The raid protected channels will be unlocked. Default is `false`")),
392    
393     new SlashCommandBuilder().setName('unlock').setDescription('Unlock a channel')
394     .addRoleOption(option => option.setName('role').setDescription("Unlock channel for the given role. Default is @everyone"))
395     .addBooleanOption(option => option.setName('force').setDescription("Force set the channel permission to `true`"))
396     .addChannelOption(option => option.setName('channel').setDescription("The channel that will be unlocked. Default is the current channel")),
397    
398     new SlashCommandBuilder().setName('send').setDescription('Send a DM to a user')
399     .addStringOption(option => option.setName('content').setDescription("The message content").setRequired(true))
400     .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true)),
401 rakin 81
402    
403     new SlashCommandBuilder().setName('appeal').setDescription('Send us a messages about a punishment appeal')
404 rakin 51 ].map(command => command.toJSON());
405    
406 rakin 125 let contextMenuCommands = [
407     new ContextMenuCommandBuilder().setName('Moderation History').setType(ApplicationCommandType.User),
408     new ContextMenuCommandBuilder().setName('Ban').setType(ApplicationCommandType.User),
409 rakin 197 new ContextMenuCommandBuilder().setName('Shot').setType(ApplicationCommandType.User),
410 rakin 125 new ContextMenuCommandBuilder().setName('Kick').setType(ApplicationCommandType.User),
411     ].map(command => command.toJSON());
412    
413     commands = commands.concat(contextMenuCommands);
414    
415 rakin 67 if (process.argv.includes('--clear')) {
416     commands = [];
417 rakin 125 contextMenuCommands = [];
418 rakin 67 }
419    
420 rakin 57 const rest = new REST({ version: '9' }).setToken(TOKEN);
421 rakin 51
422 rakin 67 rest.put(Routes[process.argv.includes('--guild') ? 'applicationGuildCommands' : 'applicationCommands'](CLIENT_ID, GUILD_ID), { body: commands })
423     .then(() => console.log('Successfully registered application ' + (process.argv.includes('--guild') ? 'guild ' : '') + 'commands.'))
424 rakin 197 .catch(console.error);

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26