zhenxun_bot/plugins/genshin/query_resource_points/__init__.py

104 lines
3.4 KiB
Python
Raw Normal View History

2021-05-20 19:34:27 +08:00
from nonebot import on_command, on_regex
2021-06-04 18:01:33 +08:00
from nonebot.rule import to_me
2021-07-30 21:21:51 +08:00
from .query_resource import get_resource_type_list, query_resource, init
2021-06-30 19:50:55 +08:00
from utils.utils import get_message_text, scheduler
2021-07-30 21:21:51 +08:00
from nonebot.adapters.cqhttp import Bot, MessageEvent, GroupMessageEvent, Message
2021-05-20 19:34:27 +08:00
from nonebot.typing import T_State
from services.log import logger
2021-08-17 23:17:08 +08:00
from nonebot.permission import SUPERUSER
2021-05-20 19:34:27 +08:00
import re
2021-07-30 21:21:51 +08:00
2021-05-20 19:34:27 +08:00
try:
import ujson as json
except ModuleNotFoundError:
import json
2021-07-30 21:21:51 +08:00
__plugin_name__ = "原神资源查询"
2021-06-15 10:57:08 +08:00
2021-07-30 21:21:51 +08:00
__plugin_usage__ = (
"用法:\n" "\t原神资源查询 [消息]\n" "\t原神资源列表\n" "\t[消息]在哪\n" "\t哪有[消息]\n" "[消息] = 资源名称"
)
2021-06-15 10:57:08 +08:00
2021-05-20 19:34:27 +08:00
qr = on_command("原神资源查询", priority=5, block=True)
qr_lst = on_command("原神资源列表", priority=5, block=True)
2021-07-30 21:21:51 +08:00
rex_qr = on_regex(".*?(在哪|在哪里|哪有|哪里有).*?", rule=to_me(), priority=5, block=True)
2021-08-17 23:17:08 +08:00
update_info = on_command('更新原神资源信息', permission=SUPERUSER, priority=1, block=True)
2021-05-20 19:34:27 +08:00
@qr.handle()
async def _(bot: Bot, event: MessageEvent, state: T_State):
resource_name = get_message_text(event.json())
2021-07-30 21:21:51 +08:00
await qr.send('正在生成位置....')
rst = await query_resource(resource_name)
await qr.send(Message(rst), at_sender=True)
2021-05-20 19:34:27 +08:00
logger.info(
2021-07-30 21:21:51 +08:00
f"(USER {event.user_id}, GROUP {event.group_id if isinstance(event, GroupMessageEvent) else 'private'})"
f" 查询原神材料:" + resource_name
)
2021-05-20 19:34:27 +08:00
@rex_qr.handle()
async def _(bot: Bot, event: MessageEvent, state: T_State):
msg = get_message_text(event.json())
2021-07-30 21:21:51 +08:00
if msg.find("在哪") != -1:
rs = re.search("(.*)在哪.*?", msg)
resource_name = rs.group(1) if rs else ""
2021-05-20 19:34:27 +08:00
else:
2021-07-30 21:21:51 +08:00
rs = re.search(".*?(哪有|哪里有)(.*)", msg)
resource_name = rs.group(2) if rs else ""
2021-05-20 19:34:27 +08:00
if resource_name:
2021-07-30 21:21:51 +08:00
await qr.send('正在生成位置....')
msg = await query_resource(resource_name)
await rex_qr.send(Message(msg), at_sender=True)
2021-05-20 19:34:27 +08:00
logger.info(
2021-07-30 21:21:51 +08:00
f"(USER {event.user_id}, GROUP {event.group_id if isinstance(event, GroupMessageEvent) else 'private'})"
f" 查询原神材料:" + resource_name
)
2021-05-20 19:34:27 +08:00
@qr_lst.handle()
async def _(bot: Bot, event: MessageEvent, state: T_State):
mes_list = []
2021-07-30 21:21:51 +08:00
txt = get_resource_type_list()
2021-05-20 19:34:27 +08:00
txt_list = txt.split("\n")
2021-07-30 21:21:51 +08:00
if event.message_type == "group":
2021-05-20 19:34:27 +08:00
for txt in txt_list:
data = {
"type": "node",
"data": {
"name": f"这里是{list(bot.config.nickname)[0]}",
"uin": f"{bot.self_id}",
2021-07-30 21:21:51 +08:00
"content": txt,
},
2021-05-20 19:34:27 +08:00
}
mes_list.append(data)
2021-07-30 21:21:51 +08:00
if isinstance(event, GroupMessageEvent):
2021-05-20 19:34:27 +08:00
await bot.send_group_forward_msg(group_id=event.group_id, messages=mes_list)
else:
2021-07-30 21:21:51 +08:00
rst = ""
2021-05-20 19:34:27 +08:00
for i in range(len(txt_list)):
2021-07-30 21:21:51 +08:00
rst += txt_list[i] + "\n"
2021-05-20 19:34:27 +08:00
if i % 5 == 0:
if rst:
await qr_lst.send(rst)
2021-07-30 21:21:51 +08:00
rst = ""
2021-05-20 19:34:27 +08:00
2021-07-30 21:21:51 +08:00
@update_info.handle()
async def _(bot: Bot, event: MessageEvent, state: T_State):
await init(True)
await update_info.send('更新原神资源信息完成...')
2021-05-20 19:34:27 +08:00
@scheduler.scheduled_job(
'cron',
hour=5,
minute=1,
)
async def _():
try:
2021-07-30 21:21:51 +08:00
await init()
2021-05-20 19:34:27 +08:00
logger.info(f'每日更新原神材料信息成功!')
except Exception as e:
logger.error(f'每日更新原神材料信息错误:{e}')