mirror of
https://github.com/neoarz/Syntrel.git
synced 2025-12-25 03:40:11 +01:00
chore: server bot not selfbot self, selfuse slowing being rolled out
This commit is contained in:
@@ -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
|
||||||
|
|||||||
@@ -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,7 +158,8 @@ 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))]
|
||||||
|
|
||||||
if not files:
|
if not files:
|
||||||
@@ -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,
|
||||||
@@ -143,12 +206,18 @@ def download_command():
|
|||||||
embed.add_field(name="Duration", value=duration_str, inline=True)
|
embed.add_field(name="Duration", value=duration_str, inline=True)
|
||||||
embed.add_field(name="Platform", value=platform, inline=True)
|
embed.add_field(name="Platform", value=platform, inline=True)
|
||||||
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}")
|
||||||
@@ -164,8 +233,12 @@ def download_command():
|
|||||||
color=0xE02B2B,
|
color=0xE02B2B,
|
||||||
)
|
)
|
||||||
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")
|
||||||
@@ -212,12 +311,18 @@ def download_command():
|
|||||||
embed.add_field(name="Duration", value=duration_str, inline=True)
|
embed.add_field(name="Duration", value=duration_str, inline=True)
|
||||||
embed.add_field(name="Platform", value=platform, inline=True)
|
embed.add_field(name="Platform", value=platform, inline=True)
|
||||||
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(
|
||||||
@@ -226,8 +331,12 @@ def download_command():
|
|||||||
color=0xE02B2B,
|
color=0xE02B2B,
|
||||||
)
|
)
|
||||||
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()
|
||||||
@@ -242,8 +351,12 @@ def download_command():
|
|||||||
color=0xE02B2B,
|
color=0xE02B2B,
|
||||||
)
|
)
|
||||||
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:
|
||||||
|
|||||||
@@ -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
|
||||||
@@ -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
|
||||||
Reference in New Issue
Block a user