REF: Added /Stop

REF: Added /Leave
FIX: Fixed music issues
This commit is contained in:
Dan 2024-09-17 11:27:33 -04:00
parent 1b5587c958
commit 7c937b6112
2 changed files with 41 additions and 7 deletions

View File

@ -1,3 +1,5 @@
# modules/music.py
import discord import discord
from discord import app_commands from discord import app_commands
import yt_dlp import yt_dlp
@ -14,6 +16,7 @@ class Music:
self.save_file = 'music_state.json' self.save_file = 'music_state.json'
self.volumes = {} # Store volume levels per guild self.volumes = {} # Store volume levels per guild
self.default_volume = 0.5 # Default volume level (50%) self.default_volume = 0.5 # Default volume level (50%)
self.current_interactions = {} # Store interactions per guild
# Load saved state for auto-resume # Load saved state for auto-resume
self.load_music_state() self.load_music_state()
@ -42,6 +45,10 @@ class Music:
async def stop(interaction: discord.Interaction): async def stop(interaction: discord.Interaction):
await self.stop(interaction) await self.stop(interaction)
@app_commands.command(name='leave', description='Disconnect the bot from the voice channel')
async def leave(interaction: discord.Interaction):
await self.leave(interaction)
@app_commands.command(name='volume', description='Set the playback volume') @app_commands.command(name='volume', description='Set the playback volume')
@app_commands.describe(level='Volume level between 0 and 100') @app_commands.describe(level='Volume level between 0 and 100')
async def volume(interaction: discord.Interaction, level: int): async def volume(interaction: discord.Interaction, level: int):
@ -53,6 +60,7 @@ class Music:
self.client.tree.add_command(resume) self.client.tree.add_command(resume)
self.client.tree.add_command(skip) self.client.tree.add_command(skip)
self.client.tree.add_command(stop) self.client.tree.add_command(stop)
self.client.tree.add_command(leave)
self.client.tree.add_command(volume) self.client.tree.add_command(volume)
async def play(self, interaction: discord.Interaction, query: str): async def play(self, interaction: discord.Interaction, query: str):
@ -60,6 +68,9 @@ class Music:
guild_id = interaction.guild_id guild_id = interaction.guild_id
# Store the interaction object for later use
self.current_interactions[guild_id] = interaction
# Check if the user is in a voice channel # Check if the user is in a voice channel
if interaction.user.voice is None: if interaction.user.voice is None:
await interaction.followup.send("You must be connected to a voice channel to use this command.") await interaction.followup.send("You must be connected to a voice channel to use this command.")
@ -120,7 +131,7 @@ class Music:
async def play_next(self, guild_id): async def play_next(self, guild_id):
if guild_id not in self.music_queues or not self.music_queues[guild_id]: if guild_id not in self.music_queues or not self.music_queues[guild_id]:
await self.voice_clients[guild_id].disconnect() # Do not disconnect here
return return
url = self.music_queues[guild_id].pop(0) url = self.music_queues[guild_id].pop(0)
@ -160,16 +171,32 @@ class Music:
if thumbnail: if thumbnail:
embed.set_thumbnail(url=thumbnail) embed.set_thumbnail(url=thumbnail)
channel = self.voice_clients[guild_id].channel # Use the stored interaction to send the message
text_channel = channel.guild.system_channel or channel.guild.text_channels[0] interaction = self.current_interactions.get(guild_id)
await text_channel.send(embed=embed) if interaction:
try:
await interaction.followup.send(embed=embed)
except discord.HTTPException as e:
print(f"Failed to send message: {e}")
finally:
# Remove the interaction to prevent reuse
self.current_interactions.pop(guild_id, None)
else:
# Fallback to a default text channel
channel = self.voice_clients[guild_id].channel
text_channel = channel.guild.system_channel or channel.guild.text_channels[0]
try:
await text_channel.send(embed=embed)
except discord.HTTPException as e:
print(f"Failed to send message: {e}")
# Save state for auto-resume # Save state for auto-resume
self.save_music_state() self.save_music_state()
except Exception as e: except Exception as e:
print(f"Error during playback: {e}") print(f"Error during playback: {e}")
await self.voice_clients[guild_id].disconnect() if guild_id in self.voice_clients and self.voice_clients[guild_id].is_connected():
await self.voice_clients[guild_id].disconnect()
def after_song(self, error, guild_id): def after_song(self, error, guild_id):
if error: if error:
@ -206,11 +233,18 @@ class Music:
if guild_id in self.voice_clients: if guild_id in self.voice_clients:
self.voice_clients[guild_id].stop() self.voice_clients[guild_id].stop()
self.music_queues[guild_id] = [] self.music_queues[guild_id] = []
await self.voice_clients[guild_id].disconnect()
await interaction.response.send_message("🛑 **Playback stopped and queue cleared.**") await interaction.response.send_message("🛑 **Playback stopped and queue cleared.**")
else: else:
await interaction.response.send_message("❌ **No music is playing.**") await interaction.response.send_message("❌ **No music is playing.**")
async def leave(self, interaction: discord.Interaction):
guild_id = interaction.guild_id
if guild_id in self.voice_clients and self.voice_clients[guild_id].is_connected():
await self.voice_clients[guild_id].disconnect()
await interaction.response.send_message("👋 **Disconnected from the voice channel.**")
else:
await interaction.response.send_message("❌ **I am not connected to a voice channel.**")
async def set_volume(self, interaction: discord.Interaction, level: int): async def set_volume(self, interaction: discord.Interaction, level: int):
guild_id = interaction.guild_id guild_id = interaction.guild_id

View File

@ -1 +1 @@
{"current_tracks": {"1161168803888107550": "https://www.youtube.com/watch?v=fnlJw9H0xAM", "1142517462529757184": "https://www.youtube.com/watch?v=fnlJw9H0xAM"}, "music_queues": {"1161168803888107550": [], "1142517462529757184": []}, "volumes": {"1161168803888107550": 0.5, "1142517462529757184": 0.5}} {"current_tracks": {"1161168803888107550": "https://www.youtube.com/watch?v=fnlJw9H0xAM", "1142517462529757184": "https://www.youtube.com/watch?v=fnlJw9H0xAM", "1142517462529757184": "https://www.youtube.com/watch?v=wWoQ7PFSYlk"}, "music_queues": {"1161168803888107550": [], "1142517462529757184": [], "1142517462529757184": []}, "volumes": {"1161168803888107550": 0.5, "1142517462529757184": 0.5, "1142517462529757184": 0.5}}