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

Diff of /trunk/deploy-commands.js

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

trunk/deploy-commands.ts revision 51 by rakin, Mon Jul 29 17:28:23 2024 UTC trunk/deploy-commands.js revision 79 by rakin, Mon Jul 29 17:28:30 2024 UTC
# Line 1  Line 1 
1  #!/bin/ts-node  #!/bin/node
2    
3  import { SlashCommandBuilder } from '@discordjs/builders';  const { SlashCommandBuilder } = require('@discordjs/builders');
4  import { REST } from '@discordjs/rest';  const { REST } = require('@discordjs/rest');
5  import { Routes } from 'discord-api-types/v9';  const { Routes } = require('discord-api-types/v9');
6  import { config } from 'dotenv';  const { config } = require('dotenv');
7  import { existsSync } from 'fs';  const { existsSync } = require('fs');
8  import path from 'path';  const { Permissions } = require('discord.js');
9    const path = require('path');
10    const { ActivityType } = require('discord-api-types/v10');
11    
12  if (existsSync(path.join(__dirname, '.env'))) {  if (existsSync(path.join(__dirname, '.env'))) {
13      config();      config();
# Line 16  else { Line 18  else {
18    
19  const { CLIENT_ID, GUILD_ID, TOKEN } = process.env;  const { CLIENT_ID, GUILD_ID, TOKEN } = process.env;
20    
21  const commands = [  let commands = [
22      new SlashCommandBuilder().setName('about').setDescription('Show information about the bot'),      // SETTINGS
     new SlashCommandBuilder().setName('test').setDescription('Test command'),  
     new SlashCommandBuilder().setName('system').setDescription('Show the system status'),  
   
     // ABOUT  
23      new SlashCommandBuilder().setName('help').setDescription('A short documentation about the commands')      new SlashCommandBuilder().setName('help').setDescription('A short documentation about the commands')
24          .addStringOption(option => option.setName('command').setDescription("The command")),          .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    
63      // INFORMATION      // INFORMATION
64      new SlashCommandBuilder().setName('stats').setDescription('Show the server statistics'),      new SlashCommandBuilder().setName('stats').setDescription('Show the server statistics'),
65        new SlashCommandBuilder().setName('profile').setDescription('Show someone\'s profile')
66            .addUserOption(option => option.setName('user').setDescription('The user')),
67        new SlashCommandBuilder().setName('avatar').setDescription('Show someone\'s avatar')
68            .addUserOption(option => option.setName('user').setDescription('The user')),
69        new SlashCommandBuilder().setName('rolelist').setDescription('List all roles or show info about a role')
70            .addRoleOption(option => option.setName('role').setDescription('The role'))
71            .addIntegerOption(option => option.setName('page').setDescription('The page number')),
72    
73      // AUTOMATION      // AUTOMATION
74        new SlashCommandBuilder().setName('ballot').setDescription('Ballot engine')
75            .addSubcommand(subcommand =>
76                subcommand
77                    .setName('create')
78                    .setDescription('Send a ballot/poll message for collecting votes')
79                    .addStringOption(option => option.setName('content').setDescription('Message content').setRequired(true))
80                    .addBooleanOption(option => option.setName('anonymous').setDescription('If this is set to true then the syetem won\'t show your username'))
81                    .addChannelOption(option => option.setName('channel').setDescription('The channel where the message should be sent')))
82            .addSubcommand(subcommand =>
83                subcommand
84                    .setName('view')
85                    .setDescription('Get information/stats about a ballot')
86                    .addIntegerOption(option => option.setName('id').setDescription('The ballot ID'))),
87            
88      new SlashCommandBuilder().setName('queues').setDescription('List all queued jobs'),      new SlashCommandBuilder().setName('queues').setDescription('List all queued jobs'),
89    
90      new SlashCommandBuilder().setName('schedule').setDescription('Schedule a message for sending later')      new SlashCommandBuilder().setName('schedule').setDescription('Schedule a message for sending later')
# Line 120  const commands = [ Line 176  const commands = [
176          .addStringOption(option => option.setName('reason').setDescription("The reason for banning this user"))          .addStringOption(option => option.setName('reason').setDescription("The reason for banning this user"))
177          .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of this user").setMinValue(0).setMaxValue(7)),          .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of this user").setMinValue(0).setMaxValue(7)),
178    
179        new SlashCommandBuilder().setName('massban').setDescription('Ban multiple users')
180            .addStringOption(option => option.setName('users').setDescription("The user IDs (separated by spaces)").setRequired(true))
181            .addStringOption(option => option.setName('reason').setDescription("The reason for banning"))
182            .addIntegerOption(option => option.setName('days').setDescription("The days old messages to delete of these users").setMinValue(0).setMaxValue(7)),
183    
184      new SlashCommandBuilder().setName('kick').setDescription('Kick a member')      new SlashCommandBuilder().setName('kick').setDescription('Kick a member')
185          .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true))          .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true))
186          .addStringOption(option => option.setName('reason').setDescription("The reason for kicking this user")),          .addStringOption(option => option.setName('reason').setDescription("The reason for kicking this user")),
# Line 168  const commands = [ Line 229  const commands = [
229      new SlashCommandBuilder().setName('history').setDescription('Fetch all moderation history for a user')      new SlashCommandBuilder().setName('history').setDescription('Fetch all moderation history for a user')
230          .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true)),          .addUserOption(option => option.setName('user').setDescription("The user").setRequired(true)),
231    
232      new SlashCommandBuilder().setName('clear').setDescription('Clear all messages in the current channel for a user')      new SlashCommandBuilder().setName('clear').setDescription('Clear messages in bulk')
233          .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true)),          .addUserOption(option => option.setName('user').setDescription("The user"))
234            .addIntegerOption(option => option.setName('count').setDescription("The amount of messages to delete").setMaxValue(400).setMinValue(0))
235            .addChannelOption(option => option.setName('channel').setDescription("The channel where the messages will be deleted")),
236    
237      new SlashCommandBuilder().setName('echo').setDescription('Re-send a message from the bot system')      new SlashCommandBuilder().setName('echo').setDescription('Re-send a message from the bot system')
238          .addStringOption(option => option.setName('content').setDescription("The message content").setRequired(true))          .addStringOption(option => option.setName('content').setDescription("The message content").setRequired(true))
# Line 179  const commands = [ Line 242  const commands = [
242          .addRoleOption(option => option.setName('role').setDescription("Lock channel for the given role. Default is @everyone"))          .addRoleOption(option => option.setName('role').setDescription("Lock channel for the given role. Default is @everyone"))
243          .addChannelOption(option => option.setName('channel').setDescription("The channel that will be locked. Default is the current channel")),          .addChannelOption(option => option.setName('channel').setDescription("The channel that will be locked. Default is the current channel")),
244    
245        new SlashCommandBuilder().setName('setchperms').setDescription('Set permissions for channels')
246            .addChannelOption(option => option.setName('channel').setDescription("The channel that (or its children) will be updated").setRequired(true))
247            .addRoleOption(option => option.setName('role').setDescription("Lock channel for the given role.").setRequired(true))
248            .addStringOption(option => option.setName('permission').setDescription("The permission codename").setRequired(true).setAutocomplete(true))
249            .addStringOption(option => option.setName('value').setDescription("The permission value").addChoices(...[
250                {
251                    name: 'Allow',
252                    value: 'true'
253                },
254                {
255                    name: 'Deny',
256                    value: 'false',
257                },
258                {
259                    name: 'Default',
260                    value: 'null',
261                }
262            ]).setRequired(true)),
263    
264      new SlashCommandBuilder().setName('lockall').setDescription('Lock multiple channels')      new SlashCommandBuilder().setName('lockall').setDescription('Lock multiple channels')
265          .addRoleOption(option => option.setName('role').setDescription("Lock channels for the given role. Default is @everyone"))          .addRoleOption(option => option.setName('role').setDescription("Lock channels for the given role. Default is @everyone"))
266          .addBooleanOption(option => option.setName('raid').setDescription("The raid protected channels will be locked. Default is `false`")),          .addBooleanOption(option => option.setName('raid').setDescription("The raid protected channels will be locked. Default is `false`")),
# Line 198  const commands = [ Line 280  const commands = [
280          .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true)),          .addUserOption(option => option.setName('member').setDescription("The member").setRequired(true)),
281  ].map(command => command.toJSON());  ].map(command => command.toJSON());
282    
283  const rest = new REST({ version: '9' }).setToken(TOKEN!);  if (process.argv.includes('--clear')) {
284        commands = [];
285    }
286    
287    const rest = new REST({ version: '9' }).setToken(TOKEN);
288    
289  rest.put(Routes.applicationGuildCommands(CLIENT_ID!, GUILD_ID!), { body: commands })  rest.put(Routes[process.argv.includes('--guild') ? 'applicationGuildCommands' : 'applicationCommands'](CLIENT_ID, GUILD_ID), { body: commands })
290      .then(() => console.log('Successfully registered application commands.'))      .then(() => console.log('Successfully registered application ' + (process.argv.includes('--guild') ? 'guild ' : '') + 'commands.'))
291      .catch(console.error);      .catch(console.error);

Legend:
Removed from v.51  
changed lines
  Added in v.79

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26