aboutsummaryrefslogtreecommitdiff
path: root/src/lib/extensions
diff options
context:
space:
mode:
authorTymanWasTaken <tyman@tyman.tech>2021-05-17 14:06:24 -0400
committerTymanWasTaken <tyman@tyman.tech>2021-05-17 14:06:24 -0400
commit9aee8c80067530b178612f1261c38b83683f266d (patch)
tree2ac52f719bdd77ef0265da2de02336f0759deaba /src/lib/extensions
parent4d63c4af57a7391dd61106b79874b8e83c14971a (diff)
downloadtanzanite-9aee8c80067530b178612f1261c38b83683f266d.tar.gz
tanzanite-9aee8c80067530b178612f1261c38b83683f266d.tar.bz2
tanzanite-9aee8c80067530b178612f1261c38b83683f266d.zip
probably works idk what all I did
Diffstat (limited to 'src/lib/extensions')
-rw-r--r--src/lib/extensions/Util.ts77
1 files changed, 74 insertions, 3 deletions
diff --git a/src/lib/extensions/Util.ts b/src/lib/extensions/Util.ts
index 661392f..0aadc89 100644
--- a/src/lib/extensions/Util.ts
+++ b/src/lib/extensions/Util.ts
@@ -4,6 +4,16 @@ import { promisify } from 'util';
import { exec } from 'child_process';
import got from 'got';
import { MessageEmbed, GuildMember, User } from 'discord.js';
+import { CommandInteractionOption } from 'discord.js';
+import {
+ ApplicationCommandOptionType,
+ APIInteractionDataResolvedGuildMember,
+ APIInteractionDataResolvedChannel,
+ APIRole
+} from 'discord-api-types';
+import { GuildChannel } from 'discord.js';
+import { Role } from 'discord.js';
+import chalk from 'chalk';
interface hastebinRes {
key: string;
@@ -32,6 +42,17 @@ export interface uuidRes {
created_at: string;
}
+export interface SlashCommandOption<T> {
+ name: string;
+ type: ApplicationCommandOptionType;
+ value?: T;
+ options?: CommandInteractionOption[];
+ user?: User;
+ member?: GuildMember | APIInteractionDataResolvedGuildMember;
+ channel?: GuildChannel | APIInteractionDataResolvedChannel;
+ role?: Role | APIRole;
+}
+
export class Util extends ClientUtil {
/**
* The client of this ClientUtil
@@ -88,9 +109,7 @@ export class Util extends ClientUtil {
* @param command The shell command to run
* @returns The stdout and stderr of the shell command
*/
- public async shell(
- command: string
- ): Promise<{
+ public async shell(command: string): Promise<{
stdout: string;
stderr: string;
}> {
@@ -225,6 +244,58 @@ export class Util extends ClientUtil {
return apiRes.uuid;
}
+ public async syncSlashCommands(force = false): Promise<void> {
+ try {
+ const registered = await this.client.application.commands.fetch();
+ for (const [, registeredCommand] of registered) {
+ if (
+ !this.client.commandHandler.modules.find(
+ (cmd) => cmd.id == registeredCommand.name
+ ) ||
+ force
+ ) {
+ await this.client.application.commands.delete(registeredCommand.id);
+ this.client.logger.verbose(
+ chalk`{red Deleted slash command ${registeredCommand.name}}`
+ );
+ }
+ }
+
+ for (const [, botCommand] of this.client.commandHandler.modules) {
+ if (botCommand.execSlash) {
+ const found = registered.find((i) => i.name == botCommand.id);
+
+ const slashdata = {
+ name: botCommand.id,
+ description: botCommand.description.content,
+ options: botCommand.options.slashCommandOptions
+ };
+
+ if (found?.id && !force) {
+ if (slashdata.description !== found.description) {
+ await this.client.application.commands.edit(found.id, slashdata);
+ this.client.logger.verbose(
+ chalk`{yellow Edited slash command ${botCommand.id}}`
+ );
+ }
+ } else {
+ await this.client.application.commands.create(slashdata);
+ this.client.logger.verbose(
+ chalk`{green Created slash command ${botCommand.id}}`
+ );
+ }
+ }
+ }
+
+ return this.client.logger.log(chalk.green('Slash commands registered'));
+ } catch (e) {
+ console.log(chalk.red(e.stack));
+ return this.client.logger.error(
+ chalk`{red Slash commands not registered, see above error.}`
+ );
+ }
+ }
+
public moulberryBushRoleMap = [
{ name: '*', id: '792453550768390194' },
{ name: 'Admin Perms', id: '746541309853958186' },