test stop
This commit is contained in:
parent
653ee7c3a1
commit
551dec6c08
1 changed files with 29 additions and 10 deletions
37
main.py
37
main.py
|
@ -11,6 +11,7 @@ intents.message_content = True
|
||||||
intents.voice_states = True
|
intents.voice_states = True
|
||||||
bot = commands.Bot(command_prefix='!', intents=intents)
|
bot = commands.Bot(command_prefix='!', intents=intents)
|
||||||
queued_songs = []
|
queued_songs = []
|
||||||
|
voice_client = None # Global variable to track voice client
|
||||||
|
|
||||||
def find_song(query, songs_dir):
|
def find_song(query, songs_dir):
|
||||||
best_match = None
|
best_match = None
|
||||||
|
@ -20,8 +21,7 @@ def find_song(query, songs_dir):
|
||||||
for file in files:
|
for file in files:
|
||||||
if file.endswith(".mp3"):
|
if file.endswith(".mp3"):
|
||||||
song_path = os.path.join(root, file)
|
song_path = os.path.join(root, file)
|
||||||
#song_name = os.path.relpath(song_path, start=songs_dir)
|
song_name = os.path.relpath(song_path, start=songs_dir)
|
||||||
song_name = os.path.splitext(file)[0]
|
|
||||||
confidence = process.extractOne(query, [song_name.replace("_", " ")])[1]
|
confidence = process.extractOne(query, [song_name.replace("_", " ")])[1]
|
||||||
|
|
||||||
if confidence > best_confidence:
|
if confidence > best_confidence:
|
||||||
|
@ -32,13 +32,31 @@ def find_song(query, songs_dir):
|
||||||
|
|
||||||
@bot.command()
|
@bot.command()
|
||||||
async def play(ctx, *, query):
|
async def play(ctx, *, query):
|
||||||
voice_client = discord.utils.get(bot.voice_clients, guild=ctx.guild)
|
global voice_client
|
||||||
if voice_client and voice_client.is_connected():
|
if voice_client and voice_client.is_connected():
|
||||||
await add_to_queue(ctx, query)
|
await add_to_queue(ctx, query)
|
||||||
else:
|
else:
|
||||||
await connect_and_play(ctx, query)
|
await connect_and_play(ctx, query)
|
||||||
|
|
||||||
|
@bot.command()
|
||||||
|
async def skip(ctx):
|
||||||
|
global voice_client
|
||||||
|
if voice_client and voice_client.is_playing():
|
||||||
|
voice_client.stop()
|
||||||
|
|
||||||
|
@bot.command()
|
||||||
|
async def stop(ctx):
|
||||||
|
global voice_client
|
||||||
|
if voice_client and voice_client.is_connected():
|
||||||
|
queued_songs.clear()
|
||||||
|
if voice_client.is_playing():
|
||||||
|
voice_client.stop()
|
||||||
|
await voice_client.disconnect()
|
||||||
|
voice_client = None
|
||||||
|
await ctx.send("Stopped playback and cleared queue.")
|
||||||
|
|
||||||
async def add_to_queue(ctx, query):
|
async def add_to_queue(ctx, query):
|
||||||
|
global voice_client
|
||||||
songs_dir = os.getenv("SONGS_DIR")
|
songs_dir = os.getenv("SONGS_DIR")
|
||||||
# Find the closest match to the query
|
# Find the closest match to the query
|
||||||
song_path, confidence = find_song(query, songs_dir)
|
song_path, confidence = find_song(query, songs_dir)
|
||||||
|
@ -48,9 +66,10 @@ async def add_to_queue(ctx, query):
|
||||||
queued_songs.append((song_path, song_name))
|
queued_songs.append((song_path, song_name))
|
||||||
await ctx.send(f"**Added to queue:** `{song_name}`")
|
await ctx.send(f"**Added to queue:** `{song_name}`")
|
||||||
else:
|
else:
|
||||||
await ctx.send("Sorry, couldn't find a match for that song.")
|
await ctx.send("Can't find a match for that song.")
|
||||||
|
|
||||||
async def connect_and_play(ctx, query):
|
async def connect_and_play(ctx, query):
|
||||||
|
global voice_client
|
||||||
voice_channel = ctx.author.voice.channel
|
voice_channel = ctx.author.voice.channel
|
||||||
if voice_channel:
|
if voice_channel:
|
||||||
songs_dir = os.getenv("SONGS_DIR")
|
songs_dir = os.getenv("SONGS_DIR")
|
||||||
|
@ -60,20 +79,20 @@ async def connect_and_play(ctx, query):
|
||||||
if confidence >= 70 and song_path: # Adjust confidence threshold as needed
|
if confidence >= 70 and song_path: # Adjust confidence threshold as needed
|
||||||
song_name = os.path.relpath(song_path, start=songs_dir) # Get the song name relative to songs_dir
|
song_name = os.path.relpath(song_path, start=songs_dir) # Get the song name relative to songs_dir
|
||||||
queued_songs.append((song_path, song_name))
|
queued_songs.append((song_path, song_name))
|
||||||
await play_queued_songs(ctx, voice_channel)
|
voice_client = await play_queued_songs(ctx, voice_channel)
|
||||||
else:
|
else:
|
||||||
await ctx.send("Sorry, couldn't find a match for that song.")
|
await ctx.send("Can't find a match for that song.")
|
||||||
else:
|
|
||||||
await ctx.send("You need to be in a voice channel to use this command!")
|
|
||||||
|
|
||||||
async def play_queued_songs(ctx, voice_channel):
|
async def play_queued_songs(ctx, voice_channel):
|
||||||
|
global voice_client
|
||||||
voice_client = await voice_channel.connect()
|
voice_client = await voice_channel.connect()
|
||||||
while queued_songs:
|
while queued_songs:
|
||||||
song_path, song_name = queued_songs.pop(0) # Get the first song in the queue
|
song_path, song_name = queued_songs.pop(0) # Get the first song in the queue
|
||||||
await ctx.send(f"**Now playing:** `{song_name}`")
|
await ctx.send(f"**Now playing:** `{song_name}`")
|
||||||
voice_client.play(discord.FFmpegPCMAudio(song_path))
|
voice_client.play(discord.FFmpegPCMAudio(song_path))
|
||||||
while voice_client.is_playing():
|
while voice_client and voice_client.is_playing(): # Check if voice_client is not None
|
||||||
await asyncio.sleep(1)
|
await asyncio.sleep(1)
|
||||||
|
if voice_client:
|
||||||
await voice_client.disconnect()
|
await voice_client.disconnect()
|
||||||
|
|
||||||
bot.run(os.getenv("DISCORD_TOKEN"))
|
bot.run(os.getenv("DISCORD_TOKEN"))
|
||||||
|
|
Loading…
Reference in a new issue