commit
b115dc2202
5 changed files with 231 additions and 61 deletions
141
Channeller.py
Normal file
141
Channeller.py
Normal file
|
@ -0,0 +1,141 @@
|
|||
import json
|
||||
import discord
|
||||
from discord.ext import commands
|
||||
|
||||
class Channeller:
|
||||
def __init__(self, bot):
|
||||
self.bot = bot
|
||||
with open('config.json') as json_data_file:
|
||||
parameter = json.load(json_data_file)
|
||||
|
||||
self.owner = parameter['Perms']['Admin']
|
||||
|
||||
self.server = self.bot.get_server("177396472294277120")
|
||||
self.ow_role = discord.utils.get(self.server.roles, name="🔫 Overwatch")
|
||||
|
||||
ow_chan = dict()
|
||||
pv_chan = dict()
|
||||
|
||||
"""await def __unload(self):
|
||||
print("Channeller off")
|
||||
for c in self.ow_chan.values():
|
||||
await self.bot.delete_channel(c)"""
|
||||
|
||||
def is_owner(self, id):
|
||||
if id in self.owner:
|
||||
return True
|
||||
return False
|
||||
|
||||
#Groupe de commande du Channeller
|
||||
@commands.group(pass_context=True)
|
||||
async def channeller(self, ctx):
|
||||
if ctx.invoked_subcommand is None:
|
||||
await ctx.invoke(self.help)
|
||||
|
||||
#Le help
|
||||
@channeller.command(pass_context=True)
|
||||
async def help(self, ctx):
|
||||
embed=discord.Embed(title="Channeller", description="Aide", color=0xff0000)
|
||||
embed.set_thumbnail(url="https://i.imgur.com/F7M1e6s.png")
|
||||
embed.add_field(name="jeux", value="Crée un channel vocal pour jouer !", inline=True)
|
||||
embed.add_field(name="private", value="Crée un channel vocal privée", inline=True)
|
||||
embed.add_field(name="publique", value="Crée un channel vocal publique", inline=True)
|
||||
await self.bot.say(embed=embed)
|
||||
|
||||
#Crée un Channel jeux
|
||||
@channeller.command(pass_context=True)
|
||||
async def jeux(self, ctx, jeux):
|
||||
|
||||
help=discord.Embed(title="Channeller jeux", description="Aide", color=0xff0000)
|
||||
help.set_thumbnail(url="https://i.imgur.com/F7M1e6s.png")
|
||||
help.add_field(name="overwatch", value="Crée un channel vocal pour jouer !", inline=True)
|
||||
help.add_field(name="fortinte", value="Crée un channel vocal privée", inline=True) #TODO: Changer "fortninte",et mettre fortnite
|
||||
help.add_field(name="factorio", value="Crée un channel vocal publique", inline=True)
|
||||
help.add_field(name="minecraft", value="Crée un channel", inline=True)
|
||||
help.add_field(name="minecrafticka", value="Crée un channel vocal", inline=True)
|
||||
|
||||
if jeux == "list":
|
||||
await self.bot.say(embed=help)
|
||||
|
||||
elif jeux == None:
|
||||
await self.bot.say(embed=help)
|
||||
|
||||
elif jeux == "overwatch":
|
||||
if self.ow_role in ctx.message.author.roles:
|
||||
everyone_perms = discord.PermissionOverwrite(connect=False)
|
||||
ow_perms = discord.PermissionOverwrite(connect=True)
|
||||
|
||||
everyone = discord.ChannelPermissions(target=self.server.default_role, overwrite=everyone_perms)
|
||||
ow = discord.ChannelPermissions(target=self.ow_role, overwrite=ow_perms)
|
||||
|
||||
name = "Overwatch "+str(len(self.ow_chan)+1)
|
||||
self.ow_chan[name] = await self.bot.create_channel(self.server, name, everyone, ow, type=discord.ChannelType.voice)
|
||||
embed=discord.Embed(title="Channeller jeux", description="Info", color=0xff0000)
|
||||
embed.set_thumbnail(url="https://i.imgur.com/F7M1e6s.png")
|
||||
embed.add_field(name="jeux overwatch", value="Channel créé ! Déplacement automatique...", inline=True)
|
||||
await self.bot.say(embed=embed)
|
||||
print("Channel "+str(name)+" créé par: "+str(ctx.message.author))
|
||||
await self.bot.move_member(ctx.message.author, self.ow_chan[name])
|
||||
|
||||
else:
|
||||
await self.bot.say("No")
|
||||
embed=discord.Embed(title="Channeller jeux", description="Erreur", color=0xff0000)
|
||||
embed.set_thumbnail(url="https://i.imgur.com/F7M1e6s.png")
|
||||
embed.add_field(name="jeux overwatch", value="Désolé mais vous n'avez pas le grade du jeu corespondant !", inline=True)
|
||||
await self.bot.say(embed=embed)
|
||||
print("Refus de création d'un channel Overwatch, "+str(ctx.message.author)+" ne possède pas le grade")
|
||||
|
||||
else:
|
||||
await self.bot.say(embed=help)
|
||||
|
||||
@channeller.command(pass_context=True)
|
||||
async def private(self, ctx, nom, perso):
|
||||
|
||||
if nom in self.pv_chan.values():
|
||||
print("nom deja existant !")
|
||||
|
||||
else:
|
||||
everyone_perms = discord.PermissionOverwrite(connect=False)
|
||||
pv_perms = discord.PermissionOverwrite(connect=True)
|
||||
|
||||
everyone = discord.ChannelPermissions(target=self.server.default_role, overwrite=everyone_perms)
|
||||
pv = discord.ChannelPermissions(target=ctx.message.author, overwrite=pv_perms)
|
||||
|
||||
self.pv_chan[nom] = await self.bot.create_channel(self.server, nom, everyone, pv, type=discord.ChannelType.voice)
|
||||
|
||||
"""for player in perso:
|
||||
test"""
|
||||
print(perso)
|
||||
|
||||
embed=discord.Embed(title="Channeller priver", description="Info", color=0xff0000)
|
||||
embed.set_thumbnail(url="https://i.imgur.com/F7M1e6s.png")
|
||||
embed.add_field(name="Priver", value="Channel créé ! Déplacement automatique...", inline=True)
|
||||
await self.bot.say(embed=embed)
|
||||
print("Channel "+str(nom)+" créé par: "+str(ctx.message.author))
|
||||
await self.bot.move_member(ctx.message.author, self.pv_chan[nom])
|
||||
|
||||
"""@channeller.command(pass_contexte=True)
|
||||
async def delete(self):
|
||||
for n in range(0, self.ow_num):
|
||||
await self.bot.delete_channel(self.ow_chan["ow_"+str(n+1)])
|
||||
self.ow_chan = dict()"""
|
||||
|
||||
async def on_voice_state_update(self, x, y):
|
||||
#OW clear
|
||||
for c in self.ow_chan.values():
|
||||
self.ow_chan[str(c)] = self.bot.get_channel(c.id)
|
||||
if len(self.ow_chan[str(c)].voice_members) == 0:
|
||||
await self.bot.delete_channel(c)
|
||||
del self.ow_chan[str(c)]
|
||||
|
||||
#PV clear
|
||||
for c in self.pv_chan.values():
|
||||
self.pv_chan[str(c)] = self.bot.get_channel(c.id)
|
||||
if len(self.pv_chan[str(c)].voice_members) == 0:
|
||||
await self.bot.delete_channel(c)
|
||||
del self.pv_chan[str(c)]
|
||||
|
||||
|
||||
def setup(bot):
|
||||
bot.add_cog(Channeller(bot))
|
||||
print("Channeller chargé")
|
32
Garou.py
32
Garou.py
|
@ -3,7 +3,6 @@ import discord
|
|||
import random
|
||||
from random import randint
|
||||
from discord.ext import commands
|
||||
#from threading import Thread
|
||||
|
||||
|
||||
class Garou:
|
||||
|
@ -16,12 +15,13 @@ class Garou:
|
|||
|
||||
self.owner = self.parameter['Perms']['Admin']
|
||||
|
||||
#Truc utile
|
||||
self.server = self.bot.get_server("177396472294277120")
|
||||
self.garou_role = discord.utils.get(self.server.roles, name="Garou")
|
||||
self.mort_role = discord.utils.get(self.server.roles, name="Morts")
|
||||
self.server = self.bot.get_server("177396472294277120") #On defini le serveur
|
||||
|
||||
#Get des channels.
|
||||
#Get des roles :
|
||||
self.garou_role = discord.utils.get(self.server.roles, name="🐺 Garou")
|
||||
self.mort_role = discord.utils.get(self.server.roles, name="☠️ Morts")
|
||||
|
||||
#Get des channels :
|
||||
self.forum_channel = self.bot.get_channel("402067902469242900")
|
||||
self.Garou_channel = self.bot.get_channel("403500093380100106")
|
||||
self.soeur_channel = self.bot.get_channel("403518380017057792")
|
||||
|
@ -62,6 +62,9 @@ class Garou:
|
|||
self.perms_jour_soeur.send_messages = False
|
||||
self.perms_jour_soeur.read_messages = True
|
||||
|
||||
"""async def __unload(self):
|
||||
await self.end()"""
|
||||
|
||||
|
||||
#Variables de base
|
||||
game = 0 #Dit si une partie est en cours et a quelle stade elle en est
|
||||
|
@ -534,10 +537,17 @@ class Garou:
|
|||
loup=discord.Embed(title="Garou", description="Nuit", color=0xff0000)
|
||||
loup.set_thumbnail(url="https://i.imgur.com/XLPDenM.png")
|
||||
loup.add_field(name="Vote", value="Les votes sont ouvert pour chosir qui tuer ce soir !", inline=False)
|
||||
loup.add_field(name="Victime", value="")
|
||||
|
||||
|
||||
self.LG = 1
|
||||
|
||||
elif self.LG == 2:
|
||||
print("Fin du vote des Loups-Garou")
|
||||
loup=discord.Embed(title="Garou", description="Nuit", color=0xff0000)
|
||||
loup.set_thumbnail(url="https://i.imgur.com/XLPDenM.png")
|
||||
loup.add_field(name="Vote", value="Les votes sont fini !", inline=False)
|
||||
loup.add_field(name="Vote", value="Vous avez choisi "+str(self.LG_victime)+" !", inline=False)
|
||||
|
||||
self.LG = 3
|
||||
return None
|
||||
|
||||
if "GML" in self.def_joueurs.values():
|
||||
|
@ -887,11 +897,11 @@ class Garou:
|
|||
|
||||
elif r == "LG":
|
||||
if self.LG == 1:
|
||||
#Vote des loup Garous
|
||||
print("Vote des loups-garou")
|
||||
|
||||
#Faut faire le system de vote et aprés cela
|
||||
#self.LG = 2
|
||||
if valuraupif == True:
|
||||
self.LG = 2
|
||||
await self.night_start()
|
||||
|
||||
|
||||
elif r == "VY":
|
||||
|
|
63
Music.py
63
Music.py
|
@ -71,8 +71,8 @@ class VoiceState:
|
|||
|
||||
|
||||
class Musique:
|
||||
"""Commandes de musique.
|
||||
"""
|
||||
#Commandes de musique.
|
||||
|
||||
def __init__(self, bot):
|
||||
self.bot = bot
|
||||
self.voice_states = {}
|
||||
|
@ -133,14 +133,14 @@ class Musique:
|
|||
embed.add_field(name="skip", value="Passer 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)
|
||||
#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
|
||||
@music.command(pass_context=True, no_pm=True)
|
||||
async def summon(self, ctx):
|
||||
"""Invoque le bot dans le channel vocal.
|
||||
Ne fonctionne que si l'utilisateur est déja dans un channel."""
|
||||
#Invoque le bot dans le channel vocal.
|
||||
#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 musique summon lancée par: "+str(ctx.message.author)+" refuser car il n'est pas dans un channel vocal")
|
||||
|
@ -171,13 +171,12 @@ class Musique:
|
|||
#Permet de mettre a jouer une musique
|
||||
@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 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:
|
||||
https://rg3.github.io/youtube-dl/supportedsites.html
|
||||
"""
|
||||
#Joue une musique.
|
||||
#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:
|
||||
#https://rg3.github.io/youtube-dl/supportedsites.html
|
||||
state = self.get_voice_state(ctx.message.server)
|
||||
opts = {
|
||||
"format":"bestaudio/worstvideo",
|
||||
|
@ -218,9 +217,9 @@ class Musique:
|
|||
await state.songs.put(entry)
|
||||
|
||||
#Permmet de definit le volume
|
||||
@music.command(pass_context=True, no_pm=True)
|
||||
"""@music.command(pass_context=True, no_pm=True)
|
||||
async def volume(self, ctx, value : int):
|
||||
"""Définie le volume du bot."""
|
||||
#Définie le volume du bot.
|
||||
voice_channel_id = ctx.message.author.voice_channel
|
||||
if self.is_listening(voice_channel_id) == True:
|
||||
state = self.get_voice_state(ctx.message.server)
|
||||
|
@ -238,9 +237,9 @@ class Musique:
|
|||
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)
|
||||
await self.bot.say(embed=embed)"""
|
||||
|
||||
#MEt en pause la musique
|
||||
#Met en pause la musique
|
||||
@music.command(pass_context=True,no_pm=True)
|
||||
async def pause(self,ctx):
|
||||
voice_channel_id = ctx.message.author.voice_channel
|
||||
|
@ -283,7 +282,7 @@ class Musique:
|
|||
embed.add_field(name="resume", value="Vous n'étes pas dans le channel vocal !", inline=True)
|
||||
await self.bot.say(embed=embed)
|
||||
|
||||
async def on_voice_state_update(self,before,after):
|
||||
"""async def on_voice_state_update(self,before,after):
|
||||
state = self.get_voice_state(after.server)
|
||||
if type(state.voice) != type(None):
|
||||
if type(before.voice_channel) != type(None):
|
||||
|
@ -294,14 +293,30 @@ class Musique:
|
|||
if type(after.voice_channel) != type(None):
|
||||
if len(after.voice_channel.voice_members)>=2:
|
||||
try:await self.get_resume(state.voice.channel.server)
|
||||
except:pass
|
||||
except:pass"""
|
||||
async def on_voice_state_update(self,before,after):
|
||||
state = self.get_voice_state(after.server)
|
||||
if type(state.voice) != type(None):
|
||||
if len(state.voice.channel.voice_members)<2:
|
||||
server = after.server
|
||||
if state.is_playing():
|
||||
player = state.player
|
||||
player.stop()
|
||||
print("Stop lancer, channel vide !")
|
||||
|
||||
try:
|
||||
state.audio_player.cancel()
|
||||
del self.voice_states[server.id]
|
||||
await state.voice.disconnect()
|
||||
except:
|
||||
pass
|
||||
|
||||
#Arret la musique et fait quitter le bot
|
||||
@music.command(pass_context=True, no_pm=True)
|
||||
async def stop(self, ctx):
|
||||
"""Arrete la musique jouée et quitte le channel.
|
||||
Cela vide aussi la queue.
|
||||
"""
|
||||
#Arrete la musique jouée et quitte le channel.
|
||||
#Cela vide aussi la queue.
|
||||
|
||||
voice_channel_id = ctx.message.author.voice_channel
|
||||
if self.is_listening(voice_channel_id) == True:
|
||||
server = ctx.message.server
|
||||
|
@ -333,9 +348,9 @@ class Musique:
|
|||
#Permet de passer la musique en cours
|
||||
@music.command(pass_context=True, no_pm=True)
|
||||
async def skip(self, ctx):
|
||||
"""Vote pour passer la chanson en cours.
|
||||
Il faut trois votes pour passer la chanson.
|
||||
"""
|
||||
#Vote pour passer la chanson en cours.
|
||||
#Il faut trois votes pour passer la chanson.
|
||||
|
||||
voice_channel_id = ctx.message.author.voice_channel
|
||||
if self.is_listening(voice_channel_id) == True:
|
||||
state = self.get_voice_state(ctx.message.server)
|
||||
|
|
3
bot.py
3
bot.py
|
@ -34,6 +34,9 @@ async def on_ready():
|
|||
print("Démarrage de Music")
|
||||
bot.load_extension("Music")
|
||||
|
||||
print("Démarrage de Channeller")
|
||||
bot.load_extension("Channeller")
|
||||
|
||||
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")
|
||||
|
|
1
run.sh
1
run.sh
|
@ -10,3 +10,4 @@ fi
|
|||
printf "\nMise a jour terminer !\n"
|
||||
printf "\nLancement du FTW-Bot...\n"
|
||||
python3.6 bot.py
|
||||
exit
|
||||
|
|
Reference in a new issue