aboutsummaryrefslogtreecommitdiff
path: root/src
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
parentedc95ad5db67cbf75cb62f528545cf2c3a1090f0 (diff)
parent4f0db62170398c542d23fcee3812f0887901f977 (diff)
downloadmuse-3dfd16860be1f607a53d49e97cf68260497530d0.tar.xz
muse-3dfd16860be1f607a53d49e97cf68260497530d0.zip
Merge branch 'master' of github.com:codetheweb/muse
Diffstat (limited to 'src')
-rw-r--r--src/commands/stop.ts37
-rw-r--r--src/inversify.config.ts2
-rw-r--r--src/services/player.ts6
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 c0991a4..a18d753 100644
--- a/src/services/player.ts
+++ b/src/services/player.ts
@@ -340,6 +340,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);
}