|
|
@ -3,7 +3,6 @@ import time
|
|
|
|
import traceback
|
|
|
|
import traceback
|
|
|
|
from typing import Optional, Tuple, TypedDict
|
|
|
|
from typing import Optional, Tuple, TypedDict
|
|
|
|
|
|
|
|
|
|
|
|
import sqlalchemy
|
|
|
|
|
|
|
|
from api.model.chat_complete.bot_persona import BotPersonaHelper
|
|
|
|
from api.model.chat_complete.bot_persona import BotPersonaHelper
|
|
|
|
from api.model.chat_complete.conversation import (
|
|
|
|
from api.model.chat_complete.conversation import (
|
|
|
|
ConversationChunkHelper,
|
|
|
|
ConversationChunkHelper,
|
|
|
@ -281,7 +280,7 @@ class ChatCompleteService:
|
|
|
|
message_log = []
|
|
|
|
message_log = []
|
|
|
|
if self.conversation_chunk is not None:
|
|
|
|
if self.conversation_chunk is not None:
|
|
|
|
for message in self.conversation_chunk.message_data:
|
|
|
|
for message in self.conversation_chunk.message_data:
|
|
|
|
if message["role"] in ["user", "assistant"]:
|
|
|
|
if message.get("role") in ["user", "assistant"]:
|
|
|
|
message_log.append(
|
|
|
|
message_log.append(
|
|
|
|
{
|
|
|
|
{
|
|
|
|
"role": message["role"],
|
|
|
|
"role": message["role"],
|
|
|
@ -387,7 +386,7 @@ class ChatCompleteService:
|
|
|
|
return False
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
|
|
for i in range(len(self.conversation_chunk.message_data) - 1, -1, -1):
|
|
|
|
for i in range(len(self.conversation_chunk.message_data) - 1, -1, -1):
|
|
|
|
if self.conversation_chunk.message_data[i]["role"] == "assistant":
|
|
|
|
if self.conversation_chunk.message_data[i].get("role") == "assistant":
|
|
|
|
self.conversation_chunk.message_data[i]["point_cost"] = point_cost
|
|
|
|
self.conversation_chunk.message_data[i]["point_cost"] = point_cost
|
|
|
|
flag_modified(self.conversation_chunk, "message_data")
|
|
|
|
flag_modified(self.conversation_chunk, "message_data")
|
|
|
|
await self.conversation_chunk_helper.update(self.conversation_chunk)
|
|
|
|
await self.conversation_chunk_helper.update(self.conversation_chunk)
|
|
|
@ -399,9 +398,11 @@ class ChatCompleteService:
|
|
|
|
bot_name = Config.get("chatcomplete.bot_name", "ChatComplete", str)
|
|
|
|
bot_name = Config.get("chatcomplete.bot_name", "ChatComplete", str)
|
|
|
|
|
|
|
|
|
|
|
|
for message_data in message_log_list:
|
|
|
|
for message_data in message_log_list:
|
|
|
|
if message_data["role"] == "summary":
|
|
|
|
if "content" in message_data:
|
|
|
|
|
|
|
|
msg_role = message_data.get("role")
|
|
|
|
|
|
|
|
if msg_role == "summary":
|
|
|
|
chat_log.append(message_data["content"])
|
|
|
|
chat_log.append(message_data["content"])
|
|
|
|
elif message_data["role"] == "assistant":
|
|
|
|
elif msg_role == "assistant":
|
|
|
|
chat_log.append(
|
|
|
|
chat_log.append(
|
|
|
|
f'{bot_name}: {message_data["content"]}'
|
|
|
|
f'{bot_name}: {message_data["content"]}'
|
|
|
|
)
|
|
|
|
)
|
|
|
@ -426,11 +427,15 @@ class ChatCompleteService:
|
|
|
|
bot_name = Config.get("chatcomplete.bot_name", "ChatComplete", str)
|
|
|
|
bot_name = Config.get("chatcomplete.bot_name", "ChatComplete", str)
|
|
|
|
|
|
|
|
|
|
|
|
for message_data in message_log_list:
|
|
|
|
for message_data in message_log_list:
|
|
|
|
if message_data["role"] == "assistant":
|
|
|
|
if "content" in message_data:
|
|
|
|
|
|
|
|
msg_role = message_data.get("role")
|
|
|
|
|
|
|
|
if msg_role == "summary":
|
|
|
|
|
|
|
|
chat_log.append(message_data["content"])
|
|
|
|
|
|
|
|
elif msg_role == "assistant":
|
|
|
|
chat_log.append(
|
|
|
|
chat_log.append(
|
|
|
|
f'{bot_name}: {message_data["content"]}'
|
|
|
|
f'{bot_name}: {message_data["content"]}'
|
|
|
|
)
|
|
|
|
)
|
|
|
|
elif message_data["role"] == "user":
|
|
|
|
else:
|
|
|
|
chat_log.append(f'User: {message_data["content"]}')
|
|
|
|
chat_log.append(f'User: {message_data["content"]}')
|
|
|
|
|
|
|
|
|
|
|
|
chat_log_str = "\n".join(chat_log)
|
|
|
|
chat_log_str = "\n".join(chat_log)
|
|
|
|