discord-havoc/disc_havoc.py

88 lines
2.4 KiB
Python
Raw Normal View History

2025-02-13 14:51:35 -05:00
#!/usr/bin/env python3.12
# pylint: disable=bare-except, invalid-name, import-outside-toplevel
import os
import logging
import importlib
2025-02-13 15:48:39 -05:00
from typing import Optional
2025-02-13 14:51:35 -05:00
import discord
import setproctitle
import hypercorn
import hypercorn.asyncio
from dotenv import load_dotenv
from discord.ext import bridge, commands
from termcolor import colored
2025-02-13 15:48:39 -05:00
from constants import OWNERS, BOT_CHANIDS
2025-02-13 14:51:35 -05:00
import api
logging.basicConfig(level=logging.INFO,
format='%(asctime)s %(message)s',
encoding='utf-8')
setproctitle.setproctitle('disc-havoc')
2025-02-13 15:48:39 -05:00
"""Auto Load Cogs"""
cogs_list: list[str] = [
2025-02-13 14:51:35 -05:00
'misc',
'owner',
'sing',
'meme',
'karma',
'lovehate',
'quote',
'radio',
]
bot_activity = discord.CustomActivity(name="I made cookies!")
load_dotenv()
intents = discord.Intents.all()
intents.message_content = True
bot = bridge.Bot(command_prefix=".", intents=intents,
2025-02-13 15:48:39 -05:00
owner_ids=OWNERS, activity=bot_activity,
2025-02-13 14:51:35 -05:00
help_command=commands.MinimalHelpCommand())
@bot.event
2025-02-13 15:48:39 -05:00
async def on_ready() -> None:
2025-02-13 14:51:35 -05:00
"""Run on Bot Ready"""
logging.info("%s online!", bot.user)
2025-02-13 15:48:39 -05:00
def load_exts(initialRun: Optional[bool] = True) -> None:
"""
Load Cogs/Extensions
Args:
initialRun (Optional[bool]) default: True
Returns:
None"""
2025-02-13 14:51:35 -05:00
load_method = bot.load_extension if initialRun else bot.reload_extension
for cog in cogs_list:
logging.info("Loading: %s", cog)
load_method(f'cogs.{cog}')
importlib.reload(api)
from api import API # pylint: disable=unused-import
api_config = hypercorn.config.Config()
api_config.bind = "10.10.10.100:5992"
api_instance = api.API(bot)
try:
bot.fapi_task.cancel()
2025-02-13 15:48:39 -05:00
except Exception as e:
logging.debug("Failed to cancel fapi_task: %s",
str(e))
2025-02-13 14:51:35 -05:00
logging.info("Starting FAPI Task")
2025-02-13 15:48:39 -05:00
bot.fapi_task = bot.loop.create_task(hypercorn.asyncio.serve(api_instance.api_app,
api_config))
2025-02-13 14:51:35 -05:00
2025-02-13 15:48:39 -05:00
def __init__() -> None:
logging.info(colored(f"Log level: {logging.getLevelName(logging.root.level)}",
"red", attrs=['reverse']))
2025-02-13 14:51:35 -05:00
bot.BOT_CHANIDS = BOT_CHANIDS
bot.load_exts = load_exts
bot.load_exts()
bot.run(os.getenv('TOKEN'))
if __name__ == "__main__":
__init__()