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

Contents of /trunk/deploy-commands.js

Parent Directory Parent Directory | Revision Log Revision Log


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

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26