PamGram/core/services/wiki/services.py

52 lines
1.8 KiB
Python
Raw Normal View History

2023-04-26 08:48:05 +00:00
from typing import NoReturn
2022-07-26 10:07:31 +00:00
from core.base_service import BaseService
from modules.wiki.character import Character
2023-04-26 08:48:05 +00:00
from modules.wiki.material import Material
from modules.wiki.monster import Monster
from modules.wiki.relic import Relic
from modules.wiki.light_cone import LightCone
from modules.wiki.raider import Raider
from utils.log import logger
2022-07-26 10:07:31 +00:00
__all__ = ["WikiService"]
2022-07-26 10:07:31 +00:00
class WikiService(BaseService):
2023-04-26 08:48:05 +00:00
def __init__(self):
self.character = Character()
self.material = Material()
self.monster = Monster()
self.relic = Relic()
self.light_cone = LightCone()
self.raider = Raider()
async def initialize(self) -> None:
logger.info("正在加载 Wiki 数据")
2023-04-27 12:25:06 +00:00
try:
await self.character.read()
await self.material.read()
await self.monster.read()
await self.relic.read()
await self.light_cone.read()
await self.raider.read()
except Exception as e:
logger.error("加载 Wiki 数据失败", exc_info=e)
2023-04-26 08:48:05 +00:00
logger.info("加载 Wiki 数据完成")
2022-07-26 10:07:31 +00:00
async def refresh_wiki(self) -> NoReturn:
logger.info("正在重新获取Wiki")
logger.info("正在重新获取角色信息")
2023-04-26 08:48:05 +00:00
await self.character.refresh()
logger.info("正在重新获取材料信息")
await self.material.refresh()
logger.info("正在重新获取敌对生物信息")
await self.monster.refresh()
logger.info("正在重新获取遗器信息")
await self.relic.refresh()
logger.info("正在重新获取光锥信息")
await self.light_cone.refresh()
logger.info("正在重新获取攻略信息")
await self.raider.refresh()
logger.info("刷新成功")