mirror of
https://github.com/pacnpal/Pac-cogs.git
synced 2025-12-20 10:51:05 -05:00
fix: Change URL extraction in processor to use regex
- Replaced extractor.suitable() with direct regex pattern matching - Added check for _VALID_URL attribute - Improved error handling in URL extraction - Maintains compatibility with video_downloader.py changes
This commit is contained in:
@@ -9,61 +9,70 @@ import random
|
|||||||
# Define context menu command outside the class
|
# Define context menu command outside the class
|
||||||
@app_commands.context_menu(name="Give Birthday Role")
|
@app_commands.context_menu(name="Give Birthday Role")
|
||||||
async def birthday_context_menu(interaction: discord.Interaction, member: discord.Member):
|
async def birthday_context_menu(interaction: discord.Interaction, member: discord.Member):
|
||||||
cog = interaction.client.get_cog("Birthday")
|
|
||||||
if not cog:
|
|
||||||
await interaction.response.send_message("Birthday cog is not loaded.", ephemeral=True)
|
|
||||||
return
|
|
||||||
|
|
||||||
# Check if the user has permission to use this command
|
|
||||||
allowed_roles = await cog.config.guild(interaction.guild).allowed_roles()
|
|
||||||
if not any(role.id in allowed_roles for role in interaction.user.roles):
|
|
||||||
return await interaction.response.send_message("You don't have permission to use this command.", ephemeral=True)
|
|
||||||
|
|
||||||
birthday_role_id = await cog.config.guild(interaction.guild).birthday_role()
|
|
||||||
if not birthday_role_id:
|
|
||||||
return await interaction.response.send_message("The birthday role hasn't been set. An admin needs to set it using `/setrole`.", ephemeral=True)
|
|
||||||
|
|
||||||
birthday_role = interaction.guild.get_role(birthday_role_id)
|
|
||||||
if not birthday_role:
|
|
||||||
return await interaction.response.send_message("The birthday role doesn't exist anymore. Please ask an admin to set it again.", ephemeral=True)
|
|
||||||
|
|
||||||
# Assign the role, ignoring hierarchy
|
|
||||||
try:
|
try:
|
||||||
await member.add_roles(birthday_role, reason="Birthday role")
|
# Defer the response immediately to prevent timeout
|
||||||
except discord.Forbidden:
|
await interaction.response.defer(ephemeral=True)
|
||||||
return await interaction.response.send_message("I don't have permission to assign that role.", ephemeral=True)
|
|
||||||
|
|
||||||
# Generate birthday message with random cakes (or pie)
|
cog = interaction.client.get_cog("Birthday")
|
||||||
cakes = random.randint(0, 5)
|
if not cog:
|
||||||
if cakes == 0:
|
await interaction.followup.send("Birthday cog is not loaded.", ephemeral=True)
|
||||||
message = f"🎉 Happy Birthday, {member.mention}! Sorry, out of cake today! Here's pie instead: 🥧"
|
return
|
||||||
else:
|
|
||||||
message = f"🎉 Happy Birthday, {member.mention}! Here's your cake{'s' if cakes > 1 else ''}: " + "🎂" * cakes
|
|
||||||
|
|
||||||
# Get the birthday announcement channel
|
# Check if the user has permission to use this command
|
||||||
birthday_channel_id = await cog.config.guild(interaction.guild).birthday_channel()
|
allowed_roles = await cog.config.guild(interaction.guild).allowed_roles()
|
||||||
if birthday_channel_id:
|
if not any(role.id in allowed_roles for role in interaction.user.roles):
|
||||||
channel = interaction.client.get_channel(birthday_channel_id)
|
return await interaction.followup.send("You don't have permission to use this command.", ephemeral=True)
|
||||||
if not channel: # If the set channel doesn't exist anymore
|
|
||||||
|
birthday_role_id = await cog.config.guild(interaction.guild).birthday_role()
|
||||||
|
if not birthday_role_id:
|
||||||
|
return await interaction.followup.send("The birthday role hasn't been set. An admin needs to set it using `/setrole`.", ephemeral=True)
|
||||||
|
|
||||||
|
birthday_role = interaction.guild.get_role(birthday_role_id)
|
||||||
|
if not birthday_role:
|
||||||
|
return await interaction.followup.send("The birthday role doesn't exist anymore. Please ask an admin to set it again.", ephemeral=True)
|
||||||
|
|
||||||
|
# Assign the role, ignoring hierarchy
|
||||||
|
try:
|
||||||
|
await member.add_roles(birthday_role, reason="Birthday role")
|
||||||
|
except discord.Forbidden:
|
||||||
|
return await interaction.followup.send("I don't have permission to assign that role.", ephemeral=True)
|
||||||
|
|
||||||
|
# Generate birthday message with random cakes (or pie)
|
||||||
|
cakes = random.randint(0, 5)
|
||||||
|
if cakes == 0:
|
||||||
|
message = f"🎉 Happy Birthday, {member.mention}! Sorry, out of cake today! Here's pie instead: 🥧"
|
||||||
|
else:
|
||||||
|
message = f"🎉 Happy Birthday, {member.mention}! Here's your cake{'s' if cakes > 1 else ''}: " + "🎂" * cakes
|
||||||
|
|
||||||
|
# Get the birthday announcement channel
|
||||||
|
birthday_channel_id = await cog.config.guild(interaction.guild).birthday_channel()
|
||||||
|
if birthday_channel_id:
|
||||||
|
channel = interaction.client.get_channel(birthday_channel_id)
|
||||||
|
if not channel: # If the set channel doesn't exist anymore
|
||||||
|
channel = interaction.channel
|
||||||
|
else:
|
||||||
channel = interaction.channel
|
channel = interaction.channel
|
||||||
else:
|
|
||||||
channel = interaction.channel
|
|
||||||
|
|
||||||
await channel.send(message)
|
await channel.send(message)
|
||||||
await interaction.response.send_message("Birthday role assigned!", ephemeral=True)
|
await interaction.followup.send("Birthday role assigned!", ephemeral=True)
|
||||||
|
|
||||||
# Schedule role removal
|
# Schedule role removal
|
||||||
timezone = await cog.config.guild(interaction.guild).timezone()
|
timezone = await cog.config.guild(interaction.guild).timezone()
|
||||||
try:
|
try:
|
||||||
tz = ZoneInfo(timezone)
|
tz = ZoneInfo(timezone)
|
||||||
except ZoneInfoNotFoundError:
|
except ZoneInfoNotFoundError:
|
||||||
await interaction.followup.send("Warning: Invalid timezone set. Defaulting to UTC.", ephemeral=True)
|
await interaction.followup.send("Warning: Invalid timezone set. Defaulting to UTC.", ephemeral=True)
|
||||||
tz = ZoneInfo("UTC")
|
tz = ZoneInfo("UTC")
|
||||||
|
|
||||||
now = datetime.now(tz)
|
now = datetime.now(tz)
|
||||||
midnight = datetime.combine(now.date() + timedelta(days=1), time.min).replace(tzinfo=tz)
|
midnight = datetime.combine(now.date() + timedelta(days=1), time.min).replace(tzinfo=tz)
|
||||||
|
|
||||||
await cog.schedule_birthday_role_removal(interaction.guild, member, birthday_role, midnight)
|
await cog.schedule_birthday_role_removal(interaction.guild, member, birthday_role, midnight)
|
||||||
|
except Exception as e:
|
||||||
|
try:
|
||||||
|
await interaction.followup.send(f"An error occurred: {str(e)}", ephemeral=True)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
class Birthday(commands.Cog):
|
class Birthday(commands.Cog):
|
||||||
"""A cog to assign a birthday role until midnight in a specified timezone."""
|
"""A cog to assign a birthday role until midnight in a specified timezone."""
|
||||||
|
|||||||
@@ -197,7 +197,7 @@ class VideoArchiverCommands(commands.Cog):
|
|||||||
|
|
||||||
# Verify sites are valid
|
# Verify sites are valid
|
||||||
with yt_dlp.YoutubeDL() as ydl:
|
with yt_dlp.YoutubeDL() as ydl:
|
||||||
valid_sites = set(ie.IE_NAME.lower() for ie in ydl._ies)
|
valid_sites = set(ie.IE_NAME.lower() for ie in ydl._ies if hasattr(ie, 'IE_NAME'))
|
||||||
invalid_sites = [s for s in site_list if s not in valid_sites]
|
invalid_sites = [s for s in site_list if s not in valid_sites]
|
||||||
if invalid_sites:
|
if invalid_sites:
|
||||||
await ctx.send(
|
await ctx.send(
|
||||||
@@ -217,7 +217,8 @@ class VideoArchiverCommands(commands.Cog):
|
|||||||
embed = discord.Embed(title="Video Sites Configuration", color=discord.Color.blue())
|
embed = discord.Embed(title="Video Sites Configuration", color=discord.Color.blue())
|
||||||
|
|
||||||
with yt_dlp.YoutubeDL() as ydl:
|
with yt_dlp.YoutubeDL() as ydl:
|
||||||
all_sites = sorted(ie.IE_NAME for ie in ydl._ies if ie.IE_NAME is not None)
|
# Filter out any extractors that don't have IE_NAME attribute
|
||||||
|
all_sites = sorted(ie.IE_NAME for ie in ydl._ies if hasattr(ie, 'IE_NAME') and ie.IE_NAME is not None)
|
||||||
|
|
||||||
# Split sites into chunks for Discord's field value limit
|
# Split sites into chunks for Discord's field value limit
|
||||||
chunk_size = 20
|
chunk_size = 20
|
||||||
|
|||||||
Reference in New Issue
Block a user