Extra lavalink listeners/optional track logging
This commit is contained in:
parent
00bf7880be
commit
fa9a78314f
@ -1,14 +1,15 @@
|
|||||||
import discord
|
import discord
|
||||||
from discord.ext import commands
|
from discord.ext import commands
|
||||||
from discord import app_commands
|
|
||||||
import lavalink
|
import lavalink
|
||||||
from lavalink import errors
|
from lavalink import errors
|
||||||
|
import os
|
||||||
|
|
||||||
from utils.config import (
|
from utils.config import (
|
||||||
LAVALINK_HOST,
|
LAVALINK_HOST,
|
||||||
LAVALINK_PASSWORD,
|
LAVALINK_PASSWORD,
|
||||||
LAVALINK_PORT,
|
LAVALINK_PORT,
|
||||||
LOG,
|
LOG,
|
||||||
|
LOG_SONGS,
|
||||||
)
|
)
|
||||||
from utils.command_tree import CheckPlayerError
|
from utils.command_tree import CheckPlayerError
|
||||||
from utils.ai_recommendations import add_song_recommendations
|
from utils.ai_recommendations import add_song_recommendations
|
||||||
@ -95,6 +96,7 @@ class LavalinkVoiceClient(discord.VoiceProtocol):
|
|||||||
class Music(commands.Cog):
|
class Music(commands.Cog):
|
||||||
def __init__(self, bot):
|
def __init__(self, bot):
|
||||||
self.bot = bot
|
self.bot = bot
|
||||||
|
self.log_file = "track_events.log"
|
||||||
|
|
||||||
async def cog_load(self):
|
async def cog_load(self):
|
||||||
if not hasattr(
|
if not hasattr(
|
||||||
@ -117,11 +119,16 @@ class Music(commands.Cog):
|
|||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
await node.connect()
|
await node.connect()
|
||||||
LOG.info(f"Connected to lavalink node {node.name}")
|
|
||||||
|
|
||||||
self.lavalink: lavalink.Client = self.bot.lavalink
|
self.lavalink: lavalink.Client = self.bot.lavalink
|
||||||
self.lavalink.add_event_hooks(self)
|
self.lavalink.add_event_hooks(self)
|
||||||
|
|
||||||
|
if os.path.exists("/.dockerenv"):
|
||||||
|
self.log_file = "/config/track_events.log"
|
||||||
|
|
||||||
|
if LOG_SONGS:
|
||||||
|
LOG.info(f"Logging track events to {self.log_file}")
|
||||||
|
|
||||||
def cog_unload(self):
|
def cog_unload(self):
|
||||||
"""Cog unload handler. This removes any event hooks that were registered."""
|
"""Cog unload handler. This removes any event hooks that were registered."""
|
||||||
self.lavalink._event_hooks.clear()
|
self.lavalink._event_hooks.clear()
|
||||||
@ -235,6 +242,54 @@ class Music(commands.Cog):
|
|||||||
self.bot.openai, self.bot.user, event.player, 5, inputs
|
self.bot.openai, self.bot.user, event.player, 5, inputs
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@lavalink.listener(lavalink.events.NodeConnectedEvent)
|
||||||
|
async def node_connected(self, event: lavalink.events.NodeConnectedEvent):
|
||||||
|
LOG.info(f"Lavalink node {event.node.name} has connected")
|
||||||
|
|
||||||
|
@lavalink.listener(lavalink.events.NodeReadyEvent)
|
||||||
|
async def node_ready(self, event: lavalink.events.NodeReadyEvent):
|
||||||
|
LOG.info(f"Lavalink node {event.node.name} is ready")
|
||||||
|
|
||||||
|
@lavalink.listener(lavalink.events.NodeDisconnectedEvent)
|
||||||
|
async def node_disconnected(
|
||||||
|
self, event: lavalink.events.NodeDisconnectedEvent
|
||||||
|
):
|
||||||
|
LOG.error(f"Lavalink node {event.node.name} has disconnected")
|
||||||
|
|
||||||
|
# If we get a track load failed event (like LoadError, but for some reason that
|
||||||
|
# wasn't the eception raised), skip the track
|
||||||
|
@lavalink.listener(lavalink.events.TrackLoadFailedEvent)
|
||||||
|
async def track_load_failed(self, event: lavalink.events.TrackEndEvent):
|
||||||
|
await event.player.skip()
|
||||||
|
|
||||||
|
# Only log track events if enabled
|
||||||
|
if LOG_SONGS:
|
||||||
|
|
||||||
|
@lavalink.listener(lavalink.events.TrackStartEvent)
|
||||||
|
async def track_start(self, event: lavalink.events.TrackStartEvent):
|
||||||
|
with open(self.log_file, "a") as f:
|
||||||
|
f.write(
|
||||||
|
f"STARTED: {event.track.title} by {event.track.author}\n"
|
||||||
|
)
|
||||||
|
|
||||||
|
@lavalink.listener(lavalink.events.TrackStuckEvent)
|
||||||
|
async def track_stuck(self, event: lavalink.events.TrackStuckEvent):
|
||||||
|
with open(self.log_file, "a") as f:
|
||||||
|
f.write(
|
||||||
|
f"STUCK: {event.track.title} by {event.track.author} -"
|
||||||
|
f" {event.track.uri}\n"
|
||||||
|
)
|
||||||
|
|
||||||
|
@lavalink.listener(lavalink.events.TrackExceptionEvent)
|
||||||
|
async def track_exception(
|
||||||
|
self, event: lavalink.events.TrackExceptionEvent
|
||||||
|
):
|
||||||
|
with open(self.log_file, "a") as f:
|
||||||
|
f.write(
|
||||||
|
f"EXCEPTION{event.track.title} by {event.track.author} -"
|
||||||
|
f" {event.track.uri}\n"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def setup(bot):
|
async def setup(bot):
|
||||||
await bot.add_cog(Music(bot))
|
await bot.add_cog(Music(bot))
|
||||||
|
@ -33,7 +33,8 @@ BOT_COLOR = None
|
|||||||
BOT_INVITE_LINK = None
|
BOT_INVITE_LINK = None
|
||||||
FEEDBACK_CHANNEL_ID = None
|
FEEDBACK_CHANNEL_ID = None
|
||||||
BUG_CHANNEL_ID = None
|
BUG_CHANNEL_ID = None
|
||||||
YOUTUBE_SUPPORT = None
|
LOG_SONGS = False
|
||||||
|
YOUTUBE_SUPPORT = False
|
||||||
SPOTIFY_CLIENT_ID = None
|
SPOTIFY_CLIENT_ID = None
|
||||||
SPOTIFY_CLIENT_SECRET = None
|
SPOTIFY_CLIENT_SECRET = None
|
||||||
GENIUS_CLIENT_ID = None
|
GENIUS_CLIENT_ID = None
|
||||||
@ -54,10 +55,17 @@ schema = {
|
|||||||
"bot_invite_link": {"type": "string"},
|
"bot_invite_link": {"type": "string"},
|
||||||
"feedback_channel_id": {"type": "integer"},
|
"feedback_channel_id": {"type": "integer"},
|
||||||
"bug_channel_id": {"type": "integer"},
|
"bug_channel_id": {"type": "integer"},
|
||||||
"youtube_support": {"type": "boolean"},
|
"log_songs": {"type": "boolean"},
|
||||||
},
|
},
|
||||||
"required": ["token"],
|
"required": ["token"],
|
||||||
},
|
},
|
||||||
|
"youtube": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"enabled": {"type": "boolean"},
|
||||||
|
},
|
||||||
|
"required": ["enabled"],
|
||||||
|
},
|
||||||
"spotify": {
|
"spotify": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"properties": {
|
"properties": {
|
||||||
@ -118,7 +126,10 @@ bot_info:
|
|||||||
bot_invite_link: ""
|
bot_invite_link: ""
|
||||||
feedback_channel_id: ""
|
feedback_channel_id: ""
|
||||||
bug_channel_id: ""
|
bug_channel_id: ""
|
||||||
youtube_support: false
|
log_songs: true
|
||||||
|
|
||||||
|
youtube:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
spotify:
|
spotify:
|
||||||
spotify_client_id: ""
|
spotify_client_id: ""
|
||||||
@ -149,7 +160,7 @@ lavalink:
|
|||||||
|
|
||||||
# Thouroughly validate all of the options in the config.yaml file
|
# Thouroughly validate all of the options in the config.yaml file
|
||||||
def validate_config(file_contents):
|
def validate_config(file_contents):
|
||||||
global TOKEN, BOT_COLOR, BOT_INVITE_LINK, FEEDBACK_CHANNEL_ID, BUG_CHANNEL_ID, YOUTUBE_SUPPORT, SPOTIFY_CLIENT_ID, SPOTIFY_CLIENT_SECRET, GENIUS_CLIENT_ID, GENIUS_CLIENT_SECRET, OPENAI_API_KEY, LAVALINK_HOST, LAVALINK_PORT, LAVALINK_PASSWORD
|
global TOKEN, BOT_COLOR, BOT_INVITE_LINK, FEEDBACK_CHANNEL_ID, BUG_CHANNEL_ID, LOG_SONGS, YOUTUBE_SUPPORT, SPOTIFY_CLIENT_ID, SPOTIFY_CLIENT_SECRET, GENIUS_CLIENT_ID, GENIUS_CLIENT_SECRET, OPENAI_API_KEY, LAVALINK_HOST, LAVALINK_PORT, LAVALINK_PASSWORD
|
||||||
config = yaml.safe_load(file_contents)
|
config = yaml.safe_load(file_contents)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -209,10 +220,12 @@ def validate_config(file_contents):
|
|||||||
else:
|
else:
|
||||||
BUG_CHANNEL_ID = config["bot_info"]["bug_channel_id"]
|
BUG_CHANNEL_ID = config["bot_info"]["bug_channel_id"]
|
||||||
|
|
||||||
if "youtube_support" in config["bot_info"]:
|
if "log_songs" in config["bot_info"]:
|
||||||
YOUTUBE_SUPPORT = bool(config["bot_info"]["youtube_support"])
|
LOG_SONGS = bool(config["bot_info"]["log_songs"])
|
||||||
else:
|
|
||||||
YOUTUBE_SUPPORT = False
|
# Check for YouTube support
|
||||||
|
if "youtube" in config:
|
||||||
|
YOUTUBE_SUPPORT = bool(config["youtube"]["enabled"])
|
||||||
|
|
||||||
#
|
#
|
||||||
# If the SPOTIFY section is present, make sure the client ID and secret are valid
|
# If the SPOTIFY section is present, make sure the client ID and secret are valid
|
||||||
|
Loading…
x
Reference in New Issue
Block a user