Don't include null attributes when filling in stored conversation metadata

- Prompt adjustments to indicate to LLM what context it has
This commit is contained in:
sabaimran 2024-11-29 18:10:14 -08:00
parent c5329d76ba
commit a0b00ce4a1
3 changed files with 25 additions and 20 deletions

View file

@ -108,7 +108,7 @@ class ChatMessage(PydanticBaseModel):
created: str created: str
images: Optional[List[str]] = None images: Optional[List[str]] = None
queryFiles: Optional[List[Dict]] = None queryFiles: Optional[List[Dict]] = None
excalidrawDiagram: Optional[str] = None excalidrawDiagram: Optional[List[Dict]] = None
by: str by: str
turnId: Optional[str] turnId: Optional[str]
intent: Optional[Intent] = None intent: Optional[Intent] = None

View file

@ -186,7 +186,7 @@ Here is the image you generated based on my query. You can follow-up with a gene
generated_diagram_attachment = PromptTemplate.from_template( generated_diagram_attachment = PromptTemplate.from_template(
f""" f"""
The AI has successfully created a diagram based on the user's query and handled the request. Good job! The AI has successfully created a diagram based on the user's query and handled the request. Good job! This will be shared with the user.
AI can follow-up with a general response or summary. Limit to 1-2 sentences. AI can follow-up with a general response or summary. Limit to 1-2 sentences.
""".strip() """.strip()

View file

@ -276,27 +276,32 @@ def save_to_conversation_log(
): ):
user_message_time = user_message_time or datetime.now().strftime("%Y-%m-%d %H:%M:%S") user_message_time = user_message_time or datetime.now().strftime("%Y-%m-%d %H:%M:%S")
turn_id = tracer.get("mid") or str(uuid.uuid4()) turn_id = tracer.get("mid") or str(uuid.uuid4())
user_message_metadata = {"created": user_message_time, "images": query_images, "turnId": turn_id}
if raw_query_files and len(raw_query_files) > 0:
user_message_metadata["queryFiles"] = [file.model_dump(mode="json") for file in raw_query_files]
khoj_message_metadata = {
"context": compiled_references,
"intent": {"inferred-queries": inferred_queries, "type": intent_type},
"onlineContext": online_results,
"codeContext": code_results,
"automationId": automation_id,
"trainOfThought": train_of_thought,
"turnId": turn_id,
"images": generated_images,
"queryFiles": [file.model_dump(mode="json") for file in raw_generated_files],
}
if generated_excalidraw_diagram:
khoj_message_metadata["excalidrawDiagram"] = generated_excalidraw_diagram
updated_conversation = message_to_log( updated_conversation = message_to_log(
user_message=q, user_message=q,
chat_response=chat_response, chat_response=chat_response,
user_message_metadata={ user_message_metadata=user_message_metadata,
"created": user_message_time, khoj_message_metadata=khoj_message_metadata,
"images": query_images,
"turnId": turn_id,
"queryFiles": [file.model_dump(mode="json") for file in raw_query_files],
},
khoj_message_metadata={
"context": compiled_references,
"intent": {"inferred-queries": inferred_queries, "type": intent_type},
"onlineContext": online_results,
"codeContext": code_results,
"automationId": automation_id,
"trainOfThought": train_of_thought,
"turnId": turn_id,
"images": generated_images,
"queryFiles": [file.model_dump(mode="json") for file in raw_generated_files],
"excalidrawDiagram": str(generated_excalidraw_diagram) if generated_excalidraw_diagram else None,
},
conversation_log=meta_log.get("chat", []), conversation_log=meta_log.get("chat", []),
) )
ConversationAdapters.save_conversation( ConversationAdapters.save_conversation(