mirror of
https://github.com/RockChinQ/QChatGPT.git
synced 2024-11-16 03:32:33 +08:00
refactor: yirimirai 适配器实现异步
This commit is contained in:
parent
8d35ecd711
commit
ad5ef95e65
|
@ -7,6 +7,7 @@ from ..openai import manager as openai_mgr
|
||||||
from ..config import manager as config_mgr
|
from ..config import manager as config_mgr
|
||||||
from ..database import manager as database_mgr
|
from ..database import manager as database_mgr
|
||||||
from ..utils.center import v2 as center_mgr
|
from ..utils.center import v2 as center_mgr
|
||||||
|
from ..plugin import host as plugin_host
|
||||||
|
|
||||||
|
|
||||||
class Application:
|
class Application:
|
||||||
|
@ -28,4 +29,7 @@ class Application:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
async def run(self):
|
async def run(self):
|
||||||
pass
|
# TODO make it async
|
||||||
|
plugin_host.initialize_plugins()
|
||||||
|
|
||||||
|
await self.im_mgr.run()
|
|
@ -44,4 +44,11 @@ async def init_logging() -> logging.Logger:
|
||||||
)
|
)
|
||||||
qcg_logger.addHandler(handler)
|
qcg_logger.addHandler(handler)
|
||||||
|
|
||||||
|
logging.basicConfig(level=level, # 设置日志输出格式
|
||||||
|
format="[DEPR][%(asctime)s.%(msecs)03d] %(pathname)s (%(lineno)d) - [%(levelname)s] :\n%(message)s",
|
||||||
|
# 日志输出的格式
|
||||||
|
# -8表示占位符,让输出左对齐,输出长度都为8位
|
||||||
|
datefmt="%Y-%m-%d %H:%M:%S" # 时间输出的格式
|
||||||
|
)
|
||||||
|
|
||||||
return qcg_logger
|
return qcg_logger
|
|
@ -1,15 +1,16 @@
|
||||||
# MessageSource的适配器
|
# MessageSource的适配器
|
||||||
import typing
|
import typing
|
||||||
|
import abc
|
||||||
|
|
||||||
import mirai
|
import mirai
|
||||||
|
|
||||||
|
|
||||||
class MessageSourceAdapter:
|
class MessageSourceAdapter(metaclass=abc.ABCMeta):
|
||||||
bot_account_id: int
|
bot_account_id: int
|
||||||
def __init__(self, config: dict):
|
def __init__(self, config: dict):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def send_message(
|
async def send_message(
|
||||||
self,
|
self,
|
||||||
target_type: str,
|
target_type: str,
|
||||||
target_id: str,
|
target_id: str,
|
||||||
|
@ -24,7 +25,7 @@ class MessageSourceAdapter:
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def reply_message(
|
async def reply_message(
|
||||||
self,
|
self,
|
||||||
message_source: mirai.MessageEvent,
|
message_source: mirai.MessageEvent,
|
||||||
message: mirai.MessageChain,
|
message: mirai.MessageChain,
|
||||||
|
@ -39,7 +40,7 @@ class MessageSourceAdapter:
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def is_muted(self, group_id: int) -> bool:
|
async def is_muted(self, group_id: int) -> bool:
|
||||||
"""获取账号是否在指定群被禁言"""
|
"""获取账号是否在指定群被禁言"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
|
@ -69,8 +70,8 @@ class MessageSourceAdapter:
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def run_sync(self):
|
async def run_async(self):
|
||||||
"""以阻塞的方式运行适配器"""
|
"""异步运行"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def kill(self) -> bool:
|
def kill(self) -> bool:
|
||||||
|
|
|
@ -3,6 +3,7 @@ from __future__ import annotations
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
import logging
|
import logging
|
||||||
|
import asyncio
|
||||||
|
|
||||||
from mirai import At, GroupMessage, MessageEvent, StrangerMessage, \
|
from mirai import At, GroupMessage, MessageEvent, StrangerMessage, \
|
||||||
FriendMessage, Image, MessageChain, Plain
|
FriendMessage, Image, MessageChain, Plain
|
||||||
|
@ -138,9 +139,9 @@ class QQBotManager:
|
||||||
|
|
||||||
# 注册诸事件
|
# 注册诸事件
|
||||||
# Caution: 注册新的事件处理器之后,请务必在unsubscribe_all中编写相应的取消订阅代码
|
# Caution: 注册新的事件处理器之后,请务必在unsubscribe_all中编写相应的取消订阅代码
|
||||||
def on_friend_message(event: FriendMessage):
|
async def on_friend_message(event: FriendMessage):
|
||||||
|
|
||||||
def friend_message_handler():
|
async def friend_message_handler():
|
||||||
# 触发事件
|
# 触发事件
|
||||||
args = {
|
args = {
|
||||||
"launcher_type": "person",
|
"launcher_type": "person",
|
||||||
|
@ -153,19 +154,21 @@ class QQBotManager:
|
||||||
if plugin_event.is_prevented_default():
|
if plugin_event.is_prevented_default():
|
||||||
return
|
return
|
||||||
|
|
||||||
self.on_person_message(event)
|
await self.on_person_message(event)
|
||||||
|
|
||||||
context.get_thread_ctl().submit_user_task(
|
asyncio.create_task(friend_message_handler())
|
||||||
friend_message_handler,
|
# TODO delete this
|
||||||
)
|
# context.get_thread_ctl().submit_user_task(
|
||||||
|
# friend_message_handler,
|
||||||
|
# )
|
||||||
self.adapter.register_listener(
|
self.adapter.register_listener(
|
||||||
FriendMessage,
|
FriendMessage,
|
||||||
on_friend_message
|
on_friend_message
|
||||||
)
|
)
|
||||||
|
|
||||||
def on_stranger_message(event: StrangerMessage):
|
async def on_stranger_message(event: StrangerMessage):
|
||||||
|
|
||||||
def stranger_message_handler():
|
async def stranger_message_handler():
|
||||||
# 触发事件
|
# 触发事件
|
||||||
args = {
|
args = {
|
||||||
"launcher_type": "person",
|
"launcher_type": "person",
|
||||||
|
@ -178,11 +181,13 @@ class QQBotManager:
|
||||||
if plugin_event.is_prevented_default():
|
if plugin_event.is_prevented_default():
|
||||||
return
|
return
|
||||||
|
|
||||||
self.on_person_message(event)
|
await self.on_person_message(event)
|
||||||
|
|
||||||
context.get_thread_ctl().submit_user_task(
|
asyncio.create_task(stranger_message_handler())
|
||||||
stranger_message_handler,
|
# TODO delete this
|
||||||
)
|
# context.get_thread_ctl().submit_user_task(
|
||||||
|
# stranger_message_handler,
|
||||||
|
# )
|
||||||
# nakuru不区分好友和陌生人,故仅为yirimirai注册陌生人事件
|
# nakuru不区分好友和陌生人,故仅为yirimirai注册陌生人事件
|
||||||
if config['msg_source_adapter'] == 'yirimirai':
|
if config['msg_source_adapter'] == 'yirimirai':
|
||||||
self.adapter.register_listener(
|
self.adapter.register_listener(
|
||||||
|
@ -190,9 +195,9 @@ class QQBotManager:
|
||||||
on_stranger_message
|
on_stranger_message
|
||||||
)
|
)
|
||||||
|
|
||||||
def on_group_message(event: GroupMessage):
|
async def on_group_message(event: GroupMessage):
|
||||||
|
|
||||||
def group_message_handler(event: GroupMessage):
|
async def group_message_handler(event: GroupMessage):
|
||||||
# 触发事件
|
# 触发事件
|
||||||
args = {
|
args = {
|
||||||
"launcher_type": "group",
|
"launcher_type": "group",
|
||||||
|
@ -205,12 +210,14 @@ class QQBotManager:
|
||||||
if plugin_event.is_prevented_default():
|
if plugin_event.is_prevented_default():
|
||||||
return
|
return
|
||||||
|
|
||||||
self.on_group_message(event)
|
await self.on_group_message(event)
|
||||||
|
|
||||||
context.get_thread_ctl().submit_user_task(
|
asyncio.create_task(group_message_handler(event))
|
||||||
group_message_handler,
|
# TODO delete this
|
||||||
event
|
# context.get_thread_ctl().submit_user_task(
|
||||||
)
|
# group_message_handler,
|
||||||
|
# event
|
||||||
|
# )
|
||||||
self.adapter.register_listener(
|
self.adapter.register_listener(
|
||||||
GroupMessage,
|
GroupMessage,
|
||||||
on_group_message
|
on_group_message
|
||||||
|
@ -264,7 +271,7 @@ class QQBotManager:
|
||||||
else:
|
else:
|
||||||
self.reply_filter = qqbot_filter.ReplyFilter([])
|
self.reply_filter = qqbot_filter.ReplyFilter([])
|
||||||
|
|
||||||
def send(self, event, msg, check_quote=True, check_at_sender=True):
|
async def send(self, event, msg, check_quote=True, check_at_sender=True):
|
||||||
config = context.get_config_manager().data
|
config = context.get_config_manager().data
|
||||||
|
|
||||||
if check_at_sender and config['at_sender']:
|
if check_at_sender and config['at_sender']:
|
||||||
|
@ -282,14 +289,14 @@ class QQBotManager:
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
self.adapter.reply_message(
|
await self.adapter.reply_message(
|
||||||
event,
|
event,
|
||||||
msg,
|
msg,
|
||||||
quote_origin=True if config['quote_origin'] and check_quote else False
|
quote_origin=True if config['quote_origin'] and check_quote else False
|
||||||
)
|
)
|
||||||
|
|
||||||
# 私聊消息处理
|
# 私聊消息处理
|
||||||
def on_person_message(self, event: MessageEvent):
|
async def on_person_message(self, event: MessageEvent):
|
||||||
reply = ''
|
reply = ''
|
||||||
|
|
||||||
config = context.get_config_manager().data
|
config = context.get_config_manager().data
|
||||||
|
@ -307,14 +314,14 @@ class QQBotManager:
|
||||||
for i in range(self.retry):
|
for i in range(self.retry):
|
||||||
try:
|
try:
|
||||||
|
|
||||||
@func_timeout.func_set_timeout(config['process_message_timeout'])
|
# @func_timeout.func_set_timeout(config['process_message_timeout'])
|
||||||
def time_ctrl_wrapper():
|
async def time_ctrl_wrapper():
|
||||||
reply = processor.process_message('person', event.sender.id, str(event.message_chain),
|
reply = await processor.process_message('person', event.sender.id, str(event.message_chain),
|
||||||
event.message_chain,
|
event.message_chain,
|
||||||
event.sender.id)
|
event.sender.id)
|
||||||
return reply
|
return reply
|
||||||
|
|
||||||
reply = time_ctrl_wrapper()
|
reply = await time_ctrl_wrapper()
|
||||||
break
|
break
|
||||||
except func_timeout.FunctionTimedOut:
|
except func_timeout.FunctionTimedOut:
|
||||||
logging.warning("person_{}: 超时,重试中({})".format(event.sender.id, i))
|
logging.warning("person_{}: 超时,重试中({})".format(event.sender.id, i))
|
||||||
|
@ -330,15 +337,15 @@ class QQBotManager:
|
||||||
reply = [tips_custom.reply_message]
|
reply = [tips_custom.reply_message]
|
||||||
|
|
||||||
if reply:
|
if reply:
|
||||||
return self.send(event, reply, check_quote=False, check_at_sender=False)
|
await self.send(event, reply, check_quote=False, check_at_sender=False)
|
||||||
|
|
||||||
# 群消息处理
|
# 群消息处理
|
||||||
def on_group_message(self, event: GroupMessage):
|
async def on_group_message(self, event: GroupMessage):
|
||||||
reply = ''
|
reply = ''
|
||||||
|
|
||||||
config = context.get_config_manager().data
|
config = context.get_config_manager().data
|
||||||
|
|
||||||
def process(text=None) -> str:
|
async def process(text=None) -> str:
|
||||||
replys = ""
|
replys = ""
|
||||||
if At(self.bot_account_id) in event.message_chain:
|
if At(self.bot_account_id) in event.message_chain:
|
||||||
event.message_chain.remove(At(self.bot_account_id))
|
event.message_chain.remove(At(self.bot_account_id))
|
||||||
|
@ -347,15 +354,15 @@ class QQBotManager:
|
||||||
failed = 0
|
failed = 0
|
||||||
for i in range(self.retry):
|
for i in range(self.retry):
|
||||||
try:
|
try:
|
||||||
@func_timeout.func_set_timeout(config['process_message_timeout'])
|
# @func_timeout.func_set_timeout(config['process_message_timeout'])
|
||||||
def time_ctrl_wrapper():
|
async def time_ctrl_wrapper():
|
||||||
replys = processor.process_message('group', event.group.id,
|
replys = await processor.process_message('group', event.group.id,
|
||||||
str(event.message_chain).strip() if text is None else text,
|
str(event.message_chain).strip() if text is None else text,
|
||||||
event.message_chain,
|
event.message_chain,
|
||||||
event.sender.id)
|
event.sender.id)
|
||||||
return replys
|
return replys
|
||||||
|
|
||||||
replys = time_ctrl_wrapper()
|
replys = await time_ctrl_wrapper()
|
||||||
break
|
break
|
||||||
except func_timeout.FunctionTimedOut:
|
except func_timeout.FunctionTimedOut:
|
||||||
logging.warning("group_{}: 超时,重试中({})".format(event.group.id, i))
|
logging.warning("group_{}: 超时,重试中({})".format(event.group.id, i))
|
||||||
|
@ -379,22 +386,22 @@ class QQBotManager:
|
||||||
else:
|
else:
|
||||||
if At(self.bot_account_id) in event.message_chain and response_at(event.group.id):
|
if At(self.bot_account_id) in event.message_chain and response_at(event.group.id):
|
||||||
# 直接调用
|
# 直接调用
|
||||||
reply = process()
|
reply = await process()
|
||||||
else:
|
else:
|
||||||
check, result = check_response_rule(event.group.id, str(event.message_chain).strip())
|
check, result = check_response_rule(event.group.id, str(event.message_chain).strip())
|
||||||
|
|
||||||
if check:
|
if check:
|
||||||
reply = process(result.strip())
|
reply = await process(result.strip())
|
||||||
# 检查是否随机响应
|
# 检查是否随机响应
|
||||||
elif random_responding(event.group.id):
|
elif random_responding(event.group.id):
|
||||||
logging.info("随机响应group_{}消息".format(event.group.id))
|
logging.info("随机响应group_{}消息".format(event.group.id))
|
||||||
reply = process()
|
reply = await process()
|
||||||
|
|
||||||
if reply:
|
if reply:
|
||||||
return self.send(event, reply)
|
await self.send(event, reply)
|
||||||
|
|
||||||
# 通知系统管理员
|
# 通知系统管理员
|
||||||
def notify_admin(self, message: str):
|
async def notify_admin(self, message: str):
|
||||||
config = context.get_config_manager().data
|
config = context.get_config_manager().data
|
||||||
if config['admin_qq'] != 0 and config['admin_qq'] != []:
|
if config['admin_qq'] != 0 and config['admin_qq'] != []:
|
||||||
logging.info("通知管理员:{}".format(message))
|
logging.info("通知管理员:{}".format(message))
|
||||||
|
@ -412,7 +419,7 @@ class QQBotManager:
|
||||||
MessageChain([Plain("[bot]{}".format(message))])
|
MessageChain([Plain("[bot]{}".format(message))])
|
||||||
)
|
)
|
||||||
|
|
||||||
def notify_admin_message_chain(self, message):
|
async def notify_admin_message_chain(self, message):
|
||||||
config = context.get_config_manager().data
|
config = context.get_config_manager().data
|
||||||
if config['admin_qq'] != 0 and config['admin_qq'] != []:
|
if config['admin_qq'] != 0 and config['admin_qq'] != []:
|
||||||
logging.info("通知管理员:{}".format(message))
|
logging.info("通知管理员:{}".format(message))
|
||||||
|
@ -429,3 +436,6 @@ class QQBotManager:
|
||||||
adm,
|
adm,
|
||||||
message
|
message
|
||||||
)
|
)
|
||||||
|
|
||||||
|
async def run(self):
|
||||||
|
await self.adapter.run_async()
|
|
@ -36,7 +36,7 @@ def is_admin(qq: int) -> bool:
|
||||||
return qq == config['admin_qq']
|
return qq == config['admin_qq']
|
||||||
|
|
||||||
|
|
||||||
def process_message(launcher_type: str, launcher_id: int, text_message: str, message_chain: mirai.MessageChain,
|
async def process_message(launcher_type: str, launcher_id: int, text_message: str, message_chain: mirai.MessageChain,
|
||||||
sender_id: int) -> mirai.MessageChain:
|
sender_id: int) -> mirai.MessageChain:
|
||||||
global processing
|
global processing
|
||||||
|
|
||||||
|
@ -61,7 +61,7 @@ def process_message(launcher_type: str, launcher_id: int, text_message: str, mes
|
||||||
|
|
||||||
# 检查是否被禁言
|
# 检查是否被禁言
|
||||||
if launcher_type == 'group':
|
if launcher_type == 'group':
|
||||||
is_muted = mgr.adapter.is_muted(launcher_id)
|
is_muted = await mgr.adapter.is_muted(launcher_id)
|
||||||
if is_muted:
|
if is_muted:
|
||||||
logging.info("机器人被禁言,跳过消息处理(group_{})".format(launcher_id))
|
logging.info("机器人被禁言,跳过消息处理(group_{})".format(launcher_id))
|
||||||
return reply
|
return reply
|
||||||
|
|
|
@ -324,5 +324,8 @@ class NakuruProjectAdapter(adapter_model.MessageSourceAdapter):
|
||||||
asyncio.set_event_loop(loop)
|
asyncio.set_event_loop(loop)
|
||||||
self.bot.run()
|
self.bot.run()
|
||||||
|
|
||||||
|
async def run_async(self):
|
||||||
|
return await self.bot._run()
|
||||||
|
|
||||||
def kill(self) -> bool:
|
def kill(self) -> bool:
|
||||||
return False
|
return False
|
||||||
|
|
|
@ -36,7 +36,7 @@ class YiriMiraiAdapter(adapter_model.MessageSourceAdapter):
|
||||||
else:
|
else:
|
||||||
raise Exception('Unknown adapter for YiriMirai: ' + config['adapter'])
|
raise Exception('Unknown adapter for YiriMirai: ' + config['adapter'])
|
||||||
|
|
||||||
def send_message(
|
async def send_message(
|
||||||
self,
|
self,
|
||||||
target_type: str,
|
target_type: str,
|
||||||
target_id: str,
|
target_id: str,
|
||||||
|
@ -57,9 +57,9 @@ class YiriMiraiAdapter(adapter_model.MessageSourceAdapter):
|
||||||
else:
|
else:
|
||||||
raise Exception('Unknown target type: ' + target_type)
|
raise Exception('Unknown target type: ' + target_type)
|
||||||
|
|
||||||
asyncio.run(task)
|
await task
|
||||||
|
|
||||||
def reply_message(
|
async def reply_message(
|
||||||
self,
|
self,
|
||||||
message_source: mirai.MessageEvent,
|
message_source: mirai.MessageEvent,
|
||||||
message: mirai.MessageChain,
|
message: mirai.MessageChain,
|
||||||
|
@ -72,11 +72,10 @@ class YiriMiraiAdapter(adapter_model.MessageSourceAdapter):
|
||||||
message (mirai.MessageChain): YiriMirai库的消息链
|
message (mirai.MessageChain): YiriMirai库的消息链
|
||||||
quote_origin (bool, optional): 是否引用原消息. Defaults to False.
|
quote_origin (bool, optional): 是否引用原消息. Defaults to False.
|
||||||
"""
|
"""
|
||||||
asyncio.run(self.bot.send(message_source, message, quote_origin))
|
await self.bot.send(message_source, message, quote_origin)
|
||||||
|
|
||||||
def is_muted(self, group_id: int) -> bool:
|
async def is_muted(self, group_id: int) -> bool:
|
||||||
result = self.bot.member_info(target=group_id, member_id=self.bot.qq).get()
|
result = await self.bot.member_info(target=group_id, member_id=self.bot.qq).get()
|
||||||
result = asyncio.run(result)
|
|
||||||
if result.mute_time_remaining > 0:
|
if result.mute_time_remaining > 0:
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
@ -111,13 +110,8 @@ class YiriMiraiAdapter(adapter_model.MessageSourceAdapter):
|
||||||
|
|
||||||
bus.unsubscribe(event_type, callback)
|
bus.unsubscribe(event_type, callback)
|
||||||
|
|
||||||
def run_sync(self):
|
async def run_async(self):
|
||||||
"""运行YiriMirai"""
|
return await MiraiRunner(self.bot)._run()
|
||||||
|
|
||||||
# 创建新的
|
|
||||||
loop = asyncio.new_event_loop()
|
|
||||||
|
|
||||||
loop.run_until_complete(MiraiRunner(self.bot)._run())
|
|
||||||
|
|
||||||
def kill(self) -> bool:
|
def kill(self) -> bool:
|
||||||
return False
|
return False
|
||||||
|
|
Loading…
Reference in New Issue
Block a user