edditing code
This commit is contained in:
@@ -1,13 +1,12 @@
|
|||||||
import logging
|
import logging
|
||||||
import tempfile
|
import tempfile
|
||||||
from asyncio import sleep
|
|
||||||
from os import path, makedirs, rename, remove
|
from os import path, makedirs, rename, remove
|
||||||
from random import randrange
|
import random
|
||||||
|
|
||||||
from disnake import FFmpegPCMAudio
|
|
||||||
from disnake.ext import commands
|
from disnake.ext import commands
|
||||||
|
|
||||||
from lib.DB import read_db, check_exist_audio, add_audio
|
from lib.DB import read_db, check_exist_audio, add_audio
|
||||||
|
from lib.Player import play_audio
|
||||||
|
|
||||||
|
|
||||||
class Audio(commands.Cog):
|
class Audio(commands.Cog):
|
||||||
@@ -22,24 +21,29 @@ class Audio(commands.Cog):
|
|||||||
async def on_voice_state_update(self, member, before, after):
|
async def on_voice_state_update(self, member, before, after):
|
||||||
from lib.Comands import read_json
|
from lib.Comands import read_json
|
||||||
role = await read_json(member.guild.id, 'tigger_role')
|
role = await read_json(member.guild.id, 'tigger_role')
|
||||||
audio = await read_db(member.guild.id, member.id, 'usertracks')
|
# Read audio from DB
|
||||||
|
audio_db = await read_db(member.guild.id, member.id, 'usertracks')
|
||||||
|
def_audio_db = await read_db(member.guild.id, member.id, 'defaulttracks')
|
||||||
|
if audio_db is not None:
|
||||||
|
audio_db = audio_db.split(', ') # Need to fix creating list
|
||||||
|
for i in range(len(audio_db)):
|
||||||
|
audio_db[i] = f'{member.id}/{audio_db[i]}'
|
||||||
|
print(audio_db)
|
||||||
|
if def_audio_db is not None:
|
||||||
|
def_audio_db = def_audio_db.split(', ')
|
||||||
from lib.Comands import list_files
|
from lib.Comands import list_files
|
||||||
audio_files = await list_files(f'audio/{member.id}')
|
def_audio_ls = await list_files()
|
||||||
logging.info(f"state changed to user {member}")
|
if before.channel is None and not member.bot:
|
||||||
f = await list_files()
|
full_audio = []
|
||||||
if role is not None and before.channel is None and role in member.roles:
|
if def_audio_db or audio_db is not None:
|
||||||
track = randrange(0, len(f) - 1, 1)
|
full_audio = def_audio_db + audio_db
|
||||||
audio_source = FFmpegPCMAudio(f'audio/{f[track]}')
|
elif role in member.roles:
|
||||||
|
full_audio = def_audio_ls
|
||||||
|
print(full_audio)
|
||||||
|
audio = random.choice(full_audio)
|
||||||
|
print(audio)
|
||||||
if not self.bot.voice_clients:
|
if not self.bot.voice_clients:
|
||||||
await sleep(1)
|
await play_audio(audio, self.bot, after.channel)
|
||||||
_channel = after.channel
|
|
||||||
vc = await after.channel.connect()
|
|
||||||
if not vc.is_playing():
|
|
||||||
vc.play(audio_source, after=None)
|
|
||||||
while vc.is_playing():
|
|
||||||
await sleep(0.5)
|
|
||||||
await sleep(1)
|
|
||||||
await vc.disconnect()
|
|
||||||
|
|
||||||
@commands.command(name="upload_audio")
|
@commands.command(name="upload_audio")
|
||||||
async def upload_audio(self, ctx, user=None):
|
async def upload_audio(self, ctx, user=None):
|
||||||
@@ -62,7 +66,7 @@ class Audio(commands.Cog):
|
|||||||
from pymediainfo import MediaInfo
|
from pymediainfo import MediaInfo
|
||||||
file = f'{tempfile.tempdir}/{user.id}/{at.filename}'
|
file = f'{tempfile.tempdir}/{user.id}/{at.filename}'
|
||||||
duration = round(MediaInfo.parse(file).tracks[0].duration / 1000)
|
duration = round(MediaInfo.parse(file).tracks[0].duration / 1000)
|
||||||
if duration > 15:
|
if duration > 20:
|
||||||
await ctx.reply(f'Audio duration is {duration}, but max is 15')
|
await ctx.reply(f'Audio duration is {duration}, but max is 15')
|
||||||
remove(f'{tempfile.tempdir}/{user.id}/{at.filename}')
|
remove(f'{tempfile.tempdir}/{user.id}/{at.filename}')
|
||||||
else:
|
else:
|
||||||
|
|||||||
@@ -2,6 +2,8 @@ from os import listdir
|
|||||||
|
|
||||||
"""
|
"""
|
||||||
Loads, unloads Cogs files
|
Loads, unloads Cogs files
|
||||||
|
cog_list: return list of cog filenames
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
@@ -13,13 +15,6 @@ def cog_list():
|
|||||||
return cogs_list
|
return cogs_list
|
||||||
|
|
||||||
|
|
||||||
async def cogs_dict():
|
|
||||||
cog_dict = {}
|
|
||||||
for _cog in cog_list():
|
|
||||||
cog_dict.update({f'{_cog}': f'{_cog}'})
|
|
||||||
return cog_dict
|
|
||||||
|
|
||||||
|
|
||||||
async def work_with_cogs(what_do, bot):
|
async def work_with_cogs(what_do, bot):
|
||||||
for _filename in cog_list():
|
for _filename in cog_list():
|
||||||
if what_do == "load":
|
if what_do == "load":
|
||||||
|
|||||||
@@ -1,5 +1,9 @@
|
|||||||
import json
|
import json
|
||||||
from os import walk
|
from os import walk
|
||||||
|
"""
|
||||||
|
Some prepare for commands
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
async def list_files(fold: str = 'audio'):
|
async def list_files(fold: str = 'audio'):
|
||||||
@@ -54,13 +58,14 @@ async def write_json(guild: int, param_name: str, param: str or int):
|
|||||||
json.dump(_json, f, indent=4)
|
json.dump(_json, f, indent=4)
|
||||||
|
|
||||||
|
|
||||||
async def determine_prefix(bot, msg):
|
def determine_prefix(bot, msg):
|
||||||
"""
|
"""
|
||||||
Determite per-server bot prefix
|
Determite per-server bot prefix
|
||||||
:param bot: Disnake Bot object
|
:param bot: Disnake Bot object
|
||||||
:param msg: Disnake msg object
|
:param msg: Disnake msg object
|
||||||
:return: prefix for server, default is $
|
:return: prefix for server, default is $
|
||||||
"""
|
"""
|
||||||
|
parameter = '$'
|
||||||
with open('prefix.json', 'r', encoding='utf-8') as fp: # Open the JSON
|
with open('prefix.json', 'r', encoding='utf-8') as fp: # Open the JSON
|
||||||
try:
|
try:
|
||||||
from json import load
|
from json import load
|
||||||
@@ -69,6 +74,7 @@ async def determine_prefix(bot, msg):
|
|||||||
_json = {}
|
_json = {}
|
||||||
try:
|
try:
|
||||||
parameter = _json[f"{msg.guild.id}"]["prefix"] # Read prefix from json if is setted up
|
parameter = _json[f"{msg.guild.id}"]["prefix"] # Read prefix from json if is setted up
|
||||||
|
|
||||||
except:
|
except:
|
||||||
parameter = '$'
|
pass
|
||||||
return parameter
|
return parameter
|
||||||
|
|||||||
14
lib/Player.py
Normal file
14
lib/Player.py
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
from asyncio import sleep
|
||||||
|
from disnake import FFmpegPCMAudio
|
||||||
|
|
||||||
|
|
||||||
|
async def play_audio(audio, bot, vc):
|
||||||
|
if not bot.voice_clients:
|
||||||
|
await sleep(1)
|
||||||
|
vp = await vc.connect()
|
||||||
|
if not vp.is_playing():
|
||||||
|
vp.play(FFmpegPCMAudio(f'audio/{audio}'), after=None)
|
||||||
|
while vp.is_playing():
|
||||||
|
await sleep(0.5)
|
||||||
|
await sleep(1)
|
||||||
|
await vp.disconnect()
|
||||||
Reference in New Issue
Block a user