chore: server bot not selfbot self, selfuse slowing being rolled out

This commit is contained in:
neoarz
2025-10-20 11:57:49 -04:00
parent 6d596713fb
commit 898e01abf4
4 changed files with 387 additions and 164 deletions

View File

@@ -5,25 +5,12 @@ from discord.ext import commands
def randomfact_command(): def randomfact_command():
@commands.hybrid_command(name="randomfact", description="Get a random fact.") @commands.hybrid_command(name="randomfact", description="Get a random fact.")
async def randomfact(self, context): async def randomfact(self, context):
async with aiohttp.ClientSession() as session: embed = discord.Embed(
async with session.get( title="Command Disabled",
"https://uselessfacts.jsph.pl/random.json?language=en" description="This command is currently disabled.",
) as request: color=0xE02B2B,
if request.status == 200: )
data = await request.json() embed.set_author(name="Fun", icon_url="https://yes.nighty.works/raw/eW5lLm.webp")
embed = discord.Embed( await context.send(embed=embed)
title="Random Fact",
description=data["text"],
color=0x7289DA
)
embed.set_author(name="Fun", icon_url="https://yes.nighty.works/raw/eW5lLm.webp")
else:
embed = discord.Embed(
title="Error!",
description="There is something wrong with the API, please try again later",
color=0xE02B2B,
)
embed.set_author(name="Fun", icon_url="https://yes.nighty.works/raw/eW5lLm.webp")
await context.send(embed=embed)
return randomfact return randomfact

View File

@@ -10,45 +10,6 @@ import logging
logger = logging.getLogger("discord_bot") logger = logging.getLogger("discord_bot")
async def send_error_message(context, description: str):
embed = discord.Embed(
title="Error",
description=description,
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
async def upload_to_catbox(path: str) -> str:
try:
file_size_bytes = os.path.getsize(path)
except Exception:
file_size_bytes = -1
logger.info(f"Catbox upload start: name={os.path.basename(path)} size={file_size_bytes}")
form = aiohttp.FormData()
form.add_field('reqtype', 'fileupload')
with open(path, 'rb') as f:
form.add_field('fileToUpload', f, filename=os.path.basename(path))
timeout = aiohttp.ClientTimeout(total=600)
async with aiohttp.ClientSession(timeout=timeout) as session:
async with session.post('https://catbox.moe/user/api.php', data=form) as resp:
text = await resp.text()
logger.info(f"Catbox response: status={resp.status} body_len={len(text)}")
if resp.status == 200 and text.startswith('https://'):
url_text = text.strip()
logger.info(f"Catbox upload success: url={url_text}")
return url_text
logger.error(f"Catbox upload failed: status={resp.status} body={text.strip()[:500]}")
raise RuntimeError(f"Upload failed: {text.strip()}")
def download_command(): def download_command():
@commands.hybrid_command( @commands.hybrid_command(
name="download", name="download",
@@ -56,30 +17,111 @@ def download_command():
) )
@commands.cooldown(1, 30, commands.BucketType.user) @commands.cooldown(1, 30, commands.BucketType.user)
async def download(self, context, *, url: str): async def download(self, context, *, url: str):
if isinstance(context.channel, discord.DMChannel):
embed = discord.Embed(
title="Error",
description="This command can only be used in servers.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return
if isinstance(context.channel, discord.PartialMessageable):
embed = discord.Embed(
title="Error",
description="The bot needs send messages permissions in this channel.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return
if not url: if not url:
await send_error_message(context, "Please provide a valid URL to download.") embed = discord.Embed(
title="Error",
description="Please provide a valid URL to download.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return return
try: try:
parsed_url = urlparse(url) parsed_url = urlparse(url)
if not parsed_url.scheme or not parsed_url.netloc: if not parsed_url.scheme or not parsed_url.netloc:
await send_error_message(context, "Please provide a valid URL.") embed = discord.Embed(
title="Error",
description="Please provide a valid URL.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return return
except Exception: except Exception:
await send_error_message(context, "Please provide a valid URL.") embed = discord.Embed(
title="Error",
description="Please provide a valid URL.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return return
processing_embed = discord.Embed(
title="Download (Processing)",
description="<a:mariospin:1423677027013103709> Downloading video... This may take a moment.",
color=0x7289DA,
)
processing_embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None) interaction = getattr(context, "interaction", None)
if interaction is not None: if interaction is not None:
if not interaction.response.is_done(): if not interaction.response.is_done():
await interaction.response.defer(ephemeral=False) await interaction.response.send_message(embed=processing_embed, ephemeral=True)
else:
await interaction.followup.send(embed=processing_embed, ephemeral=True)
else: else:
processing_embed = discord.Embed(
title="Download (Processing)",
description="<a:mariospin:1423677027013103709> Downloading video... This may take a moment.",
color=0x7289DA,
)
processing_embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
processing_msg = await context.send(embed=processing_embed) processing_msg = await context.send(embed=processing_embed)
temp_dir = tempfile.mkdtemp() temp_dir = tempfile.mkdtemp()
@@ -116,6 +158,7 @@ def download_command():
video_uploader = info.get('uploader', 'Unknown') video_uploader = info.get('uploader', 'Unknown')
video_url = info.get('webpage_url') or info.get('original_url') or url video_url = info.get('webpage_url') or info.get('original_url') or url
platform = info.get('extractor') or info.get('extractor_key') or 'Unknown' platform = info.get('extractor') or info.get('extractor_key') or 'Unknown'
view_count = info.get('view_count')
files = [f for f in os.listdir(temp_dir) if os.path.isfile(os.path.join(temp_dir, f))] files = [f for f in os.listdir(temp_dir) if os.path.isfile(os.path.join(temp_dir, f))]
@@ -128,11 +171,31 @@ def download_command():
if file_size > 24 * 1024 * 1024: # 24MB limit if file_size > 24 * 1024 * 1024: # 24MB limit
logger.info("File is over 24MB, uploading to Catbox") logger.info("File is over 24MB, uploading to Catbox")
async def upload_to_catbox(path: str) -> str:
try:
file_size_bytes = os.path.getsize(path)
except Exception:
file_size_bytes = -1
logger.info(f"Catbox upload start: name={os.path.basename(path)} size={file_size_bytes}")
form = aiohttp.FormData()
form.add_field('reqtype', 'fileupload')
form.add_field('fileToUpload', open(path, 'rb'), filename=os.path.basename(path))
timeout = aiohttp.ClientTimeout(total=600)
async with aiohttp.ClientSession(timeout=timeout) as session:
async with session.post('https://catbox.moe/user/api.php', data=form) as resp:
text = await resp.text()
logger.info(f"Catbox response: status={resp.status} body_len={len(text)}")
if resp.status == 200 and text.startswith('https://'):
url_text = text.strip()
logger.info(f"Catbox upload success: url={url_text}")
return url_text
logger.error(f"Catbox upload failed: status={resp.status} body={text.strip()[:500]}")
raise RuntimeError(f"Upload failed: {text.strip()}")
try: try:
link = await upload_to_catbox(video_file) link = await upload_to_catbox(video_file)
minutes, seconds = divmod(video_duration_seconds, 60) minutes, seconds = divmod(video_duration_seconds, 60)
duration_str = f"{minutes}:{seconds:02d}" duration_str = f"{minutes}:{seconds:02d}"
description_text = f"### **[{video_title}]({video_url})**\n\n{link}" if video_url else f"### **{video_title}**\n\n{link}" description_text = f"### **[{video_title}]({video_url})**" if video_url else f"### **{video_title}**"
embed = discord.Embed( embed = discord.Embed(
title="Download", title="Download",
description=description_text, description=description_text,
@@ -145,10 +208,16 @@ def download_command():
embed.set_footer(text=f"Requested by {context.author.name}", icon_url=context.author.display_avatar.url) embed.set_footer(text=f"Requested by {context.author.name}", icon_url=context.author.display_avatar.url)
if interaction is not None: if interaction is not None:
await interaction.followup.send(embed=embed) await context.channel.send(embed=embed)
await context.channel.send(link)
try:
await interaction.delete_original_response()
except:
pass
else: else:
await processing_msg.delete() await processing_msg.delete()
await context.send(embed=embed) await context.channel.send(embed=embed)
await context.channel.send(link)
return return
except Exception as upload_error: except Exception as upload_error:
logger.exception(f"Catbox upload exception: {upload_error}") logger.exception(f"Catbox upload exception: {upload_error}")
@@ -166,6 +235,10 @@ def download_command():
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp") embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
if interaction is not None: if interaction is not None:
try:
await interaction.delete_original_response()
except:
pass
await interaction.followup.send(embed=embed, ephemeral=True) await interaction.followup.send(embed=embed, ephemeral=True)
else: else:
await processing_msg.delete() await processing_msg.delete()
@@ -192,19 +265,45 @@ def download_command():
file = discord.File(f, filename=files[0]) file = discord.File(f, filename=files[0])
if interaction is not None: if interaction is not None:
await interaction.followup.send(embeds=[embed], files=[file]) await context.channel.send(embed=embed)
await context.channel.send(file=file)
try:
await interaction.delete_original_response()
except:
pass
else: else:
await processing_msg.delete() await processing_msg.delete()
await context.send(embeds=[embed], files=[file]) await context.channel.send(embed=embed)
await context.channel.send(file=file)
except discord.HTTPException as e: except discord.HTTPException as e:
if e.status == 413: if e.status == 413:
logger.info("Discord rejected file (413), falling back to Catbox upload") logger.info("Discord rejected file (413), falling back to Catbox upload")
async def upload_to_catbox(path: str) -> str:
try:
file_size_bytes = os.path.getsize(path)
except Exception:
file_size_bytes = -1
logger.info(f"Catbox upload start: name={os.path.basename(path)} size={file_size_bytes}")
form = aiohttp.FormData()
form.add_field('reqtype', 'fileupload')
form.add_field('fileToUpload', open(path, 'rb'), filename=os.path.basename(path))
timeout = aiohttp.ClientTimeout(total=600)
async with aiohttp.ClientSession(timeout=timeout) as session:
async with session.post('https://catbox.moe/user/api.php', data=form) as resp:
text = await resp.text()
logger.info(f"Catbox response: status={resp.status} body_len={len(text)}")
if resp.status == 200 and text.startswith('https://'):
url_text = text.strip()
logger.info(f"Catbox upload success: url={url_text}")
return url_text
logger.error(f"Catbox upload failed: status={resp.status} body={text.strip()[:500]}")
raise RuntimeError(f"Upload failed: {text.strip()}")
try: try:
link = await upload_to_catbox(video_file) link = await upload_to_catbox(video_file)
description_text_with_link = f"### **[{video_title}]({video_url})**\n\n{link}" if video_url else f"### **{video_title}**\n\n{link}" description_text_with_link = f"### **[{video_title}]({video_url})**\n\n{link}" if video_url else f"### **{video_title}**\n\n{link}"
embed = discord.Embed( embed = discord.Embed(
title="Download", title="Download",
description=description_text_with_link, description=description_text,
color=0x7289DA, color=0x7289DA,
) )
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp") embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
@@ -214,10 +313,16 @@ def download_command():
embed.set_footer(text=f"Requested by {context.author.name}", icon_url=context.author.display_avatar.url) embed.set_footer(text=f"Requested by {context.author.name}", icon_url=context.author.display_avatar.url)
if interaction is not None: if interaction is not None:
await interaction.followup.send(embed=embed) await context.channel.send(embed=embed)
await context.channel.send(link)
try:
await interaction.delete_original_response()
except:
pass
else: else:
await processing_msg.delete() await processing_msg.delete()
await context.send(embed=embed) await context.channel.send(embed=embed)
await context.channel.send(link)
except Exception as upload_error: except Exception as upload_error:
logger.exception(f"Catbox upload exception: {upload_error}") logger.exception(f"Catbox upload exception: {upload_error}")
embed = discord.Embed( embed = discord.Embed(
@@ -228,6 +333,10 @@ def download_command():
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp") embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
if interaction is not None: if interaction is not None:
try:
await interaction.delete_original_response()
except:
pass
await interaction.followup.send(embed=embed, ephemeral=True) await interaction.followup.send(embed=embed, ephemeral=True)
else: else:
await processing_msg.delete() await processing_msg.delete()
@@ -244,6 +353,10 @@ def download_command():
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp") embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
if interaction is not None: if interaction is not None:
try:
await interaction.delete_original_response()
except:
pass
await interaction.followup.send(embed=embed, ephemeral=True) await interaction.followup.send(embed=embed, ephemeral=True)
else: else:
try: try:

View File

@@ -6,23 +6,6 @@ from discord.ext import commands
import aiohttp import aiohttp
import random import random
async def send_error_message(context, description: str):
embed = discord.Embed(
title="Error",
description=description,
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
def mcquote_command(): def mcquote_command():
@commands.hybrid_command( @commands.hybrid_command(
name="mcquote", name="mcquote",
@@ -30,25 +13,92 @@ def mcquote_command():
) )
@commands.cooldown(1, 10, commands.BucketType.user) @commands.cooldown(1, 10, commands.BucketType.user)
async def mcquote(self, context, *, text: str = None): async def mcquote(self, context, *, text: str = None):
if isinstance(context.channel, discord.DMChannel):
embed = discord.Embed(
title="Error",
description="This command can only be used in servers.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return
if isinstance(context.channel, discord.PartialMessageable):
embed = discord.Embed(
title="Error",
description="The bot needs send messages permissions in this channel.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return
if not text: if not text:
await send_error_message(context, "Please provide text for the Minecraft quote.") embed = discord.Embed(
title="Error",
description="Please provide text for the Minecraft quote.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return return
if len(text) > 25: if len(text) > 25:
await send_error_message(context, "Text must be 25 characters or less.") embed = discord.Embed(
title="Error",
description="Text must be 25 characters or less.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return return
processing_embed = discord.Embed(
title="Minecraft Quote (Processing)",
description="<a:mariospin:1423677027013103709> Generating quote... This may take a moment.",
color=0x7289DA,
)
processing_embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None) interaction = getattr(context, "interaction", None)
if interaction is not None: if interaction is not None:
if not interaction.response.is_done(): if not interaction.response.is_done():
await interaction.response.defer(ephemeral=False) await interaction.response.send_message(embed=processing_embed, ephemeral=True)
else:
await interaction.followup.send(embed=processing_embed, ephemeral=True)
else: else:
processing_embed = discord.Embed(
title="Minecraft Quote (Processing)",
description="<a:mariospin:1423677027013103709> Generating quote... This may take a moment.",
color=0x7289DA,
)
processing_embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
processing_msg = await context.send(embed=processing_embed) processing_msg = await context.send(embed=processing_embed)
quote_text = text.replace(" ", "+") quote_text = text.replace(" ", "+")
@@ -75,40 +125,55 @@ def mcquote_command():
with open(temp_file_path, 'rb') as f: with open(temp_file_path, 'rb') as f:
file = discord.File(f, filename="mcquote.png") file = discord.File(f, filename="mcquote.png")
interaction = getattr(context, "interaction", None)
if interaction is not None: if interaction is not None:
await interaction.followup.send(embeds=[embed], files=[file]) await context.channel.send(embed=embed)
await context.channel.send(file=file)
try:
await interaction.delete_original_response()
except:
pass
else: else:
await processing_msg.delete() await processing_msg.delete()
await context.send(embeds=[embed], files=[file]) await context.channel.send(embed=embed)
await context.channel.send(file=file)
os.remove(temp_file_path) os.remove(temp_file_path)
except aiohttp.ClientError: except aiohttp.ClientError:
embed = discord.Embed(
title="Error",
description="Failed to generate Minecraft quote. Please try again later.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None: if interaction is not None:
await interaction.followup.send(embed=discord.Embed( try:
title="Error", await interaction.delete_original_response()
description="Failed to generate Minecraft quote. Please try again later.", except:
color=0xE02B2B, pass
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp"), ephemeral=True) await interaction.followup.send(embed=embed, ephemeral=True)
else: else:
await processing_msg.delete() await processing_msg.delete()
await context.send(embed=discord.Embed( await context.send(embed=embed, ephemeral=True)
title="Error",
description="Failed to generate Minecraft quote. Please try again later.",
color=0xE02B2B,
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp"), ephemeral=True)
except Exception as e: except Exception as e:
embed = discord.Embed(
title="Error",
description=f"An unexpected error occurred: {str(e)}",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None: if interaction is not None:
await interaction.followup.send(embed=discord.Embed( try:
title="Error", await interaction.delete_original_response()
description=f"An unexpected error occurred: {str(e)}", except:
color=0xE02B2B, pass
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp"), ephemeral=True) await interaction.followup.send(embed=embed, ephemeral=True)
else: else:
await processing_msg.delete() await processing_msg.delete()
await context.send(embed=discord.Embed( await context.send(embed=embed, ephemeral=True)
title="Error",
description=f"An unexpected error occurred: {str(e)}",
color=0xE02B2B,
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp"), ephemeral=True)
return mcquote return mcquote

View File

@@ -11,23 +11,6 @@ from gtts import gTTS
DEFAULT_LANG = "en" DEFAULT_LANG = "en"
async def send_error_message(context, description: str):
embed = discord.Embed(
title="Error",
description=description,
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
def tts_command(): def tts_command():
async def send_embed( async def send_embed(
@@ -81,22 +64,86 @@ def tts_command():
text="The text to convert to speech", text="The text to convert to speech",
) )
async def tts(context: commands.Context, text: Optional[str] = None): async def tts(context: commands.Context, text: Optional[str] = None):
if isinstance(context.channel, discord.DMChannel):
embed = discord.Embed(
title="Error",
description="This command can only be used in servers.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return
if isinstance(context.channel, discord.PartialMessageable):
embed = discord.Embed(
title="Error",
description="The bot needs send messages permissions in this channel.",
color=0xE02B2B,
)
embed.set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
interaction = getattr(context, "interaction", None)
if interaction is not None:
if not interaction.response.is_done():
await interaction.response.send_message(embed=embed, ephemeral=True)
else:
await interaction.followup.send(embed=embed, ephemeral=True)
else:
await context.send(embed=embed, ephemeral=True)
return
if not text or not text.strip(): if not text or not text.strip():
if context.message and context.message.reference and context.message.reference.resolved: if context.message and context.message.reference and context.message.reference.resolved:
referenced = context.message.reference.resolved referenced = context.message.reference.resolved
if isinstance(referenced, discord.Message) and referenced.content: if isinstance(referenced, discord.Message) and referenced.content:
text = referenced.content text = referenced.content
if not text or not text.strip(): if not text or not text.strip():
await send_error_message(context, "Please provide text to convert or reply to a message containing text.") embed = (
discord.Embed(
title="Error",
description="Please provide text to convert or reply to a message containing text.",
color=0xE02B2B,
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
)
await send_embed(context, embed, ephemeral=True)
return return
text = text.strip() text = text.strip()
if len(text) > 500: if len(text) > 500:
await send_error_message(context, "Text is too long. Please limit to 500 characters.") embed = (
discord.Embed(
title="Error",
description="Text is too long. Please limit to 500 characters.",
color=0xE02B2B,
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
)
await send_embed(context, embed, ephemeral=True)
return return
processing_embed = (
discord.Embed(
title="TTS (Processing)",
description="<a:mariospin:1423677027013103709> Generating speech...",
color=0x7289DA,
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
)
interaction = getattr(context, "interaction", None) interaction = getattr(context, "interaction", None)
processing_message = None
sent_initial_interaction_response = False
if interaction is not None: if interaction is not None:
if interaction.response.is_done():
processing_message = await interaction.followup.send(embed=processing_embed, ephemeral=True)
else:
await interaction.response.send_message(embed=processing_embed, ephemeral=True)
sent_initial_interaction_response = True
if not interaction.response.is_done(): if not interaction.response.is_done():
await interaction.response.defer(ephemeral=False) await interaction.response.defer(ephemeral=False)
else: else:
@@ -112,19 +159,24 @@ def tts_command():
audio_bytes, error = await generate_tts_audio(text) audio_bytes, error = await generate_tts_audio(text)
if error or not audio_bytes: if error or not audio_bytes:
if interaction is not None: embed = (
await interaction.followup.send(embed=discord.Embed( discord.Embed(
title="Error", title="Error",
description=f"Failed to generate speech. {error or 'Unknown error.'}", description=f"Failed to generate speech. {error or 'Unknown error.'}",
color=0xE02B2B, color=0xE02B2B,
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp"), ephemeral=True) ).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp")
else: )
await processing_message.delete() await send_embed(context, embed, ephemeral=True)
await context.send(embed=discord.Embed( if interaction is not None and sent_initial_interaction_response:
title="Error", try:
description=f"Failed to generate speech. {error or 'Unknown error.'}", await interaction.delete_original_response()
color=0xE02B2B, except Exception:
).set_author(name="Media", icon_url="https://yes.nighty.works/raw/y5SEZ9.webp"), ephemeral=True) pass
if processing_message:
try:
await processing_message.delete()
except Exception:
pass
return return
audio_file = discord.File( audio_file = discord.File(
@@ -146,9 +198,15 @@ def tts_command():
) )
if interaction is not None: if interaction is not None:
await interaction.followup.send(embeds=[embed], files=[audio_file]) await context.channel.send(embed=embed)
await context.channel.send(file=audio_file)
try:
await interaction.delete_original_response()
except:
pass
else: else:
await processing_message.delete() await processing_message.delete()
await context.send(embeds=[embed], files=[audio_file]) await context.channel.send(embed=embed)
await context.channel.send(file=audio_file)
return tts return tts