mirror of
https://github.com/wlinator/luminara.git
synced 2024-10-02 22:23:13 +00:00
63 lines
1.9 KiB
Python
63 lines
1.9 KiB
Python
import logging
|
|
import os
|
|
import platform
|
|
|
|
import discord
|
|
from discord.ext import bridge
|
|
|
|
from lib import metadata
|
|
|
|
logs = logging.getLogger('Lumi.Core')
|
|
|
|
|
|
class LumiBot(bridge.Bot):
|
|
async def on_ready(self):
|
|
logs.info("-------------------------------------------------------")
|
|
logs.info(f"[INFO] {metadata.__title__} v{metadata.__version__}")
|
|
logs.info(f"[INFO] Logged in with ID {self.user.id}")
|
|
logs.info(f"[INFO] discord.py API version: {discord.__version__}")
|
|
logs.info(f"[INFO] Python version: {platform.python_version()}")
|
|
logs.info(f"[INFO] Running on: {platform.system()} {platform.release()} ({os.name})")
|
|
logs.info("-------------------------------------------------------")
|
|
|
|
"""
|
|
https://docs.pycord.dev/en/stable/api/events.html#discord.on_ready
|
|
This function isn't guaranteed to only be called once.
|
|
Event is called when RESUME request fails.
|
|
"""
|
|
|
|
async def process_commands(self, message: discord.Message):
|
|
if message.author.bot:
|
|
return
|
|
|
|
ctx = await self.get_context(message)
|
|
|
|
if ctx.command:
|
|
await ctx.trigger_typing()
|
|
await self.invoke(ctx)
|
|
|
|
@staticmethod
|
|
async def get_or_fetch_channel(guild, channel_id):
|
|
channel = guild.get_channel(channel_id)
|
|
|
|
if not channel:
|
|
try:
|
|
channel = await guild.fetch_channel(channel_id)
|
|
|
|
except (discord.HTTPException, discord.NotFound, discord.Forbidden):
|
|
return None
|
|
|
|
return channel
|
|
|
|
@staticmethod
|
|
async def get_or_fetch_member(guild, user_id):
|
|
member = guild.get_member(user_id)
|
|
|
|
if not member:
|
|
try:
|
|
member = await guild.fetch_member(user_id)
|
|
|
|
except (discord.HTTPException, discord.NotFound, discord.Forbidden):
|
|
return None
|
|
|
|
return member
|