zhenxun_bot/zhenxun/builtin_plugins/hooks/auth/auth_cost.py

42 lines
1.3 KiB
Python
Raw Normal View History

import time
2025-01-08 15:23:10 +08:00
from nonebot_plugin_uninfo import Uninfo
from zhenxun.models.plugin_info import PluginInfo
from zhenxun.models.user_console import UserConsole
from zhenxun.services.log import logger
2025-04-08 17:11:44 +08:00
from .config import LOGGER_COMMAND, WARNING_THRESHOLD
2025-04-08 17:11:44 +08:00
from .exception import SkipPluginException
from .utils import send_message
2025-01-08 15:23:10 +08:00
async def auth_cost(user: UserConsole, plugin: PluginInfo, session: Uninfo) -> int:
"""检测是否满足金币条件
参数:
2025-07-10 17:10:07 +08:00
user: UserConsole
2025-01-08 15:23:10 +08:00
plugin: PluginInfo
session: Uninfo
返回:
int: 需要消耗的金币
"""
start_time = time.time()
try:
if user.gold < plugin.cost_gold:
"""插件消耗金币不足"""
await send_message(session, f"金币不足..该功能需要{plugin.cost_gold}金币..")
raise SkipPluginException(f"{plugin.name}({plugin.module}) 金币限制...")
return plugin.cost_gold
finally:
# 记录执行时间
elapsed = time.time() - start_time
if elapsed > WARNING_THRESHOLD: # 记录耗时超过500ms的检查
logger.warning(
f"auth_cost 耗时: {elapsed:.3f}s, plugin={plugin.module}",
LOGGER_COMMAND,
session=session,
)