graphiti/core/utils/maintenance/node_operations.py

64 lines
2.0 KiB
Python
Raw Normal View History

from datetime import datetime
from core.nodes import EntityNode, EpisodicNode
import logging
from core.llm_client import LLMClient
from core.prompts import prompt_library
logger = logging.getLogger(__name__)
async def extract_new_nodes(
llm_client: LLMClient,
episode: EpisodicNode,
relevant_schema: dict[str, any],
previous_episodes: list[EpisodicNode],
) -> list[EntityNode]:
# Prepare context for LLM
existing_nodes = [
{"name": node_name, "label": node_info["label"], "uuid": node_info["uuid"]}
for node_name, node_info in relevant_schema["nodes"].items()
]
context = {
"episode_content": episode.content,
"episode_timestamp": (
episode.valid_at.isoformat() if episode.valid_at else None
),
"existing_nodes": existing_nodes,
"previous_episodes": [
{
"content": ep.content,
"timestamp": ep.valid_at.isoformat() if ep.valid_at else None,
}
for ep in previous_episodes
],
}
llm_response = await llm_client.generate_response(
prompt_library.extract_nodes.v1(context)
)
new_nodes_data = llm_response.get("new_nodes", [])
logger.info(f"Extracted new nodes: {new_nodes_data}")
# Convert the extracted data into EntityNode objects
new_nodes = []
for node_data in new_nodes_data:
# Check if the node already exists
if not any(
existing_node["name"] == node_data["name"]
for existing_node in existing_nodes
):
new_node = EntityNode(
name=node_data["name"],
labels=node_data["labels"],
summary=node_data["summary"],
created_at=datetime.now(),
)
new_nodes.append(new_node)
logger.info(f"Created new node: {new_node.name} (UUID: {new_node.uuid})")
else:
logger.info(f"Node {node_data['name']} already exists, skipping creation.")
return new_nodes