mirror of
https://github.com/zhayujie/chatgpt-on-wechat.git
synced 2026-06-15 03:04:34 +08:00
fix: remove prefix match in voice msg
This commit is contained in:
@@ -54,17 +54,23 @@ class WechatChannel(Channel):
|
||||
thread_pool.submit(self._do_handle_voice, msg)
|
||||
|
||||
def _do_handle_voice(self, msg):
|
||||
fileName = TmpDir().path() + msg['FileName']
|
||||
msg.download(fileName)
|
||||
content = super().build_voice_to_text(fileName)
|
||||
self._handle_single_msg(msg, content, conf().get('voice_reply_voice'))
|
||||
from_user_id = msg['FromUserName']
|
||||
other_user_id = msg['User']['UserName']
|
||||
if from_user_id == other_user_id:
|
||||
file_name = TmpDir().path() + msg['FileName']
|
||||
msg.download(file_name)
|
||||
query = super().build_voice_to_text(file_name)
|
||||
if conf().get('voice_reply_voice'):
|
||||
self._do_send_voice(query, from_user_id)
|
||||
else:
|
||||
self._do_send_text(query, from_user_id)
|
||||
|
||||
def handle_text(self, msg):
|
||||
logger.debug("[WX]receive text msg: " + json.dumps(msg, ensure_ascii=False))
|
||||
content = msg['Text']
|
||||
self._handle_single_msg(msg, content, False)
|
||||
self._handle_single_msg(msg, content)
|
||||
|
||||
def _handle_single_msg(self, msg, content, reply_voice=False):
|
||||
def _handle_single_msg(self, msg, content):
|
||||
from_user_id = msg['FromUserName']
|
||||
to_user_id = msg['ToUserName'] # 接收人id
|
||||
other_user_id = msg['User']['UserName'] # 对手方id
|
||||
@@ -83,8 +89,6 @@ class WechatChannel(Channel):
|
||||
if img_match_prefix:
|
||||
content = content.split(img_match_prefix, 1)[1].strip()
|
||||
thread_pool.submit(self._do_send_img, content, from_user_id)
|
||||
elif reply_voice:
|
||||
thread_pool.submit(self._do_send_voice, content, from_user_id)
|
||||
else :
|
||||
thread_pool.submit(self._do_send_text, content, from_user_id)
|
||||
elif to_user_id == other_user_id and match_prefix:
|
||||
@@ -96,8 +100,6 @@ class WechatChannel(Channel):
|
||||
if img_match_prefix:
|
||||
content = content.split(img_match_prefix, 1)[1].strip()
|
||||
thread_pool.submit(self._do_send_img, content, to_user_id)
|
||||
elif reply_voice:
|
||||
thread_pool.submit(self._do_send_voice, content, to_user_id)
|
||||
else:
|
||||
thread_pool.submit(self._do_send_text, content, to_user_id)
|
||||
|
||||
@@ -208,3 +210,4 @@ class WechatChannel(Channel):
|
||||
if content.find(ky) != -1:
|
||||
return True
|
||||
return None
|
||||
|
||||
|
||||
Reference in New Issue
Block a user