from ATRI.log import logger as log
from ATRI.utils.apscheduler import scheduler
from .data_source import Status


ping = Status().on_command("/ping", "检测bot简单信息处理速度")


@ping.handle()
async def _():
    await ping.finish(Status.ping())


status = Status().on_command("/status", "查看运行资源占用")


@status.handle()
async def _():
    msg, _ = Status.get_status()
    await status.finish(msg)


info_msg = "アトリは高性能ですから!"


@scheduler.scheduled_job("interval", name="状态检查", minutes=10, misfire_grace_time=15)  # type: ignore
async def _():
    log.info("开始检查资源消耗...")
    msg, stat = Status().get_status()
    if not stat:
        log.warning(msg)
        await status.finish(msg)
    log.info("资源消耗正常")