zhenxun_bot/basic_plugins/shop/use/data_source.py

236 lines
7.9 KiB
Python
Raw Normal View History

from nonebot.adapters.onebot.v11 import GroupMessageEvent, MessageSegment, Message
2022-01-05 22:32:59 +08:00
from services.log import logger
2022-02-19 18:20:19 +08:00
from nonebot.adapters.onebot.v11 import Bot
2022-05-03 02:03:06 +08:00
from pydantic import create_model
from utils.models import ShopParam
2022-10-15 19:49:53 +08:00
from typing import Optional, Union, Callable, List, Tuple, Dict, Any
2022-05-03 02:03:06 +08:00
from types import MappingProxyType
import inspect
2022-01-16 14:52:50 +08:00
import asyncio
class GoodsUseFuncManager:
def __init__(self):
self._data = {}
2022-10-15 19:49:53 +08:00
def register_use_before_handle(self, goods_name: str, fun_list: List[Callable]):
"""
说明:
注册商品使用前函数
参数:
:param goods_name: 商品名称
:param fun_list: 函数列表
"""
if fun_list:
self._data[goods_name]["before_handle"] = fun_list
logger.info(f"register_use_before_handle 成功注册商品:{goods_name}{len(fun_list)}个使用前函数")
def register_use_after_handle(self, goods_name: str, fun_list: List[Callable]):
"""
说明:
注册商品使用后函数
参数:
:param goods_name: 商品名称
:param fun_list: 函数列表
"""
if fun_list:
self._data[goods_name]["after_handle"] = fun_list
logger.info(f"register_use_after_handle 成功注册商品:{goods_name}{len(fun_list)}个使用后函数")
2022-01-16 14:52:50 +08:00
def register_use(self, goods_name: str, **kwargs):
"""
注册商品使用方法
:param goods_name: 商品名称
:param kwargs: kwargs
"""
self._data[goods_name] = kwargs
def exists(self, goods_name: str) -> bool:
"""
判断商品使用方法是否被注册
:param goods_name: 商品名称
"""
2022-10-15 19:49:53 +08:00
return bool(self._data.get(goods_name))
2022-01-16 14:52:50 +08:00
def get_max_num_limit(self, goods_name: str) -> int:
"""
获取单次商品使用数量
:param goods_name: 商品名称
"""
if self.exists(goods_name):
2022-05-03 09:43:38 +08:00
return self._data[goods_name]["kwargs"]["max_num_limit"]
2022-01-16 14:52:50 +08:00
return 1
2022-10-15 19:49:53 +08:00
def _parse_args(self, args_: MappingProxyType, param: ShopParam, **kwargs):
param_list_ = []
_bot = param.bot
param.bot = None
param_json = param.dict()
param_json["bot"] = _bot
for par in args_.keys():
if par in ["shop_param"]:
param_list_.append(param)
elif par not in ["args", "kwargs"]:
param_list_.append(param_json.get(par))
if kwargs.get(par) is not None:
del kwargs[par]
return param_list_
2022-05-03 02:03:06 +08:00
async def use(
self, param: ShopParam, **kwargs
) -> Optional[Union[str, MessageSegment]]:
2022-01-16 14:52:50 +08:00
"""
使用道具
2022-05-03 02:03:06 +08:00
:param param: BaseModel
2022-01-16 14:52:50 +08:00
:param kwargs: kwargs
"""
2022-05-03 02:03:06 +08:00
goods_name = param.goods_name
2022-01-16 14:52:50 +08:00
if self.exists(goods_name):
2022-10-15 19:49:53 +08:00
# 使用方法
2022-05-03 15:31:34 +08:00
args = inspect.signature(self._data[goods_name]["func"]).parameters
if args and list(args.keys())[0] != "kwargs":
2022-05-03 02:03:06 +08:00
if asyncio.iscoroutinefunction(self._data[goods_name]["func"]):
return await self._data[goods_name]["func"](
2022-10-15 19:49:53 +08:00
*self._parse_args(args, param, **kwargs)
2022-05-03 02:03:06 +08:00
)
else:
return self._data[goods_name]["func"](
2022-10-15 19:49:53 +08:00
*self._parse_args(args, param, **kwargs)
2022-05-03 02:03:06 +08:00
)
2022-01-16 14:52:50 +08:00
else:
2022-05-03 02:03:06 +08:00
if asyncio.iscoroutinefunction(self._data[goods_name]["func"]):
return await self._data[goods_name]["func"](
**kwargs,
)
else:
return self._data[goods_name]["func"](
**kwargs,
)
2022-01-16 14:52:50 +08:00
2022-10-15 19:49:53 +08:00
async def run_handle(self, goods_name: str, type_: str, param: ShopParam, **kwargs):
modified: basic_plugins/admin_bot_manage/_data_source.py 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
2023-02-18 18:46:54 +08:00
if self._data.get(goods_name) and self._data[goods_name].get(type_):
2022-10-15 19:49:53 +08:00
for func in self._data[goods_name].get(type_):
args = inspect.signature(func).parameters
if args and list(args.keys())[0] != "kwargs":
if asyncio.iscoroutinefunction(func):
await func(*self._parse_args(args, param, **kwargs))
else:
func(*self._parse_args(args, param, **kwargs))
else:
if asyncio.iscoroutinefunction(func):
await func(**kwargs)
else:
func(**kwargs)
2022-01-16 14:52:50 +08:00
def check_send_success_message(self, goods_name: str) -> bool:
"""
检查是否发送使用成功信息
:param goods_name: 商品名称
"""
if self.exists(goods_name):
return bool(self._data[goods_name]["kwargs"]["send_success_msg"])
return False
def get_kwargs(self, goods_name: str) -> dict:
"""
获取商品使用方法的kwargs
:param goods_name: 商品名称
"""
if self.exists(goods_name):
return self._data[goods_name]["kwargs"]
return {}
def init_model(self, goods_name: str, bot: Bot, event: GroupMessageEvent, num: int, text: str):
2022-05-03 02:03:06 +08:00
return self._data[goods_name]["model"](
**{
"goods_name": goods_name,
"bot": bot,
"event": event,
"user_id": event.user_id,
"group_id": event.group_id,
"num": num,
"message": event.message,
"text": text
2022-05-03 02:03:06 +08:00
}
)
2022-01-05 22:32:59 +08:00
2022-01-16 14:52:50 +08:00
func_manager = GoodsUseFuncManager()
2022-01-05 22:32:59 +08:00
2022-10-15 19:49:53 +08:00
def build_params(
bot: Bot, event: GroupMessageEvent, goods_name: str, num: int, text: str
2022-10-15 19:49:53 +08:00
) -> Tuple[ShopParam, Dict[str, Any]]:
"""
说明:
构造参数
参数:
:param bot: bot
:param event: event
:param goods_name: 商品名称
:param num: 数量
:param text: 其他信息
2022-10-15 19:49:53 +08:00
"""
_kwargs = func_manager.get_kwargs(goods_name)
return (
func_manager.init_model(goods_name, bot, event, num, text),
2022-10-15 19:49:53 +08:00
{
**_kwargs,
"_bot": bot,
"event": event,
"group_id": event.group_id,
"user_id": event.user_id,
"num": num,
"text": text,
"message": event.message,
2022-10-15 19:49:53 +08:00
"goods_name": goods_name,
},
)
2022-02-09 20:05:49 +08:00
async def effect(
bot: Bot, event: GroupMessageEvent, goods_name: str, num: int, text: str, message: Message
2022-02-09 20:05:49 +08:00
) -> Optional[Union[str, MessageSegment]]:
2022-01-05 22:32:59 +08:00
"""
商品生效
2022-01-16 14:52:50 +08:00
:param bot: Bot
:param event: GroupMessageEvent
2022-01-05 22:32:59 +08:00
:param goods_name: 商品名称
2022-01-16 14:52:50 +08:00
:param num: 使用数量
:param text: 其他信息
:param message: Message
2022-01-05 22:32:59 +08:00
:return: 使用是否成功
"""
# 优先使用注册的商品插件
2022-05-03 02:03:06 +08:00
# try:
if func_manager.exists(goods_name):
_kwargs = func_manager.get_kwargs(goods_name)
model, kwargs = build_params(bot, event, goods_name, num, text)
2022-10-15 19:49:53 +08:00
return await func_manager.use(model, **kwargs)
2022-05-03 02:03:06 +08:00
# except Exception as e:
# logger.error(f"use 商品生效函数effect 发生错误 {type(e)}{e}")
2022-02-09 20:05:49 +08:00
return None
2022-01-05 22:32:59 +08:00
2022-10-15 19:49:53 +08:00
def register_use(goods_name: str, func: Callable, **kwargs):
2022-01-05 22:32:59 +08:00
"""
注册商品使用方法
:param goods_name: 商品名称
:param func: 使用函数
:param kwargs: kwargs
"""
2022-01-16 14:52:50 +08:00
if func_manager.exists(goods_name):
2022-01-05 22:32:59 +08:00
raise ValueError("该商品使用函数已被注册!")
2022-01-16 14:52:50 +08:00
# 发送使用成功信息
2022-05-03 02:03:06 +08:00
kwargs["send_success_msg"] = kwargs.get("send_success_msg", True)
2022-05-03 09:43:38 +08:00
kwargs["max_num_limit"] = kwargs.get("max_num_limit", 1)
2022-05-03 02:03:06 +08:00
func_manager.register_use(
goods_name,
**{
"func": func,
"model": create_model(f"{goods_name}_model", __base__=ShopParam, **kwargs),
"kwargs": kwargs,
},
2022-01-16 14:52:50 +08:00
)
logger.info(f"register_use 成功注册商品:{goods_name} 的使用函数")