|
|
@@ -19,6 +19,7 @@ from common.log import logger |
|
|
|
from common.tmp_dir import TmpDir |
|
|
|
from config import conf |
|
|
|
from common.time_check import time_checker |
|
|
|
from common.expired_dict import ExpiredDict |
|
|
|
from plugins import * |
|
|
|
try: |
|
|
|
from voice.audio_convert import mp3_to_wav |
|
|
@@ -53,12 +54,27 @@ def handler_group_voice(msg): |
|
|
|
WechatChannel().handle_group_voice(msg) |
|
|
|
return None |
|
|
|
|
|
|
|
def _check(func): |
|
|
|
def wrapper(self, msg): |
|
|
|
msgId = msg['MsgId'] |
|
|
|
if msgId in self.receivedMsgs: |
|
|
|
logger.info("Wechat message {} already received, ignore".format(msgId)) |
|
|
|
return |
|
|
|
self.receivedMsgs[msgId] = msg |
|
|
|
create_time = msg['CreateTime'] # 消息时间 |
|
|
|
if conf().get('hot_reload') == True and int(create_time) < int(time.time()) - 60: # 跳过1分钟前的历史消息 |
|
|
|
logger.debug("[WX]history message {} skipped".format(msgId)) |
|
|
|
return |
|
|
|
print(create_time) |
|
|
|
return func(self, msg) |
|
|
|
return wrapper |
|
|
|
|
|
|
|
|
|
|
|
class WechatChannel(Channel): |
|
|
|
def __init__(self): |
|
|
|
self.userName = None |
|
|
|
self.nickName = None |
|
|
|
self.receivedMsgs = ExpiredDict(60*60*24) |
|
|
|
|
|
|
|
def startup(self): |
|
|
|
|
|
|
@@ -93,6 +109,8 @@ class WechatChannel(Channel): |
|
|
|
# origin_ctype: 原始消息类型,用于私聊语音消息时,避免匹配前缀 |
|
|
|
# desire_rtype: 希望回复类型,TEXT类型是文本回复,VOICE类型是语音回复 |
|
|
|
|
|
|
|
@time_checker |
|
|
|
@_check |
|
|
|
def handle_voice(self, msg): |
|
|
|
if conf().get('speech_recognition') != True: |
|
|
|
return |
|
|
@@ -113,6 +131,7 @@ class WechatChannel(Channel): |
|
|
|
thread_pool.submit(self.handle, context).add_done_callback(thread_pool_callback) |
|
|
|
|
|
|
|
@time_checker |
|
|
|
@_check |
|
|
|
def handle_text(self, msg): |
|
|
|
logger.debug("[WX]receive text msg: " + json.dumps(msg, ensure_ascii=False)) |
|
|
|
content = msg['Text'] |
|
|
@@ -126,10 +145,6 @@ class WechatChannel(Channel): |
|
|
|
other_user_id = to_user_id |
|
|
|
else: |
|
|
|
other_user_id = from_user_id |
|
|
|
create_time = msg['CreateTime'] # 消息时间 |
|
|
|
if conf().get('hot_reload') == True and int(create_time) < int(time.time()) - 60: # 跳过1分钟前的历史消息 |
|
|
|
logger.debug("[WX]history message skipped") |
|
|
|
return |
|
|
|
if "」\n- - - - - - - - - - - - - - -" in content: |
|
|
|
logger.debug("[WX]reference query skipped") |
|
|
|
return |
|
|
@@ -139,14 +154,11 @@ class WechatChannel(Channel): |
|
|
|
thread_pool.submit(self.handle, context).add_done_callback(thread_pool_callback) |
|
|
|
|
|
|
|
@time_checker |
|
|
|
@_check |
|
|
|
def handle_group(self, msg): |
|
|
|
logger.debug("[WX]receive group msg: " + json.dumps(msg, ensure_ascii=False)) |
|
|
|
group_name = msg['User'].get('NickName', None) |
|
|
|
group_id = msg['User'].get('UserName', None) |
|
|
|
create_time = msg['CreateTime'] # 消息时间 |
|
|
|
if conf().get('hot_reload') == True and int(create_time) < int(time.time()) - 60: # 跳过1分钟前的历史消息 |
|
|
|
logger.debug("[WX]history group message skipped") |
|
|
|
return |
|
|
|
if not group_name: |
|
|
|
return "" |
|
|
|
origin_content = msg['Content'] |
|
|
@@ -165,7 +177,7 @@ class WechatChannel(Channel): |
|
|
|
group_name_white_list = config.get('group_name_white_list', []) |
|
|
|
group_name_keyword_white_list = config.get('group_name_keyword_white_list', []) |
|
|
|
|
|
|
|
if any([group_name in group_name_white_list, 'ALL_GROUP' in group_name_white_list, check_contain(group_name, group_name_keyword_white_list), msg['IsAt'] and not config.get("group_at_off", False)]): |
|
|
|
if any([group_name in group_name_white_list, 'ALL_GROUP' in group_name_white_list, check_contain(group_name, group_name_keyword_white_list)]): |
|
|
|
group_chat_in_one_session = conf().get('group_chat_in_one_session', []) |
|
|
|
session_id = msg['ActualUserName'] |
|
|
|
if any([group_name in group_chat_in_one_session, 'ALL_GROUP' in group_chat_in_one_session]): |
|
|
@@ -173,17 +185,15 @@ class WechatChannel(Channel): |
|
|
|
context = self._compose_context(ContextType.TEXT, content, isgroup=True, msg=msg, receiver=group_id, session_id=session_id) |
|
|
|
if context: |
|
|
|
thread_pool.submit(self.handle, context).add_done_callback(thread_pool_callback) |
|
|
|
|
|
|
|
|
|
|
|
@time_checker |
|
|
|
@_check |
|
|
|
def handle_group_voice(self, msg): |
|
|
|
if conf().get('group_speech_recognition', False) != True: |
|
|
|
return |
|
|
|
logger.debug("[WX]receive voice for group msg: " + msg['FileName']) |
|
|
|
group_name = msg['User'].get('NickName', None) |
|
|
|
group_id = msg['User'].get('UserName', None) |
|
|
|
create_time = msg['CreateTime'] # 消息时间 |
|
|
|
if conf().get('hot_reload') == True and int(create_time) < int(time.time()) - 60: #跳过1分钟前的历史消息 |
|
|
|
logger.debug("[WX]history group voice skipped") |
|
|
|
return |
|
|
|
# 验证群名 |
|
|
|
if not group_name: |
|
|
|
return "" |
|
|
@@ -215,9 +225,13 @@ class WechatChannel(Channel): |
|
|
|
# 判断如果匹配到自定义前缀,则返回过滤掉前缀+空格后的内容,用于实现类似自定义+前缀触发生成AI图片的功能 |
|
|
|
if match_prefix: |
|
|
|
content = content.replace(match_prefix, '', 1).strip() |
|
|
|
elif context['msg']['IsAt'] and not conf().get("group_at_off", False): |
|
|
|
logger.info("[WX]receive group at, continue") |
|
|
|
elif context["origin_ctype"] == ContextType.VOICE: |
|
|
|
logger.info("[WX]receive group voice, checkprefix didn't match") |
|
|
|
return None |
|
|
|
else: |
|
|
|
return None |
|
|
|
else: # 单聊 |
|
|
|
match_prefix = check_prefix(content, conf().get('single_chat_prefix')) |
|
|
|
if match_prefix: # 判断如果匹配到自定义前缀,则返回过滤掉前缀+空格后的内容 |
|
|
|