aboutsummaryrefslogtreecommitdiff
path: root/src/commands
diff options
context:
space:
mode:
authorMax Isom <[email protected]>2022-02-24 18:24:56 -0500
committerMax Isom <[email protected]>2022-02-24 18:24:56 -0500
commit3dfd16860be1f607a53d49e97cf68260497530d0 (patch)
tree4c6b2aeebc83bc2a65cce4abd1d933254f173bea /src/commands
parentedc95ad5db67cbf75cb62f528545cf2c3a1090f0 (diff)
parent4f0db62170398c542d23fcee3812f0887901f977 (diff)
downloadmuse-3dfd16860be1f607a53d49e97cf68260497530d0.tar.xz
muse-3dfd16860be1f607a53d49e97cf68260497530d0.zip
Merge branch 'master' of github.com:codetheweb/muse
Diffstat (limited to 'src/commands')
-rw-r--r--src/commands/stop.ts37
1 files changed, 37 insertions, 0 deletions
diff --git a/src/commands/stop.ts b/src/commands/stop.ts
new file mode 100644
index 0000000..3c32c7f
--- /dev/null
+++ b/src/commands/stop.ts
@@ -0,0 +1,37 @@
+import {CommandInteraction} from 'discord.js';
+import {SlashCommandBuilder} from '@discordjs/builders';
+import {TYPES} from '../types.js';
+import {inject, injectable} from 'inversify';
+import PlayerManager from '../managers/player.js';
+import {STATUS} from '../services/player.js';
+import Command from '.';
+
+@injectable()
+export default class implements Command {
+ public readonly slashCommand = new SlashCommandBuilder()
+ .setName('stop')
+ .setDescription('stop playback, disconnect, and clear all songs in the queue');
+
+ public requiresVC = true;
+
+ private readonly playerManager: PlayerManager;
+
+ constructor(@inject(TYPES.Managers.Player) playerManager: PlayerManager) {
+ this.playerManager = playerManager;
+ }
+
+ public async execute(interaction: CommandInteraction) {
+ const player = this.playerManager.get(interaction.guild!.id);
+
+ if (!player.voiceConnection) {
+ throw new Error('not connected');
+ }
+
+ if (player.status !== STATUS.PLAYING) {
+ throw new Error('not currently playing');
+ }
+
+ player.stop();
+ await interaction.reply('u betcha');
+ }
+}