import discord from discord.ext import commands from random import randint, choice import time from datetime import datetime from pytz import timezone def setup(bot): bot.add_cog(Commands(bot)) class Commands(commands.Cog): """Commandes générales du bot.""" def __init__(self, bot): self.bot = bot # dans le message envoyer : le premier chiffre est la latence du protocole Discord WebSocket, # le deuxieme c'est le temps que le bot a pris pour faire les p'tits calculs, # le troisième c'est le temps que le bot a pris pour réagir au message @commands.command() async def ping(self, ctx, *, question = '0'): """Affiche mon ping.⁢⁢⁢⁢⁢\n ➡ Syntaxe: .ping [help]⁢⁢⁢⁢⁢⁢⁢⁢⁢⁢""" if question == 'help': return await ctx.send(embed = discord.Embed(color = randint(0, 0xFFFFFF), description = ":hourglass: correspond au temps entre deux battements de cœurs (en millisecondes)\n\n" + ":stopwatch: correspond au temps que met le bot a calculer le ping (en millisecondes)\n\n" + ":heartbeat: correspond au temps que met le bot a réagir au messages (en millisecondes)")) else: now = int(round(time.time() * 1000)) ping = now - int(round(ctx.message.created_at.timestamp() * 1000)) embed = discord.Embed(description = 'Pinging...') message = await ctx.send(embed = embed) ping2 = int(round(time.time() * 1000)) - now await message.edit(embed = discord.Embed(color = randint(0, 0xFFFFFF), description = f':hourglass: {round(self.bot.latency * 1000)}ms\n\n:stopwatch: {ping2}ms\n\n:heartbeat: {ping}ms')) await ctx.message.add_reaction(emoji = '✅') @commands.command(aliases = ['calculatrice', 'calcu']) async def calc(self, ctx, *, msg): """Calculatrice.\n ➡ Syntaxe: .calc/calculatrice/calcu ⁢⁢⁢⁢⁢⁢⁢⁢⁢⁢""" equation = msg.replace('^', '**').replace('x', '*').replace('×', '*').replace('÷', '/').replace('≥', '>=').replace('≤', '<=') try: try: if '=' in equation: if '<' in equation: left = eval(equation.split("<=")[0]) right = eval(equation.split("<=")[1]) answer = str(left <= right) elif '>' in equation: left = eval(equation.split(">=")[0]) right = eval(equation.split(">=")[1]) answer = str(left >= right) else: left = eval(equation.split("=")[0]) right = eval(equation.split("=")[1]) answer = str(left == right) else: answer = str(eval(equation)) except ZeroDivisionError: return await ctx.send("Tu ne peux pas divisé par 0.") except TypeError: return await ctx.send("Requête de calcul invalide.") if '.' in answer: aftercomma = answer.split(".")[1] if len(aftercomma) > 2: answer = str(round(float(answer),2)) equation = f"'{equation}' arrondi à 2" equation = equation.replace('*', '×').replace('/', '÷').replace('>=', '≥').replace('<=', '≤') embed = discord.Embed(color = randint(0, 0xFFFFFF), title = 'Calculatrice') embed.set_footer(text = ctx.author) embed.add_field(name = 'Calcul :', value = equation, inline = False) embed.add_field(name = 'Réponse :', value = answer.replace('False', 'Faux').replace('True', 'Vrai'), inline = False) await ctx.message.add_reaction(emoji = '✅') await ctx.send(content = None, embed = embed) @calc.error async def calc_error(self, ctx, error): await ctx.send("Tu n'as pas spécifié de calcul.") @commands.command() async def syntax(self, ctx): """Informations pour bien éditer son texte.⁢⁢⁢⁢⁢⁢⁢⁢⁢⁢""" syntaxe = "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("```Js\n") syntaxe += discord.utils.escape_markdown("//code en js (possible de remplacer 'js' par d'autres languages . adaptez le !)\n") syntaxe += discord.utils.escape_markdown('console.log("hi");\n') syntaxe += discord.utils.escape_markdown("```\n") syntaxe += "```Js\n" syntaxe += "//code en js (possible de remplacer 'js' par d'autres languages . adaptez le !)\n" syntaxe += 'console.log("hi");\n' syntaxe += "```\n" syntaxe += "Si ton code est trop long, mets le sur \n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("`code sur une seule ligne`\n") syntaxe += "`code sur une seule ligne`\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("*texte en italique*\n") syntaxe += "*texte en italique*\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("**text en gras**\n") syntaxe += "**text en gras**\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("<>\n") syntaxe += "Un lien entre crochet, ça empêche Discord de rajouté son intégration automatique (mais le lien fonctionnera toujours).\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("__texte souligné__\n") syntaxe += "__texte souligné__\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("~~texte barré~~\n") syntaxe += "~~texte barré~~\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("~~__***text en italique-gras-souligné-barré***__~~\n") syntaxe += "~~__***text en italique-gras-souligné-barré***__~~\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("\:joy: <- l'emoji ne va pas fonctionné grâce au \ \n") syntaxe += "\:joy: <- l'emoji ne va pas fonctionné grâce au \ \n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown("> cette ligne est cité\npas celle là\n") syntaxe += "> cette ligne est cité\npas celle là\n" syntaxe += "-----------------------------------------------------\n" syntaxe += discord.utils.escape_markdown(">>> cette ligne est cité\ncelle là aussi (et elles le seront toutes!)\n") syntaxe += ">>> cette ligne est cité\ncelle là aussi (et elles le seront toutes!)\n" await ctx.message.add_reaction(emoji = '✅') await ctx.send(syntaxe) @commands.command(aliases = ['info']) async def infos(self, ctx): """Donne des infos sur le bot.\n ➡ Syntaxe: .infos/info⁢""" appinfo = await self.bot.application_info() embed = discord.Embed(color = randint(0, 0xFFFFFF)) embed.set_author(name=appinfo.name, icon_url=self.bot.user.avatar_url) # liste utilisateurs de tous les serveurs où le bot est, en ligne total_online = len({m.id for m in self.bot.get_all_members() if m.status is discord.Status.online}) total_unique = len(self.bot.users) # pareil mais en comptants les hors lignes aussi # liste des différents canaux voice_channels = [] text_channels = [] for guild in self.bot.guilds: voice_channels.extend(guild.voice_channels) text_channels.extend(guild.text_channels) text = len(text_channels) voice = len(voice_channels) embed.add_field(name='Dev', value=f"[{appinfo.owner}](https://github.com/Mylloon)") # pub gratuite embed.add_field(name='Serveurs', value=len(self.bot.guilds)) embed.add_field(name='Membres', value=f'{total_unique} au total\n{total_online} en ligne') embed.add_field(name='Channels', value=f'{text} textuelles\n{voice} vocales') # ca peut être utile de connaitre quel version le bot utilise sans devoir se connecter a distance au serveur qui fait tourner le bot embed.set_footer(text=f'Basé sur discord.py {discord.__version__}') await ctx.send(embed=embed) @commands.command() async def whois(self, ctx, *user: discord.Member): """Affiche les infos sur l'utilisateur.⁢⁢⁢⁢⁢\n ➡ Syntaxe: .whois [user]⁢⁢⁢⁢⁢⁢⁢⁢⁢⁢""" if len(user) <= 1: if user == (): user = [ctx.author] nom = f"{user[0].name}#{user[0].discriminator}" if user[0].nick: nom = f"{user[0].nick} ({user[0].name}#{user[0].discriminator})" embed = discord.Embed(color = randint(0, 0xFFFFFF)).set_author(name = nom, icon_url = user[0].avatar_url) embed.add_field(name = "ID", value = user[0].id) value = str(user[0].created_at.astimezone(timezone('Europe/Paris')))[:-13].replace('-', '/').split() embed.add_field(name = "Compte créé le", value = f"{value[0][8:]}/{value[0][5:-3]}/{value[0][:4]} à {value[1]}") embed.add_field(name = "Âge du compte", value = self.age_layout(self.get_age(user[0].created_at))) embed.add_field(name = "Mention", value = user[0].mention) value = str(user[0].joined_at.astimezone(timezone('Europe/Paris')))[:-13].replace('-', '/').split() embed.add_field(name = "Serveur rejoint le", value = f"{value[0][8:]}/{value[0][5:-3]}/{value[0][:4]} à {value[1]}") embed.add_field(name = "Est sur le serveur depuis", value = self.age_layout(self.get_age(user[0].joined_at))) return await ctx.send(embed = embed) await ctx.send("Tu mentionnes trop d'utilisateurs : `.whois [@Membre]`") def get_age(self, date): joursRestants = datetime.now() - date years = joursRestants.total_seconds() / (365.242 * 24 * 3600) months = (years - int(years)) * 12 days = (months - int(months)) * (365.242 / 12) hours = (days - int(days)) * 24 minutes = (hours - int(hours)) * 60 seconds = (minutes - int(minutes)) * 60 return (int(years), int(months), int(days), int(hours), int(minutes), int(seconds)) def age_layout(self, tuple): time = {} time[0], time[1], time[2], time[3], time[4], time[5] = "an", "mois", "jour", "heure", "minute", "seconde" for i in range(len(tuple)): if tuple[i] > 1 and i != 1: time[i] = time[i] + "s" message = "" if tuple[5] > 0: # pour les secondes affichage = [5] # on affiche que : seconde if tuple[4] > 0: affichage = [4, 5] # on affiche : minute + seconde if tuple[3] > 0: affichage = [3, 4, 5] # on affiche : heure + minute + seconde if tuple[2] > 0: affichage = [2, 3, 4] # on affiche : jour + heure + minute if tuple[1] > 0: affichage = [1, 2, 3] # on affiche : mois + jour + heure if tuple[0] > 0: affichage = [0, 1, 3] # on affiche : an + mois + heure for i in affichage: message = message + f", {tuple[i]} {time[i]}" return message[2:]