Browse Source

fix: group chat bug

master
lanvent 1 year ago
parent
commit
7a94745b8a
2 changed files with 30 additions and 14 deletions
  1. +28
    -14
      channel/wechat/wechat_channel.py
  2. +2
    -0
      config.py

+ 28
- 14
channel/wechat/wechat_channel.py View File

@@ -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: # 判断如果匹配到自定义前缀,则返回过滤掉前缀+空格后的内容


+ 2
- 0
config.py View File

@@ -70,6 +70,8 @@ available_setting = {

# chatgpt指令自定义触发词
"clear_memory_commands": ['#清除记忆'], # 重置会话指令

# channel配置
"channel_type": "wx", # 通道类型,支持wx,wxy和terminal




Loading…
Cancel
Save