diff --git a/.gitignore b/.gitignore index eee48e7..f83fe4f 100644 --- a/.gitignore +++ b/.gitignore @@ -1,11 +1,9 @@ - config.json -__pycache__\ - log_test.txt __pycache__/ .vscode/ -.vscode\ \ No newline at end of file + +.zedstate \ No newline at end of file diff --git a/Administration.py b/Administration.py index bdacc41..90e5877 100644 --- a/Administration.py +++ b/Administration.py @@ -39,15 +39,15 @@ class Administration: async def load(self, ctx, ext): if self.is_owner(ctx.message.author.id) == True: self.bot.load_extension(ext) - print("Extention "+str(ext)+" charger par: "+str(ctx.message.author)) + print("Extension "+str(ext)+" chargée par: "+str(ctx.message.author)) embed=discord.Embed(title="Administration", description="Modules", color=0xffff00) - embed.add_field(name="Chargement", value="Extension "+str(ext)+" charger", inline=False) + embed.add_field(name="Chargement", value="Extension "+str(ext)+" chargée", inline=False) await self.bot.say(embed=embed) else: - print("Refue de charger: "+str(ext)+" car "+str(ctx.message.author)+" n'a pas le droit !") + print("Refus de charger: "+str(ext)+" car "+str(ctx.message.author)+" n'a pas le droit !") embed=discord.Embed(title="Administration", description="Modules", color=0xffff00) - embed.add_field(name="Chargement", value="Désoler <@"+str(ctx.message.author.id)+"> mais vous n'avez pas le droit de faire ca !", inline=False) + embed.add_field(name="Chargement", value="Désolé <@"+str(ctx.message.author.id)+"> mais vous n'avez pas le droit de faire ca !", inline=False) await self.bot.say(embed=embed) #Décharger une extension @@ -55,15 +55,15 @@ class Administration: async def unload(self, ctx, ext): if self.is_owner(ctx.message.author.id) == True: self.bot.unload_extension(ext) - print("extention "+str(ext)+" décharger") + print("Extension "+str(ext)+" déchargée") embed=discord.Embed(title="Administration", description="Modules", color=0xffff00) - embed.add_field(name="Déchargement", value="Extension "+str(ext)+" décharger", inline=False) + embed.add_field(name="Déchargement", value="Extension "+str(ext)+" déchargée", inline=False) await self.bot.say(embed=embed) else: - print("Refue de décharger: "+str(ext)+" car "+str(ctx.message.author)+" n'a pas le droit !") + print("Refus de décharger: "+str(ext)+" car "+str(ctx.message.author)+" n'a pas le droit !") embed=discord.Embed(title="Administration", description="Modules", color=0xffff00) - embed.add_field(name="Déchargement", value="Désoler <@"+str(ctx.message.author.id)+"> mais vous n'avez pas le droit de faire ca !", inline=False) + embed.add_field(name="Déchargement", value="Désolé <@"+str(ctx.message.author.id)+"> mais vous n'avez pas le droit de faire ca !", inline=False) await self.bot.say(embed=embed) #Recharger une extension @@ -72,15 +72,15 @@ class Administration: if self.is_owner(ctx.message.author.id) == True: self.bot.unload_extension(ext) self.bot.load_extension(ext) - print("Extention "+str(ext)+" mis à jour par: "+str(ctx.message.author)) + print("Extension "+str(ext)+" mise à jour par: "+str(ctx.message.author)) embed=discord.Embed(title="Administration", description="Modules", color=0xffff00) - embed.add_field(name="Reload", value="Extension "+str(ext)+" mis à jour", inline=False) + embed.add_field(name="Reload", value="Extension "+str(ext)+" mise à jour", inline=False) await self.bot.say(embed=embed) else: - print("Refue de mettre à jour: "+str(ext)+" car "+str(ctx.message.author)+" n'a pas le droit !") + print("Refus de mettre à jour: "+str(ext)+" car "+str(ctx.message.author)+" n'a pas le droit !") embed=discord.Embed(title="Administration", description="Modules", color=0xffff00) - embed.add_field(name="Reload", value="Désoler <@"+str(ctx.message.author.id)+"> mais vous n'avez pas le droit de faire ca !", inline=False) + embed.add_field(name="Reload", value="Désolé <@"+str(ctx.message.author.id)+"> mais vous n'avez pas le droit de faire ca !", inline=False) await self.bot.say(embed=embed) @@ -88,19 +88,19 @@ class Administration: @commands.command(pass_context=True) async def shutdown(self, ctx): if self.is_owner(ctx.message.author.id) == True: - print("Arret du bot fait par:"+str(ctx.message.author)+" !") + print("Arrêt du bot fait par:"+str(ctx.message.author)+" !") embed=discord.Embed(title="Administration", description="", color=0xffff00) embed.set_thumbnail(url="https://icon-icons.com/icons2/562/PNG/512/on-off-power-button_icon-icons.com_53938.png") - embed.add_field(name="Arret", value="FTW's Bot arréter", inline=False) + embed.add_field(name="Arrêt", value="FTW's Bot arrêté", inline=False) await self.bot.say(embed=embed) await self.bot.logout() await self.bot.close() else: - print("Arret du bot fait par:"+str(ctx.message.author)+" refuser") + print("Arrêt du bot fait par:"+str(ctx.message.author)+" refuser") embed=discord.Embed(title="Administration", description="", color=0xffff00) embed.set_thumbnail(url="https://icon-icons.com/icons2/562/PNG/512/on-off-power-button_icon-icons.com_53938.png") - embed.add_field(name="Erreur", value="Désoler mais vous n'avez pas le droit !", inline=False) + embed.add_field(name="Erreur", value="Désolé mais vous n'avez pas le droit !", inline=False) await self.bot.say(embed=embed) await self.bot.logout() await self.bot.close() diff --git a/Benne_a_ordure.py b/Benne_a_ordure.py index 32d6f5e..9763ce6 100644 --- a/Benne_a_ordure.py +++ b/Benne_a_ordure.py @@ -1,139 +1,125 @@ -import discord -from discord.ext import commands - - #Paramètres - -deletion_minimal = -2 #quantité de votes totale nécessaire - #pour supprimer un post. - #Prends en compte le nombre de votes - #pour le conserver et pour le supprimer. -delet_symbole = "🗑" #Réaction permettant la suppression du post. -cons_symbole = "♻" #Réaction permettant la conservation du post. - -authorized_to_start_deletion = ["156484695083843585","177393521051959306"] -blocked_from_deleted = [".156484695083843585",".384104235375001632"] - - - -reactDict = {} -messageDict = {} - - - - -def authorized_verif(id): - for i in range(len(authorized_to_start_deletion)): - if id == authorized_to_start_deletion[i]: - return True - return False - -def anti_delete(id): - for i in range(len(blocked_from_deleted)): - if str(id) == blocked_from_deleted[i]: - return False - return True - - -async def first_reaction(self , reaction , user): - if authorized_verif(user.id): - print("creation") - if reaction.emoji == delet_symbole: - reactDict[reaction.message.id]=-1 - elif reaction.emoji == cons_symbole: - reactDict[reaction.message.id]=1 - date,heure = timeCorrect(reaction.message.timestamp) - - - message = str(reaction.message.author.mention)+" a recut un vote pour la suppression ou la conservation de son message du "+str(reaction.message.timestamp)+".Si vous souhaitez voir son message supprimé, votez "+delet_symbole+". Si vous pensez que son message est correct, votez "+str(cons_symbole)+"." - m = await self.bot.send_message(reaction.message.channel,message) - messageDict[reaction.message.id]=m - await self.bot.add_reaction(reaction.message,cons_symbole) - await self.bot.add_reaction(reaction.message,delet_symbole) - -async def delete(self , reaction , user): - await self.bot.delete_message(reaction.message) - await self.bot.delete_message(messageDict[reaction.message.id]) - - -def timeCorrect(temps): - date = "5" - heure = "6" - - - - - - return date,heure - - - -class Ben: - def __init__(self,bot): - self.bot = bot - f = open("log_test.txt","a") #Montres le début de l'enregistrement dans les logs. - f.write("\n\nDébut de l'enregistrement des réactions.\n\n\n") - f.close - - - async def on_reaction_remove(self,reaction,user):#Récupères la réaction - print("-"+str(reaction.emoji)) #si on retire une réaction. - print(reaction.count) - print(user.name) - print(reaction.message.id) - if str(reaction.emoji) == cons_symbole: #Vérifie si le caractère - reactDict[reaction.message.id]-=1 #corresponds au symbole - elif str(reaction.emoji) == delet_symbole: #de suppression - reactDict[reaction.message.id]+=1 - #ou au symbole de conservation. - print("num = "+str(reactDict[reaction.message.id])) - if reactDict[reaction.message.id]==deletion_minimal: - await delete(self , reaction , user) #si le - #nombre est - #suppérieur, - #suppression. - - - - - #def auto_deletion(self,Message): - # await self.bot.delete_message(Message) - # print(Message.content) - - - - async def on_reaction_add(self, reaction, user): #Récupères la réaction - print("+"+str(reaction.emoji)) #si on ajoute une réaction. - print(reaction.count) - print(user.name) - print(reaction.message.id) - if anti_delete(reaction.message.author.id)== True: - print("message autorise") - if str(reaction.emoji) == cons_symbole: - if reactDict.get(reaction.message.id)!=None: - reactDict[reaction.message.id]+=1 - print("message present") - else: - await first_reaction(self,reaction,user) - - - - if str(reaction.emoji) == delet_symbole: - if reactDict.get(reaction.message.id)!=None: - reactDict[reaction.message.id]-=1 - print("message present") - else: - await first_reaction(self,reaction,user) - - - - if reactDict.get(reaction.message.id) != None : - if reactDict[reaction.message.id]<=deletion_minimal: - await delete(self , reaction , user) - else: - print(reactDict[reaction.message.id]) - - print("tzdsqdzqs"+str(reactDict[reaction.message.id])) - -def setup(bot): - bot.add_cog(Ben(bot)) - print("Benne_a_ordure charger") +import discord +from discord.ext import commands + + #Paramètres + +deletion_minimal = -2 #quantité de votes totale nécessaire + #pour supprimer un post. + #Prends en compte le nombre de votes + #pour le conserver et pour le supprimer. +delet_symbole = "🗑" #Réaction permettant la suppression du post. +cons_symbole = "♻" #Réaction permettant la conservation du post. + +authorized_to_start_deletion = ["156484695083843585","177393521051959306"] +blocked_from_deleted = [".156484695083843585",".384104235375001632"] + +reactDict = {} +messageDict = {} + +def authorized_verif(id): + for i in range(len(authorized_to_start_deletion)): + if id == authorized_to_start_deletion[i]: + return True + return False + +def anti_delete(id): + for i in range(len(blocked_from_deleted)): + if str(id) == blocked_from_deleted[i]: + return False + return True + + +async def first_reaction(self , reaction , user): + if authorized_verif(user.id): + print("Création") + if reaction.emoji == delet_symbole: + reactDict[reaction.message.id]=-1 + elif reaction.emoji == cons_symbole: + reactDict[reaction.message.id]=1 + date,heure = timeCorrect(reaction.message.timestamp) + + message = str(reaction.message.author.mention)+" a reçu un vote pour la suppression ou la conservation de son message du "+str(reaction.message.timestamp)+".Si vous souhaitez voir son message supprimé, votez "+delet_symbole+". Si vous pensez que son message est correct, votez "+str(cons_symbole)+"." + m = await self.bot.send_message(reaction.message.channel,message) + messageDict[reaction.message.id]=m + await self.bot.add_reaction(reaction.message,cons_symbole) + await self.bot.add_reaction(reaction.message,delet_symbole) + +async def delete(self , reaction , user): + await self.bot.delete_message(reaction.message) + await self.bot.delete_message(messageDict[reaction.message.id]) + +def timeCorrect(temps): + date = "5" + heure = "6" + return date,heure + +class Ben: + def __init__(self,bot): + self.bot = bot + f = open("log_test.txt","a") #Montres le début de l'enregistrement dans les logs. + f.write("\nDébut de l'enregistrement des réactions.\n") + f.close + + + async def on_reaction_remove(self,reaction,user):#Récupères la réaction + print("-"+str(reaction.emoji)) #si on retire une réaction. + print(reaction.count) + print(user.name) + print(reaction.message.id) + if str(reaction.emoji) == cons_symbole: #Vérifie si le caractère + reactDict[reaction.message.id]-=1 #corresponds au symbole + elif str(reaction.emoji) == delet_symbole: #de suppression + reactDict[reaction.message.id]+=1 + #ou au symbole de conservation. + print("num = "+str(reactDict[reaction.message.id])) + if reactDict[reaction.message.id]==deletion_minimal: + await delete(self , reaction , user) #si le + #nombre est + #suppérieur, + #suppression. + + + + + #def auto_deletion(self,Message): + # await self.bot.delete_message(Message) + # print(Message.content) + + + + async def on_reaction_add(self, reaction, user): #Récupères la réaction + print("+"+str(reaction.emoji)) #si on ajoute une réaction. + print(reaction.count) + print(user.name) + print(reaction.message.id) + if anti_delete(reaction.message.author.id)== True: + print("Message autorisé") + if str(reaction.emoji) == cons_symbole: + if reactDict.get(reaction.message.id)!=None: + reactDict[reaction.message.id]+=1 + print("Message présent") + else: + await first_reaction(self,reaction,user) + + + + if str(reaction.emoji) == delet_symbole: + if reactDict.get(reaction.message.id)!=None: + reactDict[reaction.message.id]-=1 + print("Message présent") + else: + await first_reaction(self,reaction,user) + + + + if reactDict.get(reaction.message.id) != None : + if reactDict[reaction.message.id]<=deletion_minimal: + await delete(self , reaction , user) + else: + print(reactDict[reaction.message.id]) + + #print("tzdsqdzqs"+str(reactDict[reaction.message.id])) + +def setup(bot): + bot.add_cog(Ben(bot)) + print("Benne_a_ordure chargée") diff --git a/DefaultCMD.py b/DefaultCMD.py index a4c533b..9c2cc63 100644 --- a/DefaultCMD.py +++ b/DefaultCMD.py @@ -1,41 +1,41 @@ -import discord -from discord.ext import commands - -class DefaultCMD: - def __init__(self, bot): - self.bot = bot - - #Commande ping - @commands.command(pass_context=True) - async def ping(self, ctx): - """La commande la plus stupide de se bot""" - await self.bot.say("Pong!") - print("Commande ping lancer par: "+str(ctx.message.author)) - - #Commande dis - @commands.command(pass_context=True) - async def dis(self, ctx, *, something): - """Un mode peroquet""" - await self.bot.say(something) - print("Commande dis lancer par: "+str(ctx.message.author)+" argument: "+str(something)) - - #Commande flash - @commands.command(pass_context=True) - async def flash(self, ctx, *, something): - """Fait apparaitre un text siblimiquement""" - await self.bot.delete_message(ctx.message) - print("Commande flash lancer par: "+str(ctx.message.author)+" argument: "+str(something)) - - #Commande indirect - @commands.command(pass_context=True) - async def say(self, ctx, *, something): - """Fait passer un message indirectement""" - await self.bot.say("**{} said:** {}".format(str(ctx.message.author), something)) - await self.bot.delete_message(ctx.message) - print("Commande say lancer par: "+str(ctx.message.author)+" argument: "+str(something)) - - - -def setup(bot): - bot.add_cog(DefaultCMD(bot)) - print("DefaultCMD charger") +import discord +from discord.ext import commands + +class DefaultCMD: + def __init__(self, bot): + self.bot = bot + + #Commande ping + @commands.command(pass_context=True) + async def ping(self, ctx): + """La commande la plus stupide de se bot""" + await self.bot.say("Pong!") + print("Commande ping lancée par: "+str(ctx.message.author)) + + #Commande dis + @commands.command(pass_context=True) + async def dis(self, ctx, *, something): + """Un mode peroquet""" + await self.bot.say(something) + print("Commande dis lancée par: "+str(ctx.message.author)+" argument: "+str(something)) + + #Commande flash + @commands.command(pass_context=True) + async def flash(self, ctx, *, something): + """Fait apparaitre un text siblimiquement""" + await self.bot.delete_message(ctx.message) + print("Commande flash lancée par: "+str(ctx.message.author)+" argument: "+str(something)) + + #Commande indirect + @commands.command(pass_context=True) + async def say(self, ctx, *, something): + """Fait passer un message indirectement""" + await self.bot.say("**{} said:** {}".format(str(ctx.message.author), something)) + await self.bot.delete_message(ctx.message) + print("Commande say lancée par: "+str(ctx.message.author)+" argument: "+str(something)) + + + +def setup(bot): + bot.add_cog(DefaultCMD(bot)) + print("DefaultCMD chargée") diff --git a/ExampleRepl.py b/ExampleRepl.py index 75bd12e..9bd3cf7 100644 --- a/ExampleRepl.py +++ b/ExampleRepl.py @@ -163,4 +163,4 @@ class REPL: def setup(bot): bot.add_cog(REPL(bot)) - print("ExampleRepl charger") + print("ExampleRepl chargée") diff --git a/Garou.py b/Garou.py index 93fd9a2..facbbed 100644 --- a/Garou.py +++ b/Garou.py @@ -20,7 +20,7 @@ class Garou: num_joueurs = 0 #Nombre de joueurs dans la partie #Vrai variables - minijoueurs = 1 #5, Le nombre minimum de joueurs qu'il faut pour lancer une partie + minijoueurs = 1 #5, Le nombre minimum de joueurs qu'il faut pour lancée une partie roles = ["0", "LG", "VY", "VO", "SO", "VG", "VG", "CS", "CU", "LG", "CL", "AG", "MA", "IL", "IPDL", "JDF", "VG", "RE", "GML", "VG", "LGB", "VG", "SA", "LG", "AS", "CER", "MO", "AC", "SE", "SE", "IDV", "BE", "ES", "KZ", "ISM", "VG"] #Les roles donner #text time @@ -30,7 +30,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Villageois") intro.add_field(name="Votre personnage : ", value="*A Thiercelieu les habitants sont victimes d’une terrible malédiction, chaque jour ils tentent de tuer un loup-garou en votant*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous, à chaque journée, vous votez avec le reste des joueurs pour tenter d’éliminer les loups-garous.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous, à chaque journée, vous votez avec le reste des joueurs pour tenter d’éliminer les loups-garous.**", inline=False) return intro elif role == "LG": @@ -38,7 +38,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Loup-garou") intro.add_field(name="Votre personnage : ", value="*Le village de Thiercelieu est victime d’une terrible malédiction. Des loups-garous terrorisent les habitants de cette petite bourgade et dévorent les villageois.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but et de tuer tous les villageois. Chaque nuit, vous décidez, avec les autres loups-garous, de tuer une personne.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but et de tuer tous les villageois. Chaque nuit, vous décidez, avec les autres loups-garous, de tuer une personne.**", inline=False) return intro elif role =="VY": @@ -46,7 +46,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Voyante") intro.add_field(name="Votre personnage : ", value="*Cette personne si secrète pourra-t-elle faire la lumière sur les évènements de Thiercelieu ? Ces dons bizarres pour la voyance lui permettent de connaitre la véritable nature des gens.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous pourrez connaitre le rôle d’une personne.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous pourrez connaitre le rôle d’une personne.**", inline=False) return intro elif role == "VO": @@ -54,7 +54,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Voleur") intro.add_field(name="Votre personnage : ", value="*Qui est donc ce chapardeur qui met la confusion dans la tête des gens ? Il n’est pas méchant, mais des gens disent qu’il manipulerait les autres.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but et de tuer tous les loups-garous. Toutes les deux nuits, vous échangerez les rôles de deux personnes. **", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but et de tuer tous les loups-garous. Toutes les deux nuits, vous échangerez les rôles de deux personnes. **", inline=False) return intro elif role =="SO": @@ -62,7 +62,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Sorcière") intro.add_field(name="Votre personnage : ", value="*Quelle est cette femme qui concocte ses potions en secret, décidant du sort de ses victimes ? On la dit capable de soigner, mais aussi de tuer.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous pouvez soigner ou tuer une personne, ou ne rien faire. Attention, chaque potion ne peut être utilisé qu’une seule fois.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous pouvez soigner ou tuer une personne, ou ne rien faire. Attention, chaque potion ne peut être utilisé qu’une seule fois.**", inline=False) return intro elif role == "CS": @@ -70,7 +70,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Chasseur") intro.add_field(name="Votre personnage : ", value="*Cet homme seul à décider de prendre les armes et de traquer les loups-garous qui terrorisent le village. Qui sait ce que pourrait faire un homme armé au bord de la mort ?*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but et de tuer tous les loups-garous. Si vous êtes tué, vous pourrez tuer une autre personne avant de mourir.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but et de tuer tous les loups-garous. Si vous êtes tué, vous pourrez tuer une autre personne avant de mourir.**", inline=False) return intro elif role == "CU": @@ -78,7 +78,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Cupidon") intro.add_field(name="Votre personnage : ", value="*Qui recevra les flèches de l’amour lancées par ce petit être ? Ceux-ci se voueront un amour pur et total, et dépendrons l’un de l’autre.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. En début de partie, vous rendrez deux personnes amoureuses. Celles-ci seront dépendante l’une de l’autre, et si l’une meurt, l’autre se tuera de chagrin.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. En début de partie, vous rendrez deux personnes amoureuses. Celles-ci seront dépendante l’une de l’autre, et si l’une meurt, l’autre se tuera de chagrin.**", inline=False) return intro elif role == "CL": @@ -86,7 +86,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Chien-loup") intro.add_field(name="Votre personnage : ", value="*Il existe à Thiercelieu une espèce de chien très rares, pouvant adopter des comportements violents. Deviendra-t-il loup-garou, ou restera t-il un chien docile ?*", inline=False) - intro.add_field(name="Votre bute : ", value="**En début de partie vous aurez le choix entre rejoindre les loups-garous ou les villageois.**", inline=False) + intro.add_field(name="Votre but : ", value="**En début de partie vous aurez le choix entre rejoindre les loups-garous ou les villageois.**", inline=False) return intro elif role == "AG": @@ -94,7 +94,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Ange") intro.add_field(name="Votre personnage : ", value="*Ce petit homme volant ce fiche éperdument du sort d’un petit village perdu au fond des landes. Tout ce qu’il veut c’est s’envoler un retrouver le calme des cieux.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but et de gagner la partie seul. Si vous êtes tué par les villageois au premier jour, vous remportez la partie. Sinon, vous devenez simple villageois.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but et de gagner la partie seul. Si vous êtes tué par les villageois au premier jour, vous remportez la partie. Sinon, vous devenez simple villageois.**", inline=False) return intro elif role == "MA": @@ -102,7 +102,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Maire") intro.add_field(name="Votre personnage : ", value="*Tout village, même dans la terreur, a besoin d’un leader en qui avoir confiance.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but et de tuer tous les loups-garous. Votre vote compte double.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but et de tuer tous les loups-garous. Votre vote compte double.**", inline=False) return intro elif role == "IL": @@ -110,7 +110,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Illettré") intro.add_field(name="Votre personnage : ", value="*L’éducation est privilège dont tout le monde devrait avoir accès. Cette personne étrangère ne comprend rien aux paroles des autres habitants. De temps en temps il aime se balader la nuit, il voit des choses étranges, sans savoir ce qu’elles sont.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but et de tuer tous les loups-garous. Chaque nuit, vous percevez des morceaux de la conversation des loups-garous.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but et de tuer tous les loups-garous. Chaque nuit, vous percevez des morceaux de la conversation des loups-garous.**", inline=False) return intro elif role == "IPDL": @@ -118,7 +118,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Infect père des loups") intro.add_field(name="Votre personnage : ", value="*Même les loups-garous ont une famille. Cette famille-là est ancienne est terrible, capable de pervertir le cœur des plus nobles.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les villageois. Une fois par partie, vous pouvez infecter une personne désignée comme victime par les loups-garous. Celle-ci ne sera pas tuée mais deviendra secrètement un loup-garou.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les villageois. Une fois par partie, vous pouvez infecter une personne désignée comme victime par les loups-garous. Celle-ci ne sera pas tuée mais deviendra secrètement un loup-garou.**", inline=False) return intro elif role == "JDF": @@ -126,7 +126,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Joueur de flûte") intro.add_field(name="Votre personnage : ", value="*Cet homme, autrefois banni, et aujourd’hui oublié, revient au village pour se venger. Armé de sa flûte à bec, il prend peu à peu possession du village à qui il souhaite donner une leçon.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de contaminer tous les habitants du village. Chaque nuit, vous contaminez une ou deux personnes.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de contaminer tous les habitants du village. Chaque nuit, vous contaminez une ou deux personnes.**", inline=False) return intro elif role == "RE": @@ -134,7 +134,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Renard") intro.add_field(name="Votre personnage : ", value="*Les loups ne sont pas les seuls animaux à Thiercelieu. Ce renard rusé serait capable de sentir l’âme des gens ainsi que leurs intentions.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous voyez le rôle de trois personnes, mais si aucune d’elles n’est un loup-garou, vous perdez votre pouvoir.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous voyez le rôle de trois personnes, mais si aucune d’elles n’est un loup-garou, vous perdez votre pouvoir.**", inline=False) return intro elif role == "GML": @@ -142,7 +142,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Grand méchant loup") intro.add_field(name="Votre personnage : ", value="*Il n’y a pas que les trois petits cochons qui craignent le grand méchant loup. Celui est encore plus meurtrier est assoiffé de sang que ses semblables.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les villageois. Tant qu’aucun loup-garou n’est mort, vous pouvez tuer une personne supplémentaire par nuit.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les villageois. Tant qu’aucun loup-garou n’est mort, vous pouvez tuer une personne supplémentaire par nuit.**", inline=False) return intro elif role == "LGB": @@ -150,7 +150,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Loup-garou blanc") intro.add_field(name="Votre personnage : ", value="*Il y aurait un traitre dans les rangs des loups-garous. Celui-ci les éliminerait de l’intérieur, un à un.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de finir la partie seul. Toutes les deux nuits, vous pouvez tuer un loup-garou, en plus de la victime de chaque nuit.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de finir la partie seul. Toutes les deux nuits, vous pouvez tuer un loup-garou, en plus de la victime de chaque nuit.**", inline=False) return intro elif role == "SA": @@ -158,7 +158,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Salvateur") intro.add_field(name="Votre personnage : ", value="*A Thiercelieu, ce personnage est devenu une légende. Sa bénédiction permettrait de se protéger des événements récents.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous accordez votre bénédiction à une personne. Celle-ci ne pourra pas être tuée pendant la nuit.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, vous accordez votre bénédiction à une personne. Celle-ci ne pourra pas être tuée pendant la nuit.**", inline=False) return intro elif role == "AS": @@ -166,7 +166,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Assassin") intro.add_field(name="Votre personnage : ", value="*A Thiercelieu, il y a un fou qui n’avait jusque-là jamais été dangereux. Mais les récents évènements ont perturbé sa santé mentale. Depuis, il vit dans une folie meurtrière qui ne peut contrôler.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de finir la partie seul. Chaque matin, vous tuez une personne au hasard.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de finir la partie seul. Chaque matin, vous tuez une personne au hasard.**", inline=False) return intro elif role == "CER": @@ -174,7 +174,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Chevalier à l’épée rouillée") intro.add_field(name="Votre personnage : ", value="*Don Quigrince était un fier chevalier vaillant ayant participé à de nombreuses batailles. Aujourd’hui, le temps et le manque d’action se sont transformés en ennui. Il ne mange plus, dors peu, et ne s’est pas occupé de son épée depuis fort longtemps. Celle-ci s’est émoussée, et pourrait surement empoissonner un loup trop gourmand.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Si vous êtes tué par les loup-garou, celui qui avait proposé votre mort sera tué la nuit suivante.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Si vous êtes tué par les loup-garou, celui qui avait proposé votre mort sera tué la nuit suivante.**", inline=False) return intro elif role == "MO": @@ -182,7 +182,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Montreur d’ours") intro.add_field(name="Votre personnage : ", value="*En plus des loups-garous, il y a un ours qui rode dans les bois de Thiercelieu. Celui-ci est très grincheux, et n’hésitera pas à grogner pour effrayer les loups-garous trop curieux.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, si un loup-garou se trouve à coté de vous, vous grognez.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Chaque nuit, si un loup-garou se trouve à coté de vous, vous grognez.**", inline=False) return intro elif role == "AC": @@ -190,7 +190,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Ancien") intro.add_field(name="Votre personnage : ", value="*L’expérience amène la sagesse. Et la sagesse amène la maitrise de soi. Le doyen du village l’a bien compris. Bien qu’étant d’un âge avancé, il saura s’enfuir face aux loups-garous qui essayeraient de le tuer. Cependant, sa mort démoraliserait tous les villageois.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer les loups-garous. Si vous êtes tué par les loups garous, vous pourrez échanger votre rôle avec une personne au hasard la nuit suivante. Si vous êtes tué une deuxième fois, tous les villageois restants perdrons leurs pouvoirs.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer les loups-garous. Si vous êtes tué par les loups garous, vous pourrez échanger votre rôle avec une personne au hasard la nuit suivante. Si vous êtes tué une deuxième fois, tous les villageois restants perdrons leurs pouvoirs.**", inline=False) return intro elif role == "SE": @@ -198,7 +198,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Sœur") intro.add_field(name="Votre personnage : ", value="*Rien n’est plus beau que la fraternité. Ces deux sœurs sont comme deux doigts d’une même main, ou deux cheveux d’une même mèche. Elles se comprennent sans même se parler.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les villageois. Certaines nuits, vous serez appelés, et pourrait communiquer avec l’autre sœur.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les villageois. Certaines nuits, vous serez appelés, et pourrait communiquer avec l’autre sœur.**", inline=False) return intro elif role == "IDV": @@ -206,7 +206,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Idiot du village") intro.add_field(name="Votre personnage : ", value="*Les villageois ont beau essayer d’en faire quelque chose, il ne comprend rien de rien. Cependant, ils ne pourront jamais lui faire de mal. Même au moment de le tuer, ils décideront de ne rien lui faire, et de ne plus lui parler. Qui écouterait un idiot ?*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Si vous êtes tué par les villageois, vous serez acquitté mais perdrez votre droit de vote.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Si vous êtes tué par les villageois, vous serez acquitté mais perdrez votre droit de vote.**", inline=False) return intro elif role == "ES": @@ -214,7 +214,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Enfant sauvage") intro.add_field(name="Votre personnage : ", value="*Cet enfant est sorti de la forêt un jour, sans prévenir. Il a été élevé par les loups, dans les bois. Cependant, il essaye de s’intégrer dans le village, en prenant un modèle. Qui sait ce qu’il pourrait devenir s’il lui arrivait quelque chose ?*", inline=False) - intro.add_field(name="Votre bute : ", value="**En début de partie, vous choisissez un modèle. Tant que cette personne est en vie, vous restez villageois, mais si elle meurt, vous vous transformez en loup-garou.**", inline=False) + intro.add_field(name="Votre but : ", value="**En début de partie, vous choisissez un modèle. Tant que cette personne est en vie, vous restez villageois, mais si elle meurt, vous vous transformez en loup-garou.**", inline=False) return intro elif role == "BE": @@ -222,7 +222,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Bouc-émissaire") intro.add_field(name="Votre personnage : ", value="*Qu’est-ce que cet homme a bien pu faire pour être autant détester par le village ? En cas de doute, c’est toujours de sa faute.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups-garous. Si les villageois doutent sur qui tuer pendant le vote, vous serez tué par défaut.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups-garous. Si les villageois doutent sur qui tuer pendant le vote, vous serez tué par défaut.**", inline=False) return intro elif role == "KZ": @@ -230,7 +230,7 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Kamikaze") intro.add_field(name="Votre personnage : ", value="*Cet homme au passif si tumultueux n’a plus rien à perdre. Il serait prêt à risquer sa vie pour faire entendre raison aux autres villageois.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups garous. Une fois par partie, vous pouvez à tout moment tuer une autre personne, mais vous mourrez en faisant cela.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups garous. Une fois par partie, vous pouvez à tout moment tuer une autre personne, mais vous mourrez en faisant cela.**", inline=False) return intro elif role == "ISM": @@ -238,23 +238,23 @@ class Garou: intro.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") intro.add_field(name="Vous êtes : ", value="Insomniaque") intro.add_field(name="Votre personnage : ", value="*Les problèmes de sommeil sont terribles. Mais cela permet de savoir tout avant les autres. Impossible de savoir ce qui empêche cette femme de dormir. Peut-être ce qu’elle apprend le matin, à l’aube.*", inline=False) - intro.add_field(name="Votre bute : ", value="**Votre but est de tuer tous les loups –garous. Toutes les nuits, vous saurez le dérouler exact de tout la nuit.**", inline=False) + intro.add_field(name="Votre but : ", value="**Votre but est de tuer tous les loups –garous. Toutes les nuits, vous saurez le dérouler exact de tout la nuit.**", inline=False) return intro - #Erreur de partie deja en cours + #Erreur de partie déjà en cours erreur1=discord.Embed(title="Garou", description="Erreur", color=0xff0000) erreur1.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - erreur1.add_field(name="Imposible", value="Désoler mais une partie est deja en cours !", inline=False) + erreur1.add_field(name="Impossible", value="Désolé mais une partie est déjà en cours !", inline=False) - #Erreur de partie non lancer + #Erreur de partie non lancée erreur2=discord.Embed(title="Garou", description="Erreur", color=0xff0000) erreur2.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - erreur2.add_field(name="Imposible", value="Désoler mais aucune partie en cours !", inline=False) + erreur2.add_field(name="Impossible", value="Désolé mais aucune partie en cours !", inline=False) #Erreur de ne pas étre le GM erreur3=discord.Embed(title="Garou", description="Erreur", color=0xff0000) erreur3.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - erreur3.add_field(name="Imposible", value="Désoler mais vous n'étes pas le GM !", inline=False) + erreur3.add_field(name="Impossible", value="Désolé mais vous n'étes pas le GM !", inline=False) #Pour verifier que la personne donner soit bien un joueur @@ -275,50 +275,50 @@ class Garou: #Commande pour démarre le jeux @lg.command(pass_context=True) async def start(self, ctx): - if self.game == 1: #Verification si une partie est deja lancer - print("Commande lg start lancer par: "+str(ctx.message.author)+" refuser, partie deja lancer") + if self.game == 1: #Verification si une partie est déjà lancée + print("Commande lg start lancée par: "+str(ctx.message.author)+" refusée, partie déjà lancée") await self.bot.say(embed=self.erreur1) else: - if self.djoueurs >= 1: #Verification si les joueurs sont deja defini - print("Commande lg start lancer par: "+str(ctx.message.author)+" refuser, partie deja lancer") + if self.djoueurs >= 1: #Verification si les joueurs sont déjà defini + print("Commande lg start lancée par: "+str(ctx.message.author)+" refusée, partie déjà lancée") await self.bot.say(embed=self.erreur1) else: - print("Commande lg start lancer par: "+str(ctx.message.author)) - self.game=1 #On dit qu'une la partie est lancer + print("Commande lg start lancée par: "+str(ctx.message.author)) + self.game=1 #On dit qu'une la partie est lancée self.gm=ctx.message.author #On defini le GM self.djoueurs = 1 #On dit qu'on defini les joueurs self.list_joueurs.insert(0, ctx.message.author.id) #On ajoute le GM dans la liste de joueurs (ID) self.ult_list_joueurs.insert(0,ctx.message.author) #On ajoute le GM dans la liste de joueurs (Object) embed=discord.Embed(title="Garou", description="Dèmarrage", color=0xff0000) embed.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - embed.add_field(name="Début de partie", value="Une partie a été lancer par: "+str(ctx.message.author)+" ! \nPour rejoindre, taper la commande: ```lg join```", inline=False) + embed.add_field(name="Début de partie", value="Une partie a été lancée par: "+str(ctx.message.author)+" ! \nPour rejoindre, taper la commande: ```lg join```", inline=False) await self.bot.say(embed=embed) #Commande pour rejoindre la partie @lg.command(pass_context=True) async def join(self, ctx): - if self.game == 0: #Verification si une partie est deja lancer - print("Commande lg join lancer par: "+str(ctx.message.author)+" refuser, aucune partie lancer !") + if self.game == 0: #Verification si une partie est déjà lancée + print("Commande lg join lancée par: "+str(ctx.message.author)+" refusée, aucune partie lancée !") await self.bot.say(embed=self.erreur2) else: - if self.djoueurs == 2: #Verification si les joueurs sont deja defini - print("Commande lg join lancer par: "+str(ctx.message.author)+" refuser, joueurs deja defini !") + if self.djoueurs == 2: #Verification si les joueurs sont déjà defini + print("Commande lg join lancée par: "+str(ctx.message.author)+" refusée, joueurs déjà defini !") await self.bot.say(embed=self.erreur1) elif self.djoueurs == 1: #Verification si les joueurs sont en cours de definition if self.gm == ctx.message.author: #Verification si c'est le GM - print("Commande lg join lancer par: "+str(ctx.message.author)+" refuser, c'est le GM !") + print("Commande lg join lancée par: "+str(ctx.message.author)+" refusée, c'est le GM !") embed=discord.Embed(title="Garou", description="Erreur", color=0xff0000) embed.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - embed.add_field(name="Imposible", value="Désoler mais vous êtes le GM, vous avez deja rejoint par defaut.", inline=False) + embed.add_field(name="Impossible", value="Désolé mais vous êtes le GM, vous avez déjà rejoint par defaut.", inline=False) await self.bot.say(embed=embed) else: - print("Commande lg join lancer par: "+str(ctx.message.author)) + print("Commande lg join lancée par: "+str(ctx.message.author)) self.list_joueurs.append(ctx.message.author.id) self.ult_list_joueurs.append(ctx.message.author) embed=discord.Embed(title="Garou", description="Dèmarrage", color=0xff0000) @@ -327,44 +327,44 @@ class Garou: await self.bot.say(embed=embed) - #Commande pour lancer la partie + #Commande pour lancée la partie @lg.command(pass_context=True) async def play(self, ctx): - if self.game == 0: #Verification si une partie est deja lancer - print("Commande lg play lancer par: "+str(ctx.message.author)+" refuser, aucune partie lancer !") + if self.game == 0: #Verification si une partie est déjà lancée + print("Commande lg play lancée par: "+str(ctx.message.author)+" refusée, aucune partie lancée !") await self.bot.say(embed=self.erreur2) else: - if self.djoueurs == 0: #Verification si les joueurs sont deja defini - print("Commande lg play lancer par: "+str(ctx.message.author)+" refuser, definition des joueurs non lancer !") + if self.djoueurs == 0: #Verification si les joueurs sont déjà defini + print("Commande lg play lancée par: "+str(ctx.message.author)+" refusée, definition des joueurs non lancée !") await self.bot.say(embed=self.erreur2) - elif self.djoueurs == 2: #Verification si les joueurs sont deja defini - print("Commande lg play lancer par: "+str(ctx.message.author)+" refuser, joueurs deja defini !") + elif self.djoueurs == 2: #Verification si les joueurs sont déjà defini + print("Commande lg play lancée par: "+str(ctx.message.author)+" refusée, joueurs déjà defini !") await self.bot.say(embed=self.erreur1) elif self.djoueurs == 1: #Verification si les joueurs sont en cours de definition if self.gm == ctx.message.author: #Verification si c'est le GM if len(self.list_joueurs) < self.minijoueurs: #Verification du nombre de joueurs minimal requi - print("Commande lg play lancer par: "+str(ctx.message.author)+", refuser car minimum de joueurs pas atteint") + print("Commande lg play lancée par: "+str(ctx.message.author)+", refusée car minimum de joueurs pas atteint") embed=discord.Embed(title="Garou", description="Erreur", color=0xff0000) embed.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - embed.add_field(name="Imposible", value="Désoler mais il n'y a que "+str(len(self.list_joueurs))+" joueur(s) dans la partie", inline=False) + embed.add_field(name="Impossible", value="Désolé mais il n'y a que "+str(len(self.list_joueurs))+" joueur(s) dans la partie", inline=False) await self.bot.say(embed=embed) else: self.djoueurs=2 #On dit que les joueurs sont defini self.num_joueurs=len(self.list_joueurs) #On defini combien de joueurs en tout - print("Commande lg play lancer par: "+str(ctx.message.author)) + print("Commande lg play lancée par: "+str(ctx.message.author)) #Definition des roles for j in range(0,self.num_joueurs): #Un boucle qui fait autent de fois qu'il y a de joueurs target = self.list_joueurs[j] #Prend dans la liste des joueurs le joueur en question. while self.is_joueurs(target) != True: #Boucle tant que le jouer n'est pas dans la liste des personnes défini r = randint(1,self.num_joueurs) #Tire un chiffre random entre 1 et le nombre de jouers - if r not in self.random: #Si se chiffre a deja éter tiré, alors sela relance le while + if r not in self.random: #Si se chiffre a déjà éter tiré, alors sela relance le while self.def_joueurs[target] = self.roles[r] #Ajoute dans le dico le joueur et assigne son role grace au chiffre random - self.random.append(r) #Ajoute le chiffre random dans la liste des chiffres deja tiré + self.random.append(r) #Ajoute le chiffre random dans la liste des chiffres déjà tiré #Envoie du message de role client = self.ult_list_joueurs[j] #Cible le joueur en question mais cette fois son objet et non son ID @@ -381,19 +381,19 @@ class Garou: else: - print("Commande lg play lancer par: "+str(ctx.message.author)+" refuser, pas le GM !") + print("Commande lg play lancée par: "+str(ctx.message.author)+" refusée, pas le GM !") await self.bot.say(embed=self.erreur3) #Commande pour annuler le Garou @lg.command(pass_context=True) async def stop(self, ctx): if self.game == 0: - print("Commande lg stop lancer par: "+str(ctx.message.author)+" refuser, aucune partie lancer !") + print("Commande lg stop lancée par: "+str(ctx.message.author)+" refusée, aucune partie lancée !") await self.bot.say(embed=self.erreur2) elif self.game == 1: if self.gm == ctx.message.author: - print("Commande lg stop lancer par: "+str(ctx.message.author)) + print("Commande lg stop lancée par: "+str(ctx.message.author)) #reset de toutes les variables game = 0 @@ -407,11 +407,11 @@ class Garou: embed=discord.Embed(title="Garou", description="Attention", color=0xff0000) embed.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") - embed.add_field(name="Partie annuler", value="Désoler mais la partie de Garou a éter annuler.", inline=False) + embed.add_field(name="Partie annuler", value="Désolé mais la partie de Garou a éter annuler.", inline=False) await self.bot.say(embed=embed) else: - print("Commande lg stop lancer par: "+str(ctx.message.author)+" refuser car ce n'est pas le GM !") + print("Commande lg stop lancée par: "+str(ctx.message.author)+" refusée car ce n'est pas le GM !") await self.bot.say(embed=self.erreur3) #Commande help @@ -420,11 +420,11 @@ class Garou: embed=discord.Embed(title="Garou", description="Aide", color=0xff0000) embed.set_thumbnail(url="https://i.imgur.com/XLPDenM.png") embed.add_field(name="start", value="Lancement de la partie", inline=True) - embed.add_field(name="join", value="Rejoidre la partie", inline=True) - embed.add_field(name="play", value="Demarre la partie", inline=True) + embed.add_field(name="join", value="Rejoindre la partie", inline=True) + embed.add_field(name="play", value="Démarre la partie", inline=True) embed.add_field(name="stop", value="Termine la partie", inline=True) await self.bot.say(embed=embed) def setup(bot): bot.add_cog(Garou(bot)) - print("Garou charger") + print("Garou chargé") diff --git a/Music.py b/Music.py index 30bb571..e9db13d 100644 --- a/Music.py +++ b/Music.py @@ -60,17 +60,17 @@ class VoiceState: while True: self.play_next_song.clear() self.current = await self.songs.get() - print("Musi en cours lancer: "+str(self.current)) + print("Musique en cours lancée: "+str(self.current)) #await self.bot.change_presence(game=discord.Game(name='faire de la musique: '+str(self.current))) - embed=discord.Embed(title="Music", description="En cours", color=0x80ff00) + embed=discord.Embed(title="Musique", description="En cours", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") - embed.add_field(name="play", value="Joue maintenant \n" + str(self.current), inline=True) + embed.add_field(name="play", value="Jouée acutellement: \n" + str(self.current), inline=True) await self.bot.send_message(self.current.channel, embed=embed) self.current.player.start() await self.play_next_song.wait() -class Music: +class Musique: """Commandes de musique. """ def __init__(self, bot): @@ -124,16 +124,16 @@ class Music: #Un simple help @music.command(pass_context=True, no_pm=True) async def help(self, ctx): - embed=discord.Embed(title="Music", description="Aide", color=0x80ff00) + embed=discord.Embed(title="Musique", description="Aide", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="play", value="Lancer une musique", inline=True) - embed.add_field(name="playing", value="Voir se qui passe", inline=True) - embed.add_field(name="pause", value="Met en pause la musique, ne marche pas", inline=True) - embed.add_field(name="resume", value="Continue la musique", inline=True) + embed.add_field(name="playing", value="Voir quelle musique est lancée", inline=True) + embed.add_field(name="pause", value="Met en pause la musique", inline=True) + embed.add_field(name="resume", value="Résume la musique", inline=True) embed.add_field(name="skip", value="Passer la musique", inline=True) - embed.add_field(name="stop", value="Arreter la musique", inline=True) - embed.add_field(name="summon", value="Faire apparaitre le bot", inline=True) - embed.add_field(name="volume", value="Definir le volume de la musique", inline=True) + embed.add_field(name="stop", value="Arrêter la musique", inline=True) + embed.add_field(name="summon", value="Faire apparaître le bot", inline=True) + embed.add_field(name="volume", value="Définir le volume de la musique", inline=True) await self.bot.say(embed=embed) #Permmet de faire connecter vocalement le bot @@ -143,25 +143,25 @@ class Music: Ne fonctionne que si l'utilisateur est déja dans un channel.""" summoned_channel = ctx.message.author.voice_channel if summoned_channel is None: - print("Commande music summon lancer par: "+str(ctx.message.author)+" refuser car il n'est pas dans un channel vocal") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique summon lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans un channel vocal") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") - embed.add_field(name="summon", value="Vous n'étes pas dans un channel vocal !", inline=True) + embed.add_field(name="summon", value="Vous n'êtes pas dans un channel vocal !", inline=True) await self.bot.say(embed=embed) return False state = self.get_voice_state(ctx.message.server) if state.voice is None: - print("Commande music summon lancer par: "+str(ctx.message.author)) + print("Commande musique summon lancée par: "+str(ctx.message.author)) state.voice = await self.bot.join_voice_channel(summoned_channel) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") - embed.add_field(name="summon", value="Il se materialise a vous !", inline=True) + embed.add_field(name="summon", value="Il se matérialise devant vous !", inline=True) await self.bot.say(embed=embed) else: - print("Commande music summon lancer par: "+str(ctx.message.author)) + print("Commande music summon lancée par: "+str(ctx.message.author)) await state.voice.move_to(summoned_channel) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="summon", value="Il se téléporte a vous !", inline=True) await self.bot.say(embed=embed) @@ -172,7 +172,7 @@ class Music: @music.command(pass_context=True, no_pm=True) async def play(self, ctx, *, song : str): """Joue une musique. - S'il y a une musique qui joue deja, alors elle est mise dans + S'il y a une musique qui joue déjà, alors elle est mise dans la queue jusqu'a la derniere musique de la queue. Le bot recherche automatiquement sur youtube. La liste des sites supportés est trouvée ici: @@ -187,8 +187,8 @@ class Music: if state.voice is None: success = await ctx.invoke(self.summon) - print("Commande music play lancer par: "+str(ctx.message.author)) - #embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique play lancée par: "+str(ctx.message.author)) + #embed=discord.Embed(title="Musique", description="", color=0x80ff00) #embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") #embed.add_field(name="play", value="Chargement de la musique...", inline=True) message = await self.bot.say("Chargement de la musique...") @@ -202,16 +202,16 @@ class Music: except Exception as e: fmt = 'Une erreur est arrivé lors du traitement de la requete: ```py\n{}: {}\n```' - print("Commande music play lancer par: "+str(ctx.message.author)+" erreur: "+fmt.format(type(e).__name__, e)) - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique play lancée par: "+str(ctx.message.author)+" erreur: "+fmt.format(type(e).__name__, e)) + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="play", value=fmt.format(type(e).__name__, e), inline=True) await self.bot.send_message(ctx.message.channel, embed=embed) else: player.volume = 0.6 entry = VoiceEntry(ctx.message, player) - print("Commande music play lancer par: "+str(ctx.message.author)+" mise en queue") - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique play lancée par: "+str(ctx.message.author)+" mise en queue") + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="play", value="La musique \n" + str(entry)+" \na été mise en queue", inline=True) await self.bot.say(embed=embed) @@ -227,15 +227,15 @@ class Music: if state.is_playing(): player = state.player player.volume = value / 100 - print("Commande music volume lancer par: "+str(ctx.message.author)) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande music volume lancée par: "+str(ctx.message.author)) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="volume", value='Volume mit à {:.0%}'.format(player.volume), inline=True) await self.bot.say(embed=embed) elif self.is_listening(voice_channel_id) == False: - print("Commande music volume lancer par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande music volume lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="volume", value="Vous n'étes pas dans le channel vocal !", inline=True) await self.bot.say(embed=embed) @@ -247,16 +247,16 @@ class Music: if self.is_listening(voice_channel_id) == True: state = self.get_voice_state(ctx.message.server) if state.is_playing(): - print("Commande music pause lancer par: "+str(ctx.message.author)) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique pause lancée par: "+str(ctx.message.author)) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="pause", value="Mis ene pause de la musique", inline=True) await self.bot.say(embed=embed) await self.set_pause(ctx.message.author.server) elif self.is_listening(voice_channel_id) == False: - print("Commande music resume lancer par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique resume lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="resume", value="Vous n'étes pas dans le channel vocal !", inline=True) await self.bot.say(embed=embed) @@ -269,16 +269,16 @@ class Music: if self.is_listening(voice_channel_id) == True: state = self.get_voice_state(ctx.message.server) if state.is_playing(): - print("Commande music resume lancer par: "+str(ctx.message.author)) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique resume lancée par: "+str(ctx.message.author)) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="resume", value="Reprise de la musique", inline=True) await self.bot.say(embed=embed) await self.set_resume(ctx.message.author.server) elif self.is_listening(voice_channel_id) == False: - print("Commande music resume lancer par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique resume lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="resume", value="Vous n'étes pas dans le channel vocal !", inline=True) await self.bot.say(embed=embed) @@ -315,8 +315,8 @@ class Music: state.audio_player.cancel() del self.voice_states[server.id] await state.voice.disconnect() - print("Commande music stop lancer par: "+str(ctx.message.author)) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique stop lancée par: "+str(ctx.message.author)) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="stop", value="Queue vidée et channel quitté.", inline=True) await self.bot.say(embed=embed) @@ -324,8 +324,8 @@ class Music: pass elif self.is_listening(voice_channel_id) == False: - print("Commande music stop lancer par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique stop lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="stop", value="Vous n'étes pas dans le channel vocal !", inline=True) await self.bot.say(embed=embed) @@ -340,8 +340,8 @@ class Music: if self.is_listening(voice_channel_id) == True: state = self.get_voice_state(ctx.message.server) if not state.is_playing(): - print("Commande music skip lancer par: "+str(ctx.message.author)+" refuser car rien est jouer") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique skip lancée par: "+str(ctx.message.author)+" refuser car rien est jouer") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="skip", value="Aucune chanson n'est jouée actuellement...", inline=True) await self.bot.say(embed=embed) @@ -349,8 +349,8 @@ class Music: voter = ctx.message.author if voter == state.current.requester: - print("Commande music skip lancer par: "+str(ctx.message.author)+" requete envoyer") - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique skip lancée par: "+str(ctx.message.author)+" requete envoyer") + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="skip", value="Une requete pour passer la chanson a été faite.", inline=True) await self.bot.say(embed=embed) @@ -359,49 +359,49 @@ class Music: state.skip_votes.add(voter.id) total_votes = len(state.skip_votes) if total_votes >= 3: - print("Commande music skip lancer") - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique skip lancée") + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="skip", value="Vote pour passer effectué, chanson passée...", inline=True) await self.bot.say(embed=embed) state.skip() else: - embed=discord.Embed(title="Music", description="", color=0x80ff00) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="skip", value="Vote pour passer effectué, actuellement à [{}/3]".format(total_votes), inline=True) await self.bot.say(embed=embed) else: - embed=discord.Embed(title="Music", description="", color=0x80ff00) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") - embed.add_field(name="skip", value="Vous avez deja voté pour passer cette chanson.", inline=True) + embed.add_field(name="skip", value="Vous avez déjà voté pour passer cette chanson.", inline=True) await self.bot.say(embed=embed) elif self.is_listening(voice_channel_id) == False: - print("Commande music skip lancer par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique skip lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans le channel vocal") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="skip", value="Vous n'étes pas dans le channel vocal !", inline=True) await self.bot.say(embed=embed) - #Affiche la musique actuellement lancer + #Affiche la musique actuellement lancée @music.command(pass_context=True, no_pm=True) async def playing(self, ctx): state = self.get_voice_state(ctx.message.server) if state.current is None: - print("Commande music playing lancer par: "+str(ctx.message.author)+" refuser car rien est jouer") - embed=discord.Embed(title="Music", description="Erreur", color=0x80ff00) + print("Commande musique playing lancée par: "+str(ctx.message.author)+" refuser car rien est jouer") + embed=discord.Embed(title="Musique", description="Erreur", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") embed.add_field(name="playing", value="Aucune chanson n'est jouée actuellement...", inline=True) await self.bot.say(embed=embed) else: skip_count = len(state.skip_votes) - print("Commande music playing lancer par: "+str(ctx.message.author)) - embed=discord.Embed(title="Music", description="", color=0x80ff00) + print("Commande musique playing lancée par: "+str(ctx.message.author)) + embed=discord.Embed(title="Musique", description="", color=0x80ff00) embed.set_thumbnail(url="http://www.icone-png.com/png/16/15638.png") - embed.add_field(name="playing", value="Joue actuellement {} [skips: {}/3]".format(state.current, skip_count), inline=True) + embed.add_field(name="playing", value="Jouée actuellement {} [skips: {}/3]".format(state.current, skip_count), inline=True) await self.bot.say(embed=embed) def setup(bot): - bot.add_cog(Music(bot)) - print('Music charger') + bot.add_cog(Musique(bot)) + print('Musique chargée') diff --git a/README.md b/README.md index c069fbf..1a8673f 100644 --- a/README.md +++ b/README.md @@ -1,13 +1,13 @@ ## Bienvenue sur le GitHub du FTW's Bot -Ce bot est celui lier au serveur Discord FTW (https://discord.gg/PtvK2ym). +Ce bot est celui lié au serveur Discord FTW (https://discord.gg/PtvK2ym). -Le bot token mit sur les pages est un exemple non fonctionelle ;) +Le bot token mit sur les pages est un example non fonctionel ;) ### Mais pourquoi mettre ce bot sur GitHub ? -Simplement pour qu'entre dev on travaille plus facillement et aussi que pour les membres du FTW puisse siganler des problems ou demander des nouveauté. +Simplement pour qu'entres devs on puisse travailler plus facilement et aussi que pour les membres de FTW puisse signaler des problèmes ou demander des nouveautés. ### Il faut quoi ? -Du côter python (avec pip) : Discord (obviouse), PyNaCl et youtube_dl -Du côter géneral : ffmpeg +Du côté python (avec pip) : Discord.py (forcément), PyNaCl et youtube_dl +Du côté géneral : ffmpeg \ No newline at end of file diff --git a/Reactionner.py b/Reactionner.py index 407b785..6dca839 100644 --- a/Reactionner.py +++ b/Reactionner.py @@ -1,67 +1,67 @@ -import discord -from discord.ext import commands - -licorne_symbole = "🦄" -licorne = ["licorne", "pony"] - -caca_symbole = "💩" -caca = ["caca", "merde"] - -sel_symbole = ":PJSalt:232086190545829888" -sel = ["sel", "salty", "putain"] - -troll_symbole = ":troll:232080409083641856" -troll = ["troll", "trol", "trololo"] - -dog_symbole = "🐶" -dog = ["waf", "chien", "dog"] - -perfect_symbole = "👌" -perfect = ["parfait", "perfect", "ok"] - -plus_symbole = ":plus:283940426053058561" -plus = ["+1"] - -class Reactionner: - def __init__(self, bot): - self.bot = bot - - async def on_message(self, message): - for i in range(len(licorne)): - if licorne[i] in message.content.lower(): - print("licorne detecter !") - await self.bot.add_reaction(message,licorne_symbole) - - for i in range(len(caca)): - if caca[i] in message.content.lower(): - print("caca detecter !") - await self.bot.add_reaction(message,caca_symbole ) - - for i in range(len(sel)): - if sel[i] in message.content.lower(): - print("sel detecter !") - await self.bot.add_reaction(message,sel_symbole) - - for i in range(len(troll)): - if troll[i] in message.content.lower(): - print("troll detecter !") - await self.bot.add_reaction(message,troll_symbole) - - for i in range(len(dog)): - if dog[i] in message.content.lower(): - print("Chien detecter !") - await self.bot.add_reaction(message,dog_symbole) - - for i in range(len(perfect)): - if perfect[i] in message.content.lower(): - print("Perfection detecter !") - await self.bot.add_reaction(message,perfect_symbole) - - for i in range(len(plus)): - if plus[i] in message.content.lower(): - print("Plus detecter !") - await self.bot.add_reaction(message,plus_symbole) - -def setup(bot): - bot.add_cog(Reactionner(bot)) - print("Reactionner charger") +import discord +from discord.ext import commands + +licorne_symbole = "🦄" +licorne = ["licorne", "pony", "poney"] + +caca_symbole = "💩" +caca = ["caca", "merde", "crotte", "bouse"] + +sel_symbole = ":PJSalt:232086190545829888" +sel = ["sel", "salty", "putain"] + +troll_symbole = ":troll:232080409083641856" +troll = ["troll", "trol", "trololo"] + +dog_symbole = "🐶" +dog = ["waf", "ouaf", "chien", "dog", "wouaf"] + +perfect_symbole = "👌" +perfect = ["parfait", "perfect", "ok"] + +plus_symbole = ":plus:283940426053058561" +plus = ["+1"] + +class Reactionner: + def __init__(self, bot): + self.bot = bot + + async def on_message(self, message): + for i in range(len(licorne)): + if licorne[i] in message.content.lower(): + print("Licorne detectée !") + await self.bot.add_reaction(message,licorne_symbole) + + for i in range(len(caca)): + if caca[i] in message.content.lower(): + print("Caca detecté !") + await self.bot.add_reaction(message,caca_symbole ) + + for i in range(len(sel)): + if sel[i] in message.content.lower(): + print("Sel detecté !") + await self.bot.add_reaction(message,sel_symbole) + + for i in range(len(troll)): + if troll[i] in message.content.lower(): + print("Troll detecté !") + await self.bot.add_reaction(message,troll_symbole) + + for i in range(len(dog)): + if dog[i] in message.content.lower(): + print("Chien detecté !") + await self.bot.add_reaction(message,dog_symbole) + + for i in range(len(perfect)): + if perfect[i] in message.content.lower(): + print("Perfection detecté !") + await self.bot.add_reaction(message,perfect_symbole) + + for i in range(len(plus)): + if plus[i] in message.content.lower(): + print("Plus detecté !") + await self.bot.add_reaction(message,plus_symbole) + +def setup(bot): + bot.add_cog(Reactionner(bot)) + print("Reactions chargé") diff --git a/bot.py b/bot.py index 5f0621e..b8b8429 100644 --- a/bot.py +++ b/bot.py @@ -1,54 +1,54 @@ -import json -import discord -from discord.ext import commands - - -with open('config.json') as json_data_file: - parameter = json.load(json_data_file) - -bot = commands.Bot(command_prefix=parameter['Bot']['prefix'], description=parameter['Bot']['description']) -bot.remove_command("help") - - -#Démarrage -@bot.event -async def on_ready(): - print("Définition du statu de base") - await bot.change_presence(game=discord.Game(name=parameter['Bot']['statu'])) - - print("Démarrage de DefaultCMD") - bot.load_extension("DefaultCMD") - - print("Démarrage de Administration") - bot.load_extension("Administration") - - print("Démarrage de Benne_a_ordure") - bot.load_extension("Benne_a_ordure") - - print("Démarrage de Reactionner") - bot.load_extension("Reactionner") - - print("Démarrage de Garou") - bot.load_extension("Garou") - - print("Démarrage de Music") - bot.load_extension("Music") - - print("FTW's Bot operationelle") - embed=discord.Embed(title="Administration", description="", color=0xffff00) - embed.set_thumbnail(url="https://icon-icons.com/icons2/562/PNG/512/on-off-power-button_icon-icons.com_53938.png") - embed.add_field(name="Démarrage", value="FTW's Bot operationelle", inline=False) - channel = bot.get_channel("389209382388498445") - await bot.send_message(channel, embed=embed) - -@bot.command(pass_context=True) -async def help(ctx): - embed=discord.Embed(title="Music", description="Aide", color=0x80ff00) - embed.set_thumbnail(url="https://cdn4.iconfinder.com/data/icons/ionicons/512/icon-help-128.png") - embed.add_field(name="basic", value="Pour voir les commands basique faite: ```basic```", inline=True) - embed.add_field(name="Garou", value="Pour voir les commands du Garou faite: ```lg help```", inline=True) - embed.add_field(name="Music", value="Pour voir les commandes pour la musique faite: ```music help```", inline=True) - await bot.say(embed=embed) - - -bot.run(parameter['Bot']['token']) +import json +import discord +from discord.ext import commands + + +with open('config.json') as json_data_file: + parameter = json.load(json_data_file) + +bot = commands.Bot(command_prefix=parameter['Bot']['prefix'], description=parameter['Bot']['description']) +bot.remove_command("help") + + +#Démarrage +@bot.event +async def on_ready(): + print("Définition du statut de base") + await bot.change_presence(game=discord.Game(name=parameter['Bot']['statu'])) + + print("Démarrage de DefaultCMD") + bot.load_extension("DefaultCMD") + + print("Démarrage de Administration") + bot.load_extension("Administration") + + print("Démarrage de Benne_a_ordure") + bot.load_extension("Benne_a_ordure") + + print("Démarrage de Reactionner") + bot.load_extension("Reactionner") + + print("Démarrage de Garou") + bot.load_extension("Garou") + + print("Démarrage de Music") + bot.load_extension("Music") + + print("FTW's Bot opérationel") + embed=discord.Embed(title="Administration", description="", color=0xffff00) + embed.set_thumbnail(url="https://icon-icons.com/icons2/562/PNG/512/on-off-power-button_icon-icons.com_53938.png") + embed.add_field(name="Démarrage", value="FTW's Bot opérationel", inline=False) + channel = bot.get_channel("389209382388498445") + await bot.send_message(channel, embed=embed) + +@bot.command(pass_context=True) +async def help(ctx): + embed=discord.Embed(title="Music", description="Aide", color=0x80ff00) + embed.set_thumbnail(url="https://cdn4.iconfinder.com/data/icons/ionicons/512/icon-help-128.png") + embed.add_field(name="Bases", value="Pour voir les commandes basiques, écrivez: ```basic```", inline=True) + embed.add_field(name="Garou", value="Pour voir les commandes du Garou, écrivez: ```lg help```", inline=True) + embed.add_field(name="Music", value="Pour voir les commandes pour la musique, écrivez: ```music help```", inline=True) + await bot.say(embed=embed) + + +bot.run(parameter['Bot']['token']) diff --git a/default_config.json b/default_config.json index 4817e51..1da2674 100644 --- a/default_config.json +++ b/default_config.json @@ -1,8 +1,13 @@ { "Bot" : { - "name": "Bot Name", - "description": "A simple description", - "prefix": "What wille summon the bot ?", - "token": "They login Token" + "name": "FTW - Bot", + "description": "[Description du bot]", + "prefix": "<@[id du bot]> ", + "token": "[Tocken du bot]", + "statu": "[Statut du bot par défaut]" + }, + "Perms" : { + "Admin": ["[Admin 1]", "[Admin 2]", "[etc...]"] } } + diff --git a/run.sh b/run.sh new file mode 100644 index 0000000..1e6177a --- /dev/null +++ b/run.sh @@ -0,0 +1,12 @@ +printf "Démarrage du FTW-Bot.\n" +printf "\nMise a jour des dépendance...\n" +if [ "$EUID" -ne 0 ] + then echo "Pour que le bot fonctionne correctement, merci de le lancer en root !" + exit +fi + python3.6 -m pip install --upgrade Discord + python3.6 -m pip install --upgrade PyNaCl + python3.6 -m pip install --upgrade youtube_dl + printf "\nMise a jour terminer !\n" + printf "\nLancement du FTW-Bot...\n" + python3.6 bot.py \ No newline at end of file