Version: 0.8.1.dev.260326
后端: 1.获取agent聊天历史记录接口做了如下更改: (1)对reasoning_content也做了存储,同步更改了mysql和redis缓存的读写逻辑 (2)为了承接前端的重试/修改消息的逻辑,进行了一些代码和表单上的改动 前端: 1.agent页面新增了很多小组件,改善交互体验 2.新增重试消息/修改消息并重新发送功能,前者有bug,可能前后端都有问题,待修复。
This commit is contained in:
@@ -10,7 +10,7 @@ func ToEinoMessages(dbMsgs []model.ChatHistory) []*schema.Message {
|
||||
res := make([]*schema.Message, 0)
|
||||
for _, m := range dbMsgs {
|
||||
var role schema.RoleType
|
||||
switch *m.Role {
|
||||
switch safeChatHistoryRole(m.Role) {
|
||||
case "user":
|
||||
role = schema.User
|
||||
case "assistant":
|
||||
@@ -18,10 +18,46 @@ func ToEinoMessages(dbMsgs []model.ChatHistory) []*schema.Message {
|
||||
default:
|
||||
role = schema.System
|
||||
}
|
||||
res = append(res, &schema.Message{
|
||||
Role: role,
|
||||
Content: *m.MessageContent,
|
||||
})
|
||||
msg := &schema.Message{
|
||||
Role: role,
|
||||
Content: safeChatHistoryText(m.MessageContent),
|
||||
ReasoningContent: safeChatHistoryText(m.ReasoningContent),
|
||||
}
|
||||
extra := make(map[string]any)
|
||||
extra["history_id"] = m.ID
|
||||
if m.ReasoningDurationSeconds > 0 {
|
||||
extra["reasoning_duration_seconds"] = m.ReasoningDurationSeconds
|
||||
}
|
||||
if m.RetryGroupID != nil && *m.RetryGroupID != "" {
|
||||
extra["retry_group_id"] = *m.RetryGroupID
|
||||
}
|
||||
if m.RetryIndex != nil && *m.RetryIndex > 0 {
|
||||
extra["retry_index"] = *m.RetryIndex
|
||||
}
|
||||
if m.RetryFromUserMessageID != nil && *m.RetryFromUserMessageID > 0 {
|
||||
extra["retry_from_user_message_id"] = *m.RetryFromUserMessageID
|
||||
}
|
||||
if m.RetryFromAssistantMessageID != nil && *m.RetryFromAssistantMessageID > 0 {
|
||||
extra["retry_from_assistant_message_id"] = *m.RetryFromAssistantMessageID
|
||||
}
|
||||
if len(extra) > 0 {
|
||||
msg.Extra = extra
|
||||
}
|
||||
res = append(res, msg)
|
||||
}
|
||||
return res
|
||||
}
|
||||
|
||||
func safeChatHistoryRole(role *string) string {
|
||||
if role == nil {
|
||||
return ""
|
||||
}
|
||||
return *role
|
||||
}
|
||||
|
||||
func safeChatHistoryText(text *string) string {
|
||||
if text == nil {
|
||||
return ""
|
||||
}
|
||||
return *text
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user