Enha: system rag

This commit is contained in:
Grail Finder
2025-11-22 21:12:42 +03:00
parent 4eb3d609a1
commit 9abe74a4b4

41
llm.go
View File

@@ -84,14 +84,15 @@ func (lcp LlamaCPPeer) FormMsg(msg, role string, resume bool) (io.Reader, error)
if msg != "" { // otherwise let the bot to continue if msg != "" { // otherwise let the bot to continue
newMsg := models.RoleMsg{Role: role, Content: msg} newMsg := models.RoleMsg{Role: role, Content: msg}
chatBody.Messages = append(chatBody.Messages, newMsg) chatBody.Messages = append(chatBody.Messages, newMsg)
// if rag // if rag - add as system message to avoid conflicts with tool usage
if cfg.RAGEnabled { if cfg.RAGEnabled {
ragResp, err := chatRagUse(newMsg.Content) ragResp, err := chatRagUse(newMsg.Content)
if err != nil { if err != nil {
logger.Error("failed to form a rag msg", "error", err) logger.Error("failed to form a rag msg", "error", err)
return nil, err return nil, err
} }
ragMsg := models.RoleMsg{Role: cfg.ToolRole, Content: ragResp} // Use system role for RAG context to avoid conflicts with tool usage
ragMsg := models.RoleMsg{Role: "system", Content: "RAG context: " + ragResp}
chatBody.Messages = append(chatBody.Messages, ragMsg) chatBody.Messages = append(chatBody.Messages, ragMsg)
} }
} }
@@ -181,15 +182,12 @@ func (op OpenAIer) FormMsg(msg, role string, resume bool) (io.Reader, error) {
if msg != "" { // otherwise let the bot continue if msg != "" { // otherwise let the bot continue
// Create the message with support for multimodal content // Create the message with support for multimodal content
var newMsg models.RoleMsg var newMsg models.RoleMsg
// Check if we have an image to add to this message // Check if we have an image to add to this message
if imageAttachmentPath != "" { if imageAttachmentPath != "" {
// Create a multimodal message with both text and image // Create a multimodal message with both text and image
newMsg = models.NewMultimodalMsg(role, []interface{}{}) newMsg = models.NewMultimodalMsg(role, []interface{}{})
// Add the text content // Add the text content
newMsg.AddTextPart(msg) newMsg.AddTextPart(msg)
// Add the image content // Add the image content
imageURL, err := models.CreateImageURLFromPath(imageAttachmentPath) imageURL, err := models.CreateImageURLFromPath(imageAttachmentPath)
if err != nil { if err != nil {
@@ -205,8 +203,19 @@ func (op OpenAIer) FormMsg(msg, role string, resume bool) (io.Reader, error) {
// Create a simple text message // Create a simple text message
newMsg = models.NewRoleMsg(role, msg) newMsg = models.NewRoleMsg(role, msg)
} }
chatBody.Messages = append(chatBody.Messages, newMsg) chatBody.Messages = append(chatBody.Messages, newMsg)
// if rag - add as system message to avoid conflicts with tool usage
if cfg.RAGEnabled {
ragResp, err := chatRagUse(newMsg.Content)
if err != nil {
logger.Error("failed to form a rag msg", "error", err)
return nil, err
}
// Use system role for RAG context to avoid conflicts with tool usage
ragMsg := models.RoleMsg{Role: "system", Content: "RAG context: " + ragResp}
chatBody.Messages = append(chatBody.Messages, ragMsg)
}
} }
req := models.OpenAIReq{ req := models.OpenAIReq{
ChatBody: chatBody, ChatBody: chatBody,
@@ -251,14 +260,15 @@ func (ds DeepSeekerCompletion) FormMsg(msg, role string, resume bool) (io.Reader
if msg != "" { // otherwise let the bot to continue if msg != "" { // otherwise let the bot to continue
newMsg := models.RoleMsg{Role: role, Content: msg} newMsg := models.RoleMsg{Role: role, Content: msg}
chatBody.Messages = append(chatBody.Messages, newMsg) chatBody.Messages = append(chatBody.Messages, newMsg)
// if rag // if rag - add as system message to avoid conflicts with tool usage
if cfg.RAGEnabled { if cfg.RAGEnabled {
ragResp, err := chatRagUse(newMsg.Content) ragResp, err := chatRagUse(newMsg.Content)
if err != nil { if err != nil {
logger.Error("failed to form a rag msg", "error", err) logger.Error("failed to form a rag msg", "error", err)
return nil, err return nil, err
} }
ragMsg := models.RoleMsg{Role: cfg.ToolRole, Content: ragResp} // Use system role for RAG context to avoid conflicts with tool usage
ragMsg := models.RoleMsg{Role: "system", Content: "RAG context: " + ragResp}
chatBody.Messages = append(chatBody.Messages, ragMsg) chatBody.Messages = append(chatBody.Messages, ragMsg)
} }
} }
@@ -332,14 +342,15 @@ func (ds DeepSeekerChat) FormMsg(msg, role string, resume bool) (io.Reader, erro
if msg != "" { // otherwise let the bot continue if msg != "" { // otherwise let the bot continue
newMsg := models.RoleMsg{Role: role, Content: msg} newMsg := models.RoleMsg{Role: role, Content: msg}
chatBody.Messages = append(chatBody.Messages, newMsg) chatBody.Messages = append(chatBody.Messages, newMsg)
// if rag // if rag - add as system message to avoid conflicts with tool usage
if cfg.RAGEnabled { if cfg.RAGEnabled {
ragResp, err := chatRagUse(newMsg.Content) ragResp, err := chatRagUse(newMsg.Content)
if err != nil { if err != nil {
logger.Error("failed to form a rag msg", "error", err) logger.Error("failed to form a rag msg", "error", err)
return nil, err return nil, err
} }
ragMsg := models.RoleMsg{Role: cfg.ToolRole, Content: ragResp} // Use system role for RAG context to avoid conflicts with tool usage
ragMsg := models.RoleMsg{Role: "system", Content: "RAG context: " + ragResp}
chatBody.Messages = append(chatBody.Messages, ragMsg) chatBody.Messages = append(chatBody.Messages, ragMsg)
} }
} }
@@ -397,14 +408,15 @@ func (or OpenRouterCompletion) FormMsg(msg, role string, resume bool) (io.Reader
if msg != "" { // otherwise let the bot to continue if msg != "" { // otherwise let the bot to continue
newMsg := models.RoleMsg{Role: role, Content: msg} newMsg := models.RoleMsg{Role: role, Content: msg}
chatBody.Messages = append(chatBody.Messages, newMsg) chatBody.Messages = append(chatBody.Messages, newMsg)
// if rag // if rag - add as system message to avoid conflicts with tool usage
if cfg.RAGEnabled { if cfg.RAGEnabled {
ragResp, err := chatRagUse(newMsg.Content) ragResp, err := chatRagUse(newMsg.Content)
if err != nil { if err != nil {
logger.Error("failed to form a rag msg", "error", err) logger.Error("failed to form a rag msg", "error", err)
return nil, err return nil, err
} }
ragMsg := models.RoleMsg{Role: cfg.ToolRole, Content: ragResp} // Use system role for RAG context to avoid conflicts with tool usage
ragMsg := models.RoleMsg{Role: "system", Content: "RAG context: " + ragResp}
chatBody.Messages = append(chatBody.Messages, ragMsg) chatBody.Messages = append(chatBody.Messages, ragMsg)
} }
} }
@@ -474,14 +486,15 @@ func (or OpenRouterChat) FormMsg(msg, role string, resume bool) (io.Reader, erro
if msg != "" { // otherwise let the bot continue if msg != "" { // otherwise let the bot continue
newMsg := models.RoleMsg{Role: role, Content: msg} newMsg := models.RoleMsg{Role: role, Content: msg}
chatBody.Messages = append(chatBody.Messages, newMsg) chatBody.Messages = append(chatBody.Messages, newMsg)
// if rag // if rag - add as system message to avoid conflicts with tool usage
if cfg.RAGEnabled { if cfg.RAGEnabled {
ragResp, err := chatRagUse(newMsg.Content) ragResp, err := chatRagUse(newMsg.Content)
if err != nil { if err != nil {
logger.Error("failed to form a rag msg", "error", err) logger.Error("failed to form a rag msg", "error", err)
return nil, err return nil, err
} }
ragMsg := models.RoleMsg{Role: cfg.ToolRole, Content: ragResp} // Use system role for RAG context to avoid conflicts with tool usage
ragMsg := models.RoleMsg{Role: "system", Content: "RAG context: " + ragResp}
chatBody.Messages = append(chatBody.Messages, ragMsg) chatBody.Messages = append(chatBody.Messages, ragMsg)
} }
} }