diff --git a/app_chatgpt/models/mail_channel.py b/app_chatgpt/models/mail_channel.py index 678a5311..c8474c7b 100644 --- a/app_chatgpt/models/mail_channel.py +++ b/app_chatgpt/models/mail_channel.py @@ -65,7 +65,9 @@ class Channel(models.Model): param = self.get_ai_config(ai) res, usage, is_ai = ai.get_ai(messages, author_id, answer_id, param) if res: - res = res.replace('\n', '
') + if self.get_ua_type() != 'wxweb': + # 处理当微信语音返回时,是直接回文本信息,不需要转换回车 + res = res.replace('\n', '
') new_msg = channel.with_user(user_id).message_post(body=res, message_type='comment', subtype_xmlid='mail.mt_comment', parent_id=message.id) if usage: prompt_tokens = usage['prompt_tokens'] diff --git a/app_common/controllers/main.py b/app_common/controllers/main.py index c4e4fc3f..8514bae8 100644 --- a/app_common/controllers/main.py +++ b/app_common/controllers/main.py @@ -6,7 +6,7 @@ import requests from math import radians, cos, sin, asin, sqrt from ..lib.user_agents import parse -from ..models.ir_http import get_ua_type +from ..models.base import get_ua_type from odoo import api, http, SUPERUSER_ID, _ @@ -28,7 +28,7 @@ class AppController(http.Controller): # 返回这个图片的base64编码 return base64.b64encode(BytesIO(response.content).read()) - @http.route(['/web/ua', '/web/ua/show'], auth='public', methods=['GET']) + @http.route(['/my/ua', '/web/ua', '/web/ua/show'], auth='public', methods=['GET']) def app_ua_show(self): # https://github.com/selwin/python-user-agents ua_string = request.httprequest.headers.get('User-Agent') diff --git a/app_common/models/base.py b/app_common/models/base.py index 6680af91..970b5877 100644 --- a/app_common/models/base.py +++ b/app_common/models/base.py @@ -1,6 +1,7 @@ # -*- coding: utf-8 -*- from odoo import models, fields, api, _ from odoo.tools import DEFAULT_SERVER_DATE_FORMAT, DEFAULT_SERVER_DATETIME_FORMAT +from odoo.http import request import requests import base64 @@ -108,3 +109,47 @@ class Base(models.AbstractModel): return None # 返回这个图片的base64编码 return base64.b64encode(BytesIO(response.content).read()) + + def get_ua_type(self): + return get_ua_type() + + +def get_ua_type(): + ua = request.httprequest.headers.get('User-Agent') + # 临时用 agent 处理,后续要前端中正确处理或者都从后台来 + # 微信浏览器 + # MicroMessenger: Mozilla/5.0 (Linux; Android 10; ELE-AL00 Build/HUAWEIELE-AL00; wv) + # AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/77.0.3865.120 + # MQQBrowser/6.2 TBS/045525 Mobile Safari/537.36 MMWEBID/3135 MicroMessenger/8.0.2.1860(0x2800023B) Process/tools WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 + # 微信浏览器,开发工具,网页 iphone + # ,Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1 + # wechatdevtools/1.03.2011120 MicroMessenger/7.0.4 Language/zh_CN webview/16178807094901773 + # webdebugger port/27772 token/b91f4a234b918f4e2a5d1a835a09c31e + + # 微信小程序 + # MicroMessenger: Mozilla/5.0 (Linux; Android 10; ELE-AL00 Build/HUAWEIELE-AL00; wv) + # AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/78.0.3904.62 XWEB/2767 MMWEBSDK/20210302 Mobile Safari/537.36 MMWEBID/6689 MicroMessenger/8.0.2.1860(0x2800023B) Process/appbrand2 WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 + # MiniProgramEnv/android + # 微信浏览器,开发工具,小程序,iphone + # Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1 + # wechatdevtools/1.03.2011120 MicroMessenger/7.0.4 Language/zh_CN webview/ + # 微信内,iphone web + # Mozilla/5.0 (iPhone; CPU iPhone OS 14_4_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 + # MicroMessenger/8.0.3(0x1800032a) NetType/WIFI Language/zh_CN + # 安卓app,h5 + # ELE-AL00(Android/10) (cn.erpapp.o20sticks.App/13.20.12.09) Weex/0.26.0 1080x2265 + + # web 表示普通浏览器,后续更深入处理 + utype = 'web' + # todo: 引入现成 py lib,处理企业微信 + if 'MicroMessenger' in ua and 'webdebugger' not in ua and ('MiniProgramEnv' in ua or 'wechatdevtools' in ua): + # 微信小程序及开发者工具 + utype = 'wxapp' + elif 'MicroMessenger' in ua: + # 微信浏览器 + utype = 'wxweb' + elif 'cn.erpapp.o20sticks.App' in ua: + # 安卓app + utype = 'native_android' + # _logger.warning('=========get ua %s,%s' % (utype, ua)) + return utype diff --git a/app_common/models/ir_http.py b/app_common/models/ir_http.py index 833d433c..565d83ed 100644 --- a/app_common/models/ir_http.py +++ b/app_common/models/ir_http.py @@ -14,45 +14,4 @@ class IrHttp(models.AbstractModel): result['ua_type'] = self.get_ua_type() return result - def get_ua_type(self): - return get_ua_type() -def get_ua_type(): - ua = request.httprequest.headers.get('User-Agent') - # 临时用 agent 处理,后续要前端中正确处理或者都从后台来 - # 微信浏览器 - # MicroMessenger: Mozilla/5.0 (Linux; Android 10; ELE-AL00 Build/HUAWEIELE-AL00; wv) - # AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/77.0.3865.120 - # MQQBrowser/6.2 TBS/045525 Mobile Safari/537.36 MMWEBID/3135 MicroMessenger/8.0.2.1860(0x2800023B) Process/tools WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 - # 微信浏览器,开发工具,网页 iphone - # ,Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1 - # wechatdevtools/1.03.2011120 MicroMessenger/7.0.4 Language/zh_CN webview/16178807094901773 - # webdebugger port/27772 token/b91f4a234b918f4e2a5d1a835a09c31e - - # 微信小程序 - # MicroMessenger: Mozilla/5.0 (Linux; Android 10; ELE-AL00 Build/HUAWEIELE-AL00; wv) - # AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/78.0.3904.62 XWEB/2767 MMWEBSDK/20210302 Mobile Safari/537.36 MMWEBID/6689 MicroMessenger/8.0.2.1860(0x2800023B) Process/appbrand2 WeChat/arm64 Weixin NetType/WIFI Language/zh_CN ABI/arm64 - # MiniProgramEnv/android - # 微信浏览器,开发工具,小程序,iphone - # Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1 - # wechatdevtools/1.03.2011120 MicroMessenger/7.0.4 Language/zh_CN webview/ - # 微信内,iphone web - # Mozilla/5.0 (iPhone; CPU iPhone OS 14_4_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 - # MicroMessenger/8.0.3(0x1800032a) NetType/WIFI Language/zh_CN - # 安卓app,h5 - # ELE-AL00(Android/10) (cn.erpapp.o20sticks.App/13.20.12.09) Weex/0.26.0 1080x2265 - - # web 表示普通浏览器,后续更深入处理 - utype = 'web' - # todo: 引入现成 py lib,处理企业微信 - if 'MicroMessenger' in ua and 'webdebugger' not in ua and ('MiniProgramEnv' in ua or 'wechatdevtools' in ua): - # 微信小程序及开发者工具 - utype = 'wxapp' - elif 'MicroMessenger' in ua: - # 微信浏览器 - utype = 'wxweb' - elif 'cn.erpapp.o20sticks.App' in ua: - # 安卓app - utype = 'native_android' - # _logger.warning('=========get ua %s,%s' % (utype, ua)) - return utype