mirror of
https://github.com/guohuadeng/app-odoo.git
synced 2025-02-23 04:11:36 +02:00
update gpt with openai
This commit is contained in:
@@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
{
|
{
|
||||||
'name': 'Latest ChatGPT4 AI Center. GPT 4 for image, Dall-E Image.Multi Robot Support. Chat and Training',
|
'name': 'Latest ChatGPT4 AI Center. GPT 4 for image, Dall-E Image.Multi Robot Support. Chat and Training',
|
||||||
'version': '16.23.03.16',
|
'version': '16.23.03.20',
|
||||||
'author': 'Sunpop.cn',
|
'author': 'Sunpop.cn',
|
||||||
'company': 'Sunpop.cn',
|
'company': 'Sunpop.cn',
|
||||||
'maintainer': 'Sunpop.cn',
|
'maintainer': 'Sunpop.cn',
|
||||||
|
|||||||
@@ -5,13 +5,15 @@ import openai
|
|||||||
from odoo import api, fields, models, _
|
from odoo import api, fields, models, _
|
||||||
from odoo.exceptions import UserError
|
from odoo.exceptions import UserError
|
||||||
|
|
||||||
|
import logging
|
||||||
|
_logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
class AiRobot(models.Model):
|
class AiRobot(models.Model):
|
||||||
_name = 'ai.robot'
|
_name = 'ai.robot'
|
||||||
_description = 'Gpt Robot'
|
_description = 'Gpt Robot'
|
||||||
_order = 'sequence, name'
|
_order = 'sequence, name'
|
||||||
|
|
||||||
name = fields.Char(string='Name', translate=True)
|
name = fields.Char(string='Name', translate=True, required=True)
|
||||||
provider = fields.Selection(string="AI Provider", selection=[('openai', 'OpenAI'), ('azure', 'Azure')], required=True, default='openai')
|
provider = fields.Selection(string="AI Provider", selection=[('openai', 'OpenAI'), ('azure', 'Azure')], required=True, default='openai')
|
||||||
ai_model = fields.Selection(string="AI Model", selection=[
|
ai_model = fields.Selection(string="AI Model", selection=[
|
||||||
('gpt-4', 'Chatgpt 4'),
|
('gpt-4', 'Chatgpt 4'),
|
||||||
@@ -35,7 +37,7 @@ GPT-3 A set of models that can understand and generate natural language
|
|||||||
openapi_api_key = fields.Char(string="API Key", help="Provide the API key here")
|
openapi_api_key = fields.Char(string="API Key", help="Provide the API key here")
|
||||||
temperature = fields.Float(string='Temperature', default=0.9)
|
temperature = fields.Float(string='Temperature', default=0.9)
|
||||||
max_length = fields.Integer('Max Length', default=300)
|
max_length = fields.Integer('Max Length', default=300)
|
||||||
endpoint = fields.Char('End Point')
|
endpoint = fields.Char('End Point', default='https://api.openai.com/v1/chat/completions')
|
||||||
engine = fields.Char('Engine', help='If use Azure, Please input the Model deployment name.')
|
engine = fields.Char('Engine', help='If use Azure, Please input the Model deployment name.')
|
||||||
api_version = fields.Char('API Version', default='2022-12-01')
|
api_version = fields.Char('API Version', default='2022-12-01')
|
||||||
sequence = fields.Integer('Sequence', help="Determine the display order", default=10)
|
sequence = fields.Integer('Sequence', help="Determine the display order", default=10)
|
||||||
@@ -62,7 +64,16 @@ GPT-3 A set of models that can understand and generate natural language
|
|||||||
top_p=0.5,
|
top_p=0.5,
|
||||||
frequency_penalty=0,
|
frequency_penalty=0,
|
||||||
presence_penalty=0, stop=["Human:", "AI:"])
|
presence_penalty=0, stop=["Human:", "AI:"])
|
||||||
|
|
||||||
|
_logger.warning('=====================azure input data: %s' % data)
|
||||||
if 'choices' in response:
|
if 'choices' in response:
|
||||||
res = response['choices'][0]['text'].replace(' .', '.').strip()
|
res = response['choices'][0]['text'].replace(' .', '.').strip()
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
@api.onchange('provider')
|
||||||
|
def _onchange_provider(self):
|
||||||
|
if self.provider == 'openai':
|
||||||
|
self.endpoint = 'https://api.openai.com/v1/chat/completions'
|
||||||
|
elif self.provider == 'azure':
|
||||||
|
self.endpoint = 'https://odoo.openai.azure.com'
|
||||||
|
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import datetime
|
|||||||
# from transformers import TextDavinciTokenizer, TextDavinciModel
|
# from transformers import TextDavinciTokenizer, TextDavinciModel
|
||||||
from odoo import api, fields, models, _
|
from odoo import api, fields, models, _
|
||||||
from odoo.exceptions import UserError
|
from odoo.exceptions import UserError
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
_logger = logging.getLogger(__name__)
|
_logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
@@ -15,9 +16,18 @@ class Channel(models.Model):
|
|||||||
|
|
||||||
@api.model
|
@api.model
|
||||||
def get_openai(self, gpt_id, provider, api_key, ai_model, data, user="Odoo"):
|
def get_openai(self, gpt_id, provider, api_key, ai_model, data, user="Odoo"):
|
||||||
|
if provider == 'azure':
|
||||||
|
res = gpt_id.get_openai(data)
|
||||||
|
return res
|
||||||
|
|
||||||
headers = {"Content-Type": "application/json", "Authorization": f"Bearer {api_key}"}
|
headers = {"Content-Type": "application/json", "Authorization": f"Bearer {api_key}"}
|
||||||
R_TIMEOUT = 5
|
R_TIMEOUT = 30
|
||||||
|
o_url = gpt_id.endpoint or "https://api.openai.com/v1/chat/completions"
|
||||||
|
|
||||||
|
# 以下处理 open ai
|
||||||
|
# 获取模型信息
|
||||||
|
# list_model = requests.get("https://api.openai.com/v1/models", headers=headers)
|
||||||
|
# model_info = requests.get("https://api.openai.com/v1/models/%s" % ai_model, headers=headers)
|
||||||
if ai_model == 'dall-e2':
|
if ai_model == 'dall-e2':
|
||||||
# todo: 处理 图像引擎,主要是返回参数到聊天中
|
# todo: 处理 图像引擎,主要是返回参数到聊天中
|
||||||
# image_url = response['data'][0]['url']
|
# image_url = response['data'][0]['url']
|
||||||
@@ -33,49 +43,43 @@ class Channel(models.Model):
|
|||||||
"model": ai_model,
|
"model": ai_model,
|
||||||
"messages": [{"role": "user", "content": data}],
|
"messages": [{"role": "user", "content": data}],
|
||||||
"temperature": 0.9,
|
"temperature": 0.9,
|
||||||
"max_tokens": 2000,
|
"max_tokens": gpt_id.max_length or 1000,
|
||||||
"top_p": 1,
|
"top_p": 1,
|
||||||
"frequency_penalty": 0.0,
|
"frequency_penalty": 0.0,
|
||||||
"presence_penalty": 0.6,
|
"presence_penalty": 0.6,
|
||||||
"user": user,
|
"user": user,
|
||||||
"stop": ["Human:", "AI:"]
|
"stop": ["Human:", "AI:"]
|
||||||
}
|
}
|
||||||
if provider == 'openai':
|
|
||||||
response = requests.post("https://api.openai.com/v1/chat/completions", data=json.dumps(pdata), headers=headers, timeout=R_TIMEOUT)
|
_logger.warning('=====================open input pdata: %s' % pdata)
|
||||||
res = response.json()
|
|
||||||
if 'choices' in res:
|
response = requests.post(o_url, data=json.dumps(pdata), headers=headers, timeout=R_TIMEOUT)
|
||||||
# for rec in res:
|
res = response.json()
|
||||||
# res = rec['message']['content']
|
if 'choices' in res:
|
||||||
res = '\n'.join([x['message']['content'] for x in res['choices']])
|
# for rec in res:
|
||||||
return res
|
# res = rec['message']['content']
|
||||||
elif provider == 'azure':
|
res = '\n'.join([x['message']['content'] for x in res['choices']])
|
||||||
res = gpt_id.get_openai(data)
|
|
||||||
return res
|
return res
|
||||||
else:
|
else:
|
||||||
pdata = {
|
pdata = {
|
||||||
"model": ai_model,
|
"model": ai_model,
|
||||||
"prompt": data,
|
"prompt": data,
|
||||||
"temperature": 0.9,
|
"temperature": 0.9,
|
||||||
"max_tokens": 2000,
|
"max_tokens": gpt_id.max_length or 1000,
|
||||||
"top_p": 1,
|
"top_p": 1,
|
||||||
"frequency_penalty": 0.0,
|
"frequency_penalty": 0.0,
|
||||||
"presence_penalty": 0.6,
|
"presence_penalty": 0.6,
|
||||||
"user": user,
|
"user": user,
|
||||||
"stop": ["Human:", "AI:"]
|
"stop": ["Human:", "AI:"]
|
||||||
}
|
}
|
||||||
if provider == 'openai':
|
response = requests.post(o_url, data=json.dumps(pdata), headers=headers, timeout=R_TIMEOUT)
|
||||||
response = requests.post("https://api.openai.com/v1/completions", data=json.dumps(pdata), headers=headers, timeout=R_TIMEOUT)
|
res = response.json()
|
||||||
res = response.json()
|
if 'choices' in res:
|
||||||
if 'choices' in res:
|
res = '\n'.join([x['text'] for x in res['choices']])
|
||||||
res = '\n'.join([x['text'] for x in res['choices']])
|
return res
|
||||||
return res
|
|
||||||
elif provider == 'azure':
|
elif provider == 'azure':
|
||||||
_logger.warning('=====================azure input data: %s' % data)
|
|
||||||
res = gpt_id.get_openai(data)
|
res = gpt_id.get_openai(data)
|
||||||
return res
|
return res
|
||||||
# 获取模型信息
|
|
||||||
# list_model = requests.get("https://api.openai.com/v1/models", headers=headers)
|
|
||||||
# model_info = requests.get("https://api.openai.com/v1/models/%s" % ai_model, headers=headers)
|
|
||||||
|
|
||||||
return "获取结果超时,请重新跟我聊聊。"
|
return "获取结果超时,请重新跟我聊聊。"
|
||||||
|
|
||||||
|
|||||||
BIN
app_chatgpt/static/description/src/demob.jpg
Normal file
BIN
app_chatgpt/static/description/src/demob.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 232 KiB |
@@ -25,7 +25,7 @@
|
|||||||
<group>
|
<group>
|
||||||
<group>
|
<group>
|
||||||
<field name="name"/>
|
<field name="name"/>
|
||||||
<field name="openapi_api_key" password="True"/>
|
<field name="openapi_api_key" password="True" required="True"/>
|
||||||
<field name="temperature"/>
|
<field name="temperature"/>
|
||||||
<field name="sequence"/>
|
<field name="sequence"/>
|
||||||
</group>
|
</group>
|
||||||
|
|||||||
Reference in New Issue
Block a user