mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
modified: basic_plugins/admin_bot_manage/admin_config.py modified: basic_plugins/admin_bot_manage/custom_welcome_message.py modified: basic_plugins/admin_bot_manage/timing_task.py modified: basic_plugins/apscheduler/__init__.py modified: basic_plugins/ban/__init__.py modified: basic_plugins/ban/data_source.py modified: basic_plugins/chat_history/chat_message.py modified: basic_plugins/chat_history/chat_message_handle.py modified: basic_plugins/group_handle/__init__.py modified: basic_plugins/hooks/_utils.py modified: basic_plugins/hooks/ban_hook.py modified: basic_plugins/hooks/chkdsk_hook.py modified: basic_plugins/init_plugin_config/__init__.py deleted: basic_plugins/init_plugin_config/init_group_manager.py modified: basic_plugins/invite_manager/__init__.py new file: basic_plugins/invite_manager/utils.py modified: basic_plugins/nickname.py modified: basic_plugins/plugin_shop/__init__.py modified: basic_plugins/plugin_shop/data_source.py modified: basic_plugins/scripts.py modified: basic_plugins/shop/__init__.py modified: basic_plugins/shop/buy.py modified: basic_plugins/shop/gold.py modified: basic_plugins/shop/my_props/__init__.py deleted: basic_plugins/shop/reset_today_gold.py modified: basic_plugins/shop/shop_handle/__init__.py modified: basic_plugins/shop/shop_handle/data_source.py modified: basic_plugins/shop/use/__init__.py modified: basic_plugins/shop/use/data_source.py modified: basic_plugins/super_cmd/__init__.py modified: basic_plugins/super_cmd/bot_friend_group.py modified: basic_plugins/super_cmd/clear_data.py modified: basic_plugins/super_cmd/exec_sql.py modified: basic_plugins/super_cmd/manager_group.py modified: basic_plugins/super_cmd/reload_setting.py modified: basic_plugins/super_cmd/set_admin_permissions.py deleted: basic_plugins/super_cmd/super_task_switch.py modified: basic_plugins/super_cmd/update_friend_group_info.py modified: basic_plugins/super_help/__init__.py modified: basic_plugins/update_info.py modified: configs/config.py modified: configs/utils/__init__.py modified: models/bag_user.py modified: models/ban_user.py modified: models/chat_history.py modified: models/friend_user.py modified: models/goods_info.py modified: models/group_info.py modified: models/group_member_info.py modified: models/level_user.py modified: models/sign_group_user.py modified: models/user_shop_gold_log.py modified: plugins/aconfig/__init__.py modified: plugins/ai/__init__.py modified: plugins/ai/data_source.py modified: plugins/bilibili_sub/__init__.py modified: plugins/bilibili_sub/data_source.py modified: plugins/bilibili_sub/model.py modified: plugins/black_word/__init__.py modified: plugins/black_word/model.py modified: plugins/black_word/utils.py modified: plugins/bt/data_source.py modified: plugins/genshin/almanac/__init__.py modified: plugins/genshin/material_remind/__init__.py modified: plugins/genshin/query_user/_models/__init__.py modified: plugins/genshin/query_user/_utils/__init__.py modified: plugins/genshin/query_user/bind/__init__.py modified: plugins/genshin/query_user/genshin_sign/__init__.py modified: plugins/genshin/query_user/genshin_sign/data_source.py modified: plugins/genshin/query_user/genshin_sign/init_task.py modified: plugins/genshin/query_user/mihoyobbs_sign/__init__.py modified: plugins/genshin/query_user/query_memo/__init__.py modified: plugins/genshin/query_user/query_memo/data_source.py modified: plugins/genshin/query_user/query_role/__init__.py modified: plugins/genshin/query_user/query_role/data_source.py modified: plugins/genshin/query_user/reset_today_query_user_data/__init__.py modified: plugins/genshin/query_user/resin_remind/__init__.py modified: plugins/genshin/query_user/resin_remind/init_task.py modified: plugins/gold_redbag/model.py modified: plugins/image_management/send_image/__init__.py modified: plugins/my_info/__init__.py modified: plugins/open_cases/models/buff_prices.py modified: plugins/open_cases/models/open_cases_user.py modified: plugins/open_cases/open_cases_c.py modified: plugins/open_cases/utils.py modified: plugins/parse_bilibili_json.py modified: plugins/pid_search.py modified: plugins/pix_gallery/__init__.py modified: plugins/pix_gallery/_data_source.py modified: plugins/pix_gallery/_model/omega_pixiv_illusts.py modified: plugins/pix_gallery/_model/pixiv.py modified: plugins/pix_gallery/_model/pixiv_keyword_user.py modified: plugins/pix_gallery/pix_add_keyword.py modified: plugins/pix_gallery/pix_pass_del_keyword.py modified: plugins/pix_gallery/pix_show_info.py modified: plugins/pix_gallery/pix_update.py modified: plugins/pixiv_rank_search/data_source.py modified: plugins/poke/__init__.py modified: plugins/russian/__init__.py modified: plugins/russian/data_source.py modified: plugins/russian/model.py modified: plugins/send_dinggong_voice/__init__.py modified: plugins/send_setu_/_model.py modified: plugins/send_setu_/send_setu/__init__.py modified: plugins/send_setu_/send_setu/data_source.py modified: plugins/send_setu_/update_setu/data_source.py modified: plugins/sign_in/goods_register.py modified: plugins/sign_in/group_user_checkin.py modified: plugins/sign_in/random_event.py modified: plugins/sign_in/utils.py modified: plugins/statistics/_model.py modified: plugins/statistics/statistics_handle.py modified: plugins/statistics/statistics_hook.py modified: plugins/update_picture.py modified: plugins/web_ui/api/request.py modified: plugins/word_bank/_model.py deleted: plugins/word_bank/_old_model.py modified: plugins/word_bank/_rule.py modified: plugins/word_bank/word_handle.py modified: plugins/word_clouds/data_source.py modified: resources/image/sign/sign_res/bar.png modified: resources/image/sign/sign_res/bar_white.png modified: services/db_context.py modified: services/log.py modified: utils/browser.py modified: utils/data_utils.py modified: utils/depends/__init__.py modified: utils/http_utils.py modified: utils/image_utils.py modified: utils/manager/admin_manager.py modified: utils/message_builder.py modified: utils/utils.py
142 lines
4.2 KiB
Python
Executable File
142 lines
4.2 KiB
Python
Executable File
from datetime import datetime, timedelta
|
|
from typing import Any, Dict, Optional
|
|
|
|
from loguru import logger as logger_
|
|
from nonebot.log import default_filter, default_format
|
|
|
|
from configs.path_config import LOG_PATH
|
|
|
|
logger_.add(
|
|
LOG_PATH / f"{datetime.now().date()}.log",
|
|
level="INFO",
|
|
rotation="00:00",
|
|
format=default_format,
|
|
filter=default_filter,
|
|
retention=timedelta(days=30),
|
|
)
|
|
|
|
logger_.add(
|
|
LOG_PATH / f"error_{datetime.now().date()}.log",
|
|
level="ERROR",
|
|
rotation="00:00",
|
|
format=default_format,
|
|
filter=default_filter,
|
|
retention=timedelta(days=30),
|
|
)
|
|
|
|
|
|
class logger:
|
|
|
|
TEMPLATE_A = "{}"
|
|
TEMPLATE_B = "[<u><c>{}</c></u>]: {}"
|
|
TEMPLATE_C = "用户[<u><e>{}</e></u>] 触发 [<u><c>{}</c></u>]: {}"
|
|
TEMPLATE_D = "群聊[<u><e>{}</e></u>] 用户[<u><e>{}</e></u>] 触发 [<u><c>{}</c></u>]: {}"
|
|
TEMPLATE_E = "群聊[<u><e>{}</e></u>] 用户[<u><e>{}</e></u>] 触发 [<u><c>{}</c></u>] [Target](<u><e>{}</e></u>): {}"
|
|
|
|
TEMPLATE_USER = "用户[<u><e>{}</e></u>] "
|
|
TEMPLATE_GROUP = "群聊[<u><e>{}</e></u>] "
|
|
TEMPLATE_COMMAND = "CMD[<u><c>{}</c></u>] "
|
|
TEMPLATE_TARGET = "[Target]([<u><e>{}</e></u>]) "
|
|
|
|
SUCCESS_TEMPLATE = "[<u><c>{}</c></u>]: {} | 参数[{}] 返回: [<y>{}</y>]"
|
|
|
|
WARNING_TEMPLATE = "[<u><y>{}</y></u>]: {}"
|
|
|
|
ERROR_TEMPLATE = "[<u><r>{}</r></u>]: {}"
|
|
|
|
@classmethod
|
|
def info(
|
|
cls,
|
|
info: str,
|
|
command: Optional[str] = None,
|
|
user_id: Optional[int] = None,
|
|
group_id: Optional[int] = None,
|
|
target: Optional[Any] = None,
|
|
):
|
|
template = cls.__parser_template(info, command, user_id, group_id, target)
|
|
logger_.opt(colors=True).info(template)
|
|
|
|
@classmethod
|
|
def success(
|
|
cls,
|
|
info: str,
|
|
command: str,
|
|
param: Optional[Dict[str, Any]] = None,
|
|
result: Optional[str] = "",
|
|
):
|
|
param_str = ""
|
|
if param:
|
|
param_str = ",".join([f"<m>{k}</m>:<g>{v}</g>" for k, v in param.items()])
|
|
logger_.opt(colors=True).success(
|
|
cls.SUCCESS_TEMPLATE.format(command, info, param_str, result)
|
|
)
|
|
|
|
@classmethod
|
|
def warning(
|
|
cls,
|
|
info: str,
|
|
command: Optional[str] = None,
|
|
user_id: Optional[int] = None,
|
|
group_id: Optional[int] = None,
|
|
target: Optional[Any] = None,
|
|
e: Optional[Exception] = None,
|
|
):
|
|
template = cls.__parser_template(info, command, user_id, group_id, target)
|
|
if e:
|
|
template += f" || 错误<r>{type(e)}: {e}</r>"
|
|
logger_.opt(colors=True).warning(template)
|
|
|
|
@classmethod
|
|
def error(
|
|
cls,
|
|
info: str,
|
|
command: Optional[str] = None,
|
|
user_id: Optional[int] = None,
|
|
group_id: Optional[int] = None,
|
|
target: Optional[Any] = None,
|
|
e: Optional[Exception] = None,
|
|
):
|
|
template = cls.__parser_template(info, command, user_id, group_id, target)
|
|
if e:
|
|
template += f" || 错误 <r>{type(e)}: {e}</r>"
|
|
logger_.opt(colors=True).error(template)
|
|
|
|
@classmethod
|
|
def debug(
|
|
cls,
|
|
info: str,
|
|
command: Optional[str] = None,
|
|
user_id: Optional[int] = None,
|
|
group_id: Optional[int] = None,
|
|
target: Optional[Any] = None,
|
|
):
|
|
template = cls.__parser_template(info, command, user_id, group_id, target)
|
|
logger_.opt(colors=True).debug(template)
|
|
|
|
@classmethod
|
|
def __parser_template(
|
|
cls,
|
|
info: str,
|
|
command: Optional[str] = None,
|
|
user_id: Optional[int] = None,
|
|
group_id: Optional[int] = None,
|
|
target: Optional[Any] = None,
|
|
) -> str:
|
|
arg_list = []
|
|
template = ""
|
|
if group_id is not None:
|
|
template += cls.TEMPLATE_GROUP
|
|
arg_list.append(group_id)
|
|
if user_id is not None:
|
|
template += cls.TEMPLATE_USER
|
|
arg_list.append(user_id)
|
|
if command is not None:
|
|
template += cls.TEMPLATE_COMMAND
|
|
arg_list.append(command)
|
|
if target is not None:
|
|
template += cls.TEMPLATE_TARGET
|
|
arg_list.append(target)
|
|
arg_list.append(info)
|
|
template += "{}"
|
|
return template.format(*arg_list)
|