update v0.1.5.3

This commit is contained in:
HibiKier 2022-05-09 21:42:24 +08:00
parent 8029c00a02
commit b3b09ed666
8 changed files with 30 additions and 29 deletions

View File

@ -242,6 +242,11 @@ __Docker 最新版本由 [Sakuracio](https://github.com/Sakuracio) 提供__
## 更新 ## 更新
### 2022/5/9
* 替换了疫情API
* 修复了私聊.ban/.unban出错
### 2022/5/5 ### 2022/5/5
* 修改bilibili_sub插件在windows平台下报错 [@pull/153](https://github.com/HibiKier/zhenxun_bot/pull/153) * 修改bilibili_sub插件在windows平台下报错 [@pull/153](https://github.com/HibiKier/zhenxun_bot/pull/153)
@ -252,12 +257,13 @@ __Docker 最新版本由 [Sakuracio](https://github.com/Sakuracio) 提供__
* 添加商品注册装饰器shop_register * 添加商品注册装饰器shop_register
* 修复商品函数kwargs无法获取参数值 * 修复商品函数kwargs无法获取参数值
### 2022/5/1 ### 2022/5/1
* 删除了`group_last_chat`插件(该功能可由`chat_history`替代 * 删除了`group_last_chat`插件(该功能可由`chat_history`替代
* 新增敏感词检测(全新反击系统,是时候重拳出击了 * 新增敏感词检测(全新反击系统,是时候重拳出击了
### 2022/4/26 \[v0.5.1.0] ### 2022/4/26
* 修复了群白名单无法正确添加 * 修复了群白名单无法正确添加
* 优化了管理员帮助图片,背景图层将位于最下层 * 优化了管理员帮助图片,背景图层将位于最下层

View File

@ -1 +1 @@
__version__: v0.1.5.1 __version__: v0.1.5.3

View File

@ -125,11 +125,13 @@ async def _(
msg = arg.extract_plain_text().strip() msg = arg.extract_plain_text().strip()
if msg: if msg:
if str(event.user_id) in bot.config.superusers: if str(event.user_id) in bot.config.superusers:
if is_number(arg.extract_plain_text().strip().split()[0]): msg_splt = msg.split()
qq = int(msg[0]) if is_number(msg_splt[0]):
msg = msg[1:]
qq = int(msg_splt[0])
msg = msg_splt[1:]
if cmd in [".ban", "/ban"]: if cmd in [".ban", "/ban"]:
time = parse_ban_time(msg) time = parse_ban_time(" ".join(msg))
if isinstance(time, str): if isinstance(time, str):
await ban.finish(time) await ban.finish(time)
result = await a_ban(qq, time, str(qq), event, 9) result = await a_ban(qq, time, str(qq), event, 9)

View File

@ -25,7 +25,9 @@ def parse_ban_time(msg: str) -> Union[int, str]:
return int(msg[0]) * 60 * 60 + int(msg[1]) * 60 return int(msg[0]) * 60 * 60 + int(msg[1]) * 60
async def a_ban(qq: int, time: int, user_name: str, event: MessageEvent, ban_level: int = None) -> str: async def a_ban(
qq: int, time: int, user_name: str, event: MessageEvent, ban_level: int = None
) -> str:
""" """
ban ban
:param qq: qq :param qq: qq
@ -38,7 +40,8 @@ async def a_ban(qq: int, time: int, user_name: str, event: MessageEvent, ban_lev
ban_level = await LevelUser.get_user_level(event.user_id, event.group_id) ban_level = await LevelUser.get_user_level(event.user_id, event.group_id)
if await BanUser.ban(qq, ban_level, time): if await BanUser.ban(qq, ban_level, time):
logger.info( logger.info(
f"USER {event.user_id} GROUP {event.group_id} 将 USER {qq} 封禁 时长 {time / 60} 分钟" f"USER {event.user_id} GROUP"
f" {event.group_id if isinstance(event, GroupMessageEvent) else ''} 将 USER {qq} 封禁 时长 {time / 60} 分钟"
) )
result = f"已经将 {user_name} 加入{NICKNAME}的黑名单了!" result = f"已经将 {user_name} 加入{NICKNAME}的黑名单了!"
if time != -1: if time != -1:
@ -57,13 +60,3 @@ async def a_ban(qq: int, time: int, user_name: str, event: MessageEvent, ban_lev
time += " 分钟" time += " 分钟"
result = f"{user_name} 已在黑名单!预计 {time}后解封" result = f"{user_name} 已在黑名单!预计 {time}后解封"
return result return result

View File

@ -69,7 +69,7 @@ class GoodsUseFuncManager:
) )
else: else:
return self._data[goods_name]["func"]( return self._data[goods_name]["func"](
**kwargs, *parse_args(args)
) )
else: else:
if asyncio.iscoroutinefunction(self._data[goods_name]["func"]): if asyncio.iscoroutinefunction(self._data[goods_name]["func"]):

View File

@ -38,7 +38,7 @@ usage
__plugin_des__ = "非常便利的B站订阅通知" __plugin_des__ = "非常便利的B站订阅通知"
__plugin_cmd__ = ["添加订阅 [主播/UP/番剧] [id/链接/番名]", "删除订阅 [id]", "查看订阅"] __plugin_cmd__ = ["添加订阅 [主播/UP/番剧] [id/链接/番名]", "删除订阅 [id]", "查看订阅"]
__plugin_version__ = 0.1 __plugin_version__ = 0.1
__plugin_author__ = "HibiKier" __plugin_author__ = "HibiKier & NumberSir"
__plugin_settings__ = { __plugin_settings__ = {
"level": 5, "level": 5,
"default_status": True, "default_status": True,

View File

@ -49,7 +49,7 @@ __plugin_cmd__ = [
"查看词条 ?[问题/下标]", "查看词条 ?[问题/下标]",
] ]
__plugin_version__ = 0.2 __plugin_version__ = 0.2
__plugin_author__ = "HibiKier" __plugin_author__ = "HibiKier & yajiwa"
__plugin_settings__ = { __plugin_settings__ = {
"admin_level": Config.get_config("word_bank", "WORD_BANK_LEVEL [LEVEL]"), "admin_level": Config.get_config("word_bank", "WORD_BANK_LEVEL [LEVEL]"),
"cmd": ["词库问答", "添加词条", "删除词条", "修改词条", "查看词条"], "cmd": ["词库问答", "添加词条", "删除词条", "修改词条", "查看词条"],

View File

@ -11,7 +11,7 @@ china_city = TEXT_PATH / "china_city.json"
data = {} data = {}
url = "https://view.inews.qq.com/g2/getOnsInfo?name=disease_h5" url = "https://api.inews.qq.com/newsqa/v1/query/inner/publish/modules/list?modules=diseaseh5Shelf"
async def get_yiqing_data(area: str) -> Union[str, MessageSegment]: async def get_yiqing_data(area: str) -> Union[str, MessageSegment]:
@ -37,7 +37,7 @@ async def get_yiqing_data(area: str) -> Union[str, MessageSegment]:
if area in data[p]: if area in data[p]:
province = p province = p
city = area city = area
epidemic_data = json.loads((await AsyncHttpx.get(url)).json()["data"]) epidemic_data = (await AsyncHttpx.get(url)).json()["data"]["diseaseh5Shelf"]
last_update_time = epidemic_data["lastUpdateTime"] last_update_time = epidemic_data["lastUpdateTime"]
if area == "中国": if area == "中国":
data_ = epidemic_data["areaTree"][0] data_ = epidemic_data["areaTree"][0]
@ -59,12 +59,12 @@ async def get_yiqing_data(area: str) -> Union[str, MessageSegment]:
add_confirm = data_["today"]["confirm"] # 新增确诊 add_confirm = data_["today"]["confirm"] # 新增确诊
grade = "" grade = ""
_grade_color = "" _grade_color = ""
if data_["total"].get("grade"): # if data_["total"].get("grade"):
grade = data_["total"]["grade"] # grade = data_["total"]["grade"]
if "中风险" in grade: # if "中风险" in grade:
_grade_color = "#fa9424" # _grade_color = "#fa9424"
else: # else:
_grade_color = "red" # _grade_color = "red"
dead_rate = f"{dead / confirm * 100:.2f}" # 死亡率 dead_rate = f"{dead / confirm * 100:.2f}" # 死亡率
heal_rate = f"{heal / confirm * 100:.2f}" # 治愈率 heal_rate = f"{heal / confirm * 100:.2f}" # 治愈率