89 lines
2.8 KiB
Python
89 lines
2.8 KiB
Python
import asyncio
|
|
import traceback
|
|
from typing import Optional
|
|
|
|
from cpl_core.application import ApplicationBuilder
|
|
from cpl_core.console import Console
|
|
|
|
from bot.application import Application
|
|
from bot.extension.init_bot_extension import InitBotExtension
|
|
from bot.startup import Startup
|
|
from bot.startup_discord_extension import StartupDiscordExtension
|
|
from bot.startup_migration_extension import StartupMigrationExtension
|
|
from bot.startup_module_extension import StartupModuleExtension
|
|
from bot.startup_settings_extension import StartupSettingsExtension
|
|
from bot_api.app_api_extension import AppApiExtension
|
|
from bot_core.core_extension.core_extension import CoreExtension
|
|
from modules.boot_log.boot_log_extension import BootLogExtension
|
|
from modules.config.config_extension import ConfigExtension
|
|
from modules.database.database_extension import DatabaseExtension
|
|
|
|
|
|
class Program:
|
|
def __init__(self):
|
|
self.app: Optional[Application] = None
|
|
|
|
async def start(self):
|
|
# discord extension has to be loaded before modules (modules depends on discord stuff)
|
|
app_builder = (
|
|
ApplicationBuilder(Application)
|
|
.use_extension(StartupSettingsExtension)
|
|
.use_extension(StartupDiscordExtension)
|
|
.use_extension(StartupModuleExtension)
|
|
.use_extension(StartupMigrationExtension)
|
|
.use_extension(DatabaseExtension)
|
|
.use_extension(ConfigExtension)
|
|
.use_extension(InitBotExtension)
|
|
.use_extension(BootLogExtension)
|
|
.use_extension(AppApiExtension)
|
|
.use_extension(CoreExtension)
|
|
.use_startup(Startup)
|
|
)
|
|
self.app: Application = await app_builder.build_async()
|
|
await self.app.run_async()
|
|
Console.write_line(f"[ INFO ] [ {__name__} ]: Finished app.run_async")
|
|
|
|
async def stop(self):
|
|
if self.app is None:
|
|
return
|
|
await self.app.stop_async()
|
|
|
|
|
|
def main():
|
|
program = Program()
|
|
try:
|
|
asyncio.run(program.start())
|
|
except KeyboardInterrupt:
|
|
asyncio.run(program.stop())
|
|
except Exception as e:
|
|
Console.error(
|
|
f"[ ERROR ] [ {__name__} ]: Cannot start the bot",
|
|
f"{e} -> {traceback.format_exc()}",
|
|
)
|
|
finally:
|
|
try:
|
|
asyncio.run(program.stop())
|
|
except Exception as e:
|
|
Console.error(
|
|
f"[ ERROR ] [ {__name__} ]: Cannot stop the bot",
|
|
f"{e} -> {traceback.format_exc()}",
|
|
)
|
|
|
|
if program.app is not None and program.app.is_restart():
|
|
del program
|
|
main()
|
|
|
|
|
|
if __name__ == "__main__":
|
|
main()
|
|
|
|
# ((
|
|
# ( `)
|
|
# ; / ,
|
|
# / \/
|
|
# / |
|
|
# / ~/
|
|
# / ) ) ~ edraft
|
|
# ___// | /
|
|
# `--' \_~-,
|