import asyncio import datetime import random from discord import Colour, Embed, Member from discord.ext import commands from discord.ext.commands import BucketType from discord.ext.commands import cooldown, command import settings # Set up the Cog class Embeds(commands.Cog): def __init__(self, bot): self.bot = bot # ~kiss command which allows users to kiss a person in the server @command(name="kiss", aliases=["Kiss"]) # Added a cooldown, only 1 instance of the command can be sent every second per user @cooldown(1, 1, BucketType.user) async def kissing(self, ctx, target: Member): # Surround with try/except to catch any exceptions that may occur try: # If the channel that the command has been sent is in the list of accepted channels if str(ctx.channel) in settings.channels: # Open the file containing the kissing gifs with open('images/FunCommands/kissing.txt') as file: # Store content of the file in kissing_array kissing_array = file.readlines() # Set member as the author member = ctx.message.author # Get the member avatar userAvatar = member.avatar_url # Set up the embed to display a random kissing gif embed = Embed( title=f" | **{member.display_name}** kissed **{target.display_name}**", colour=Colour(int(random.choice(settings.colour_list))), timestamp=datetime.datetime.utcnow()) embed.set_image(url=random.choice(kissing_array)) embed.set_footer(text=f"Requested by {member}", icon_url='{}'.format(userAvatar)) # Send the embedded message to the user await ctx.send(embed=embed) # else the command is sent in an invalid channel else: # Call error_function() and display it to the user message = await ctx.send(error_function()) # Let the user read the message for 2.5 seconds await asyncio.sleep(2.5) # Delete the message await message.delete() except FileNotFoundError as e: print(e) # ~kill command which allows users to kill a person in the server @command(name="kill", aliases=["Kill"]) # Added a cooldown, only 1 instance of the command can be sent every second per user @cooldown(1, 1, BucketType.user) async def killing(self, ctx, target: Member): # Surround with try/except to catch any exceptions that may occur try: # If the channel that the command has been sent is in the list of accepted channels if str(ctx.channel) in settings.channels: # Open the file containing the killing gifs with open('images/FunCommands/killing.txt') as file: # Store content of the file in killing_array killing_array = file.readlines() # Set member as the author member = ctx.message.author # Get the member avatar userAvatar = member.avatar_url # Set up the embed to display a random killing gif embed = Embed( title=f"<:monkaW:718960264896184380> <:monkaW:718960264896184380> | **{member.display_name}** killed **{target.display_name}**", colour=Colour(int(random.choice(settings.colour_list))), timestamp=datetime.datetime.utcnow()) embed.set_image(url=random.choice(killing_array)) embed.set_footer(text=f"Requested by {member}", icon_url='{}'.format(userAvatar)) # Send the embedded message to the user await ctx.send(embed=embed) # else the command is sent in an invalid channel else: # Call error_function() and display it to the user message = await ctx.send(error_function()) # Let the user read the message for 2.5 seconds await asyncio.sleep(2.5) # Delete the message await message.delete() except FileNotFoundError as e: print(e) # ~cuddle command which allows users to cuddle a person in the server @command(name="cuddle", aliases=["Cuddle"]) # Added a cooldown, only 1 instance of the command can be sent every second per user @cooldown(1, 1, BucketType.user) async def cuddling(self, ctx, target: Member): # Surround with try/except to catch any exceptions that may occur try: # If the channel that the command has been sent is in the list of accepted channels if str(ctx.channel) in settings.channels: # Open the file containing the cuddling gifs with open('images/FunCommands/cuddling.txt') as file: # Store content of the file in cuddling_array cuddling_array = file.readlines() # Set member as the author member = ctx.message.author # Get the member avatar userAvatar = member.avatar_url # Set up the embed to display a random cuddling gif embed = Embed( title=f"<:blushlook1:677310734123663363> <:blushlook2:679524467248201769> | **{member.display_name}** cuddled **{target.display_name}**", colour=Colour(int(random.choice(settings.colour_list))), timestamp=datetime.datetime.utcnow()) embed.set_image(url=random.choice(cuddling_array)) embed.set_footer(text=f"Requested by {member}", icon_url='{}'.format(userAvatar)) # Send the embedded message to the user await ctx.send(embed=embed) # else the command is sent in an invalid channel else: # Call error_function() and display it to the user message = await ctx.send(error_function()) # Let the user read the message for 2.5 seconds await asyncio.sleep(2.5) # Delete the message await message.delete() except FileNotFoundError as e: print(e) # ~slap command which allows users to cuddle a person in the server @command(name="slap", aliases=["Slap"]) # Added a cooldown, only 1 instance of the command can be sent every second per user @cooldown(1, 1, BucketType.user) async def slapping(self, ctx, target: Member): # Surround with try/except to catch any exceptions that may occur try: # If the channel that the command has been sent is in the list of accepted channels if str(ctx.channel) in settings.channels: # Open the file containing the cuddling gifs with open('images/FunCommands/slapping.txt') as file: # Store content of the file in cuddling_array slapping_array = file.readlines() # Set member as the author member = ctx.message.author # Get the member avatar userAvatar = member.avatar_url # Set up the embed to display a random slapping gif embed = Embed( title=f"<:baka:718942872061083678> <:baka:718942872061083678> | **{member.display_name}** slapped **{target.display_name}**", colour=Colour(int(random.choice(settings.colour_list))), timestamp=datetime.datetime.utcnow()) embed.set_image(url=random.choice(slapping_array)) embed.set_footer(text=f"Requested by {member}", icon_url='{}'.format(userAvatar)) # Send the embedded message to the user await ctx.send(embed=embed) # else the command is sent in an invalid channel else: # Call error_function() and display it to the user message = await ctx.send(error_function()) # Let the user read the message for 2.5 seconds await asyncio.sleep(2.5) # Delete the message await message.delete() except FileNotFoundError as e: print(e) # ~slap command which allows users to cuddle a person in the server @command(name="pat", aliases=["Pat"]) # Added a cooldown, only 1 instance of the command can be sent every second per user @cooldown(1, 1, BucketType.user) async def patting(self, ctx, target: Member): # Surround with try/except to catch any exceptions that may occur try: # If the channel that the command has been sent is in the list of accepted channels if str(ctx.channel) in settings.channels: # Open the file containing the patting gifs with open('images/FunCommands/patting.txt') as file: # Store content of the file in patting_array patting_array = file.readlines() # Set member as the author member = ctx.message.author # Get the member avatar userAvatar = member.avatar_url # Set up the embed to display a random patting gif embed = Embed( title=f"<:xoxo:679893117482303564> <:xoxo:679893117482303564> | **{member.display_name}** patted **{target.display_name} on the head**", colour=Colour(int(random.choice(settings.colour_list))), timestamp=datetime.datetime.utcnow()) embed.set_image(url=random.choice(patting_array)) embed.set_footer(text=f"Requested by {member}", icon_url='{}'.format(userAvatar)) # Send the embedded message to the user await ctx.send(embed=embed) # else the command is sent in an invalid channel else: # Call error_function() and display it to the user message = await ctx.send(error_function()) # Let the user read the message for 2.5 seconds await asyncio.sleep(2.5) # Delete the message await message.delete() except FileNotFoundError as e: print(e) # ~lemon command which allows users to hand people lemons to members in the user @command(name="lemon", aliases=["Lemon"]) # Added a cooldown, only 1 instance of the command can be sent every second per user @cooldown(1, 1, BucketType.user) async def give_lemon(self, ctx, target: Member): lemon_array = ["https://media.discordapp.net/attachments/669812887564320769/720093589056520202/lemon.gif", "https://media.discordapp.net/attachments/669812887564320769/720093575492272208/lemon2.gif", "https://media.discordapp.net/attachments/718484280925224981/719629805263257630/lemon.gif"] # Surround with try/except to catch any exceptions that may occur try: # If the channel that the command has been sent is in the list of accepted channels if str(ctx.channel) in settings.channels: # Set member as the author member = ctx.message.author # Get the member avatar userAvatar = member.avatar_url # Set up the embed to display a random lemon gif embed = Embed( title=f" | **{member.display_name}** Gives A Lemon To **{target.display_name}**", colour=Colour(int(random.choice(settings.colour_list))), timestamp=datetime.datetime.utcnow()) embed.set_image(url=random.choice(lemon_array)) embed.set_footer(text=f"Requested by {member}", icon_url='{}'.format(userAvatar)) # Send the embedded message to the user await ctx.send(embed=embed) # else the command is sent in an invalid channel else: # Call error_function() and display it to the user message = await ctx.send(error_function()) # Let the user read the message for 2.5 seconds await asyncio.sleep(2.5) # Delete the message await message.delete() except FileNotFoundError as e: print(e) # Error handling function to make sure that the commands only work in "enso-chan-commands" def error_function(): return "Sorry! I only work in <#721449922838134876>" def setup(bot): bot.add_cog(Embeds(bot))