diff options
| author | Thongrapee Panyapatiphan <[email protected]> | 2022-02-25 06:24:45 +0700 |
|---|---|---|
| committer | GitHub <[email protected]> | 2022-02-24 17:24:45 -0600 |
| commit | 4f0db62170398c542d23fcee3812f0887901f977 (patch) | |
| tree | 2fceb554c7376c627dd4b96ba41ed1b2a2429140 /src | |
| parent | 237086245bb1e2363562c4d0ec7aec8e9f596d24 (diff) | |
| download | muse-4f0db62170398c542d23fcee3812f0887901f977.tar.xz muse-4f0db62170398c542d23fcee3812f0887901f977.zip | |
Add stop command (#540)
Co-authored-by: Max Isom <[email protected]>
Diffstat (limited to 'src')
| -rw-r--r-- | src/commands/stop.ts | 37 | ||||
| -rw-r--r-- | src/inversify.config.ts | 2 | ||||
| -rw-r--r-- | src/services/player.ts | 6 |
3 files changed, 45 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'); + } +} diff --git a/src/inversify.config.ts b/src/inversify.config.ts index d29d3de..7116984 100644 --- a/src/inversify.config.ts +++ b/src/inversify.config.ts @@ -26,6 +26,7 @@ import Remove from './commands/remove.js'; import Seek from './commands/seek.js'; import Shuffle from './commands/shuffle.js'; import Skip from './commands/skip.js'; +import Stop from './commands/stop.js'; import Unskip from './commands/unskip.js'; import ThirdParty from './services/third-party.js'; import FileCacheProvider from './services/file-cache.js'; @@ -66,6 +67,7 @@ container.bind<AddQueryToQueue>(TYPES.Services.AddQueryToQueue).to(AddQueryToQue Seek, Shuffle, Skip, + Stop, Unskip, ].forEach(command => { container.bind<Command>(TYPES.Command).to(command).inSingletonScope(); diff --git a/src/services/player.ts b/src/services/player.ts index 79ef2bb..c315089 100644 --- a/src/services/player.ts +++ b/src/services/player.ts @@ -342,6 +342,12 @@ export default class { return this.queueSize() === 0; } + stop(): void { + this.disconnect(); + this.queuePosition = 0; + this.queue = []; + } + private getHashForCache(url: string): string { return hasha(url); } |
