graphiti-core 0.18.2__py3-none-any.whl → 0.18.4__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of graphiti-core might be problematic. Click here for more details.

@@ -44,6 +44,7 @@ def get_range_indices(provider: GraphProvider) -> list[LiteralString]:
44
44
  'CREATE INDEX has_member_uuid IF NOT EXISTS FOR ()-[e:HAS_MEMBER]-() ON (e.uuid)',
45
45
  'CREATE INDEX entity_group_id IF NOT EXISTS FOR (n:Entity) ON (n.group_id)',
46
46
  'CREATE INDEX episode_group_id IF NOT EXISTS FOR (n:Episodic) ON (n.group_id)',
47
+ 'CREATE INDEX community_group_id IF NOT EXISTS FOR (n:Community) ON (n.group_id)',
47
48
  'CREATE INDEX relation_group_id IF NOT EXISTS FOR ()-[e:RELATES_TO]-() ON (e.group_id)',
48
49
  'CREATE INDEX mention_group_id IF NOT EXISTS FOR ()-[e:MENTIONS]-() ON (e.group_id)',
49
50
  'CREATE INDEX name_entity_index IF NOT EXISTS FOR (n:Entity) ON (n.name)',
graphiti_core/graphiti.py CHANGED
@@ -26,7 +26,12 @@ from graphiti_core.cross_encoder.client import CrossEncoderClient
26
26
  from graphiti_core.cross_encoder.openai_reranker_client import OpenAIRerankerClient
27
27
  from graphiti_core.driver.driver import GraphDriver
28
28
  from graphiti_core.driver.neo4j_driver import Neo4jDriver
29
- from graphiti_core.edges import CommunityEdge, EntityEdge, EpisodicEdge
29
+ from graphiti_core.edges import (
30
+ CommunityEdge,
31
+ EntityEdge,
32
+ EpisodicEdge,
33
+ create_entity_edge_embeddings,
34
+ )
30
35
  from graphiti_core.embedder import EmbedderClient, OpenAIEmbedder
31
36
  from graphiti_core.graphiti_types import GraphitiClients
32
37
  from graphiti_core.helpers import (
@@ -36,7 +41,13 @@ from graphiti_core.helpers import (
36
41
  validate_group_id,
37
42
  )
38
43
  from graphiti_core.llm_client import LLMClient, OpenAIClient
39
- from graphiti_core.nodes import CommunityNode, EntityNode, EpisodeType, EpisodicNode
44
+ from graphiti_core.nodes import (
45
+ CommunityNode,
46
+ EntityNode,
47
+ EpisodeType,
48
+ EpisodicNode,
49
+ create_entity_node_embeddings,
50
+ )
40
51
  from graphiti_core.search.search import SearchConfig, search
41
52
  from graphiti_core.search.search_config import DEFAULT_SEARCH_LIMIT, SearchResults
42
53
  from graphiti_core.search.search_config_recipes import (
@@ -984,7 +995,7 @@ class Graphiti:
984
995
  if edge.fact_embedding is None:
985
996
  await edge.generate_embedding(self.embedder)
986
997
 
987
- resolved_nodes, uuid_map, _ = await resolve_extracted_nodes(
998
+ nodes, uuid_map, _ = await resolve_extracted_nodes(
988
999
  self.clients,
989
1000
  [source_node, target_node],
990
1001
  )
@@ -1012,9 +1023,12 @@ class Graphiti:
1012
1023
  ),
1013
1024
  )
1014
1025
 
1015
- await add_nodes_and_edges_bulk(
1016
- self.driver, [], [], resolved_nodes, [resolved_edge] + invalidated_edges, self.embedder
1017
- )
1026
+ edges: list[EntityEdge] = [resolved_edge] + invalidated_edges
1027
+
1028
+ await create_entity_edge_embeddings(self.embedder, edges)
1029
+ await create_entity_node_embeddings(self.embedder, nodes)
1030
+
1031
+ await add_nodes_and_edges_bulk(self.driver, [], [], nodes, edges, self.embedder)
1018
1032
 
1019
1033
  async def remove_episode(self, episode_uuid: str):
1020
1034
  # Find the episode to be deleted
graphiti_core/nodes.py CHANGED
@@ -118,7 +118,7 @@ class Node(BaseModel, ABC):
118
118
  return False
119
119
 
120
120
  @classmethod
121
- async def delete_by_group_id(cls, driver: GraphDriver, group_id: str):
121
+ async def delete_by_group_id(cls, driver: GraphDriver, group_id: str, batch_size: int = 100):
122
122
  if driver.provider == GraphProvider.FALKORDB:
123
123
  for label in ['Entity', 'Episodic', 'Community']:
124
124
  await driver.execute_query(
@@ -129,13 +129,18 @@ class Node(BaseModel, ABC):
129
129
  group_id=group_id,
130
130
  )
131
131
  else:
132
- await driver.execute_query(
133
- """
134
- MATCH (n:Entity|Episodic|Community {group_id: $group_id})
135
- DETACH DELETE n
136
- """,
137
- group_id=group_id,
138
- )
132
+ async with driver.session() as session:
133
+ await session.run(
134
+ """
135
+ MATCH (n:Entity|Episodic|Community {group_id: $group_id})
136
+ CALL {
137
+ WITH n
138
+ DETACH DELETE n
139
+ } IN TRANSACTIONS OF $batch_size ROWS
140
+ """,
141
+ group_id=group_id,
142
+ batch_size=batch_size,
143
+ )
139
144
 
140
145
  @classmethod
141
146
  async def get_by_uuid(cls, driver: GraphDriver, uuid: str): ...
@@ -31,7 +31,7 @@ class ComparisonOperator(Enum):
31
31
 
32
32
 
33
33
  class DateFilter(BaseModel):
34
- date: datetime = Field(description='A datetime to filter on')
34
+ date: datetime | None = Field(description='A datetime to filter on')
35
35
  comparison_operator: ComparisonOperator = Field(
36
36
  description='Comparison operator for date filter'
37
37
  )
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: graphiti-core
3
- Version: 0.18.2
3
+ Version: 0.18.4
4
4
  Summary: A temporal graph building library
5
5
  Project-URL: Homepage, https://help.getzep.com/graphiti/graphiti/overview
6
6
  Project-URL: Repository, https://github.com/getzep/graphiti
@@ -369,7 +369,7 @@ graphiti = Graphiti(
369
369
  "neo4j",
370
370
  "password",
371
371
  llm_client=OpenAIClient(
372
- llm_config=azure_llm_config,
372
+ config=azure_llm_config,
373
373
  client=llm_client_azure
374
374
  ),
375
375
  embedder=OpenAIEmbedder(
@@ -379,7 +379,7 @@ graphiti = Graphiti(
379
379
  client=embedding_client_azure
380
380
  ),
381
381
  cross_encoder=OpenAIRerankerClient(
382
- llm_config=LLMConfig(
382
+ config=LLMConfig(
383
383
  model=azure_llm_config.small_model # Use small model for reranking
384
384
  ),
385
385
  client=llm_client_azure
@@ -1,11 +1,11 @@
1
1
  graphiti_core/__init__.py,sha256=e5SWFkRiaUwfprYIeIgVIh7JDedNiloZvd3roU-0aDY,55
2
2
  graphiti_core/edges.py,sha256=KpgCzHlNgEcTTbUE62RAXKKi2YbG_fIwilE_W1TARYI,14864
3
3
  graphiti_core/errors.py,sha256=cH_v9TPgEPeQE6GFOHIg5TvejpUCBddGarMY2Whxbwc,2707
4
- graphiti_core/graph_queries.py,sha256=mkSE8JbH4dTysT1quxR_QqCU-P_MUogbj48-BVxAcY4,5316
5
- graphiti_core/graphiti.py,sha256=u9sDQ4iXxDjbI_G9FSs-xXi2xuNMZo-FvNW_sEBptYo,40129
4
+ graphiti_core/graph_queries.py,sha256=gXQvspJHpM5LRJ5HBJgr0Zw-AhHkqweCoq06wfyZ_bc,5407
5
+ graphiti_core/graphiti.py,sha256=DWp9b3r5mj64ZZz0OqsCTpOt9ZspQTe6Sxib5SlQq8A,40371
6
6
  graphiti_core/graphiti_types.py,sha256=rL-9bvnLobunJfXU4hkD6mAj14pofKp_wq8QsFDZwDU,1035
7
7
  graphiti_core/helpers.py,sha256=oKcOQE_bvsdhBpPr1Ia2tylBq1svj3X1oBMSR7qdo00,5331
8
- graphiti_core/nodes.py,sha256=-RnBtqLx1ukbQQqjZval9fDAWIJUTWaKwSMPLJ9AzM4,17866
8
+ graphiti_core/nodes.py,sha256=7K5fiEG8iTgB0rqk_IcC9K--5ycTwmvSvWEwZU1E_zU,18123
9
9
  graphiti_core/py.typed,sha256=vlmmzQOt7bmeQl9L3XJP4W6Ry0iiELepnOrinKz5KQg,79
10
10
  graphiti_core/cross_encoder/__init__.py,sha256=hry59vz21x-AtGZ0MJ7ugw0HTwJkXiddpp_Yqnwsen0,723
11
11
  graphiti_core/cross_encoder/bge_reranker_client.py,sha256=y3TfFxZh0Yvj6HUShmfUm6MC7OPXwWUlv1Qe5HF3S3I,1797
@@ -55,7 +55,7 @@ graphiti_core/search/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hS
55
55
  graphiti_core/search/search.py,sha256=u-kTmSu3VlRHYlQhuYsbwDQ-AKKCp3BZ9JZNRv3ttVY,16720
56
56
  graphiti_core/search/search_config.py,sha256=v_rUHsu1yo5OuPfEm21lSuXexQs-o8qYwSSemW2QWhU,4165
57
57
  graphiti_core/search/search_config_recipes.py,sha256=4GquRphHhJlpXQhAZOySYnCzBWYoTwxlJj44eTOavZQ,7443
58
- graphiti_core/search/search_filters.py,sha256=Xc8hNVqbPrCd8-Zql0rtf1ztjzC_0FgAqGj9vxgNwLM,6383
58
+ graphiti_core/search/search_filters.py,sha256=f7rddW6sPIRRCVoBOS9nrOsjj-6ld03EGEQbTB2lzLg,6390
59
59
  graphiti_core/search/search_helpers.py,sha256=G5Ceaq5Pfgx0Weelqgeylp_pUHwiBnINaUYsDbURJbE,2636
60
60
  graphiti_core/search/search_utils.py,sha256=D6J93x0ol4Kd_zVo-dX0MRG0BZjLvG-mCdi-vjjDTfE,32104
61
61
  graphiti_core/telemetry/__init__.py,sha256=5kALLDlU9bb2v19CdN7qVANsJWyfnL9E60J6FFgzm3o,226
@@ -71,7 +71,7 @@ graphiti_core/utils/maintenance/node_operations.py,sha256=mNqonVTNLtw0gK7tflhoCF
71
71
  graphiti_core/utils/maintenance/temporal_operations.py,sha256=mJkw9xLB4W2BsLfC5POr0r-PHWL9SIfNj_l_xu0B5ug,3410
72
72
  graphiti_core/utils/maintenance/utils.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
73
73
  graphiti_core/utils/ontology_utils/entity_types_utils.py,sha256=4eVgxLWY6Q8k9cRJ5pW59IYF--U4nXZsZIGOVb_yHfQ,1285
74
- graphiti_core-0.18.2.dist-info/METADATA,sha256=TLIGRsoZ0nYbqBSvd_qWUkd2sAXBLTyJ4hV4j-S97cY,24621
75
- graphiti_core-0.18.2.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
76
- graphiti_core-0.18.2.dist-info/licenses/LICENSE,sha256=KCUwCyDXuVEgmDWkozHyniRyWjnWUWjkuDHfU6o3JlA,11325
77
- graphiti_core-0.18.2.dist-info/RECORD,,
74
+ graphiti_core-0.18.4.dist-info/METADATA,sha256=J4bBucd0Rvm9mTrmYjy3vl1A_9Zy0irQX_F1hHTWPf4,24613
75
+ graphiti_core-0.18.4.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
76
+ graphiti_core-0.18.4.dist-info/licenses/LICENSE,sha256=KCUwCyDXuVEgmDWkozHyniRyWjnWUWjkuDHfU6o3JlA,11325
77
+ graphiti_core-0.18.4.dist-info/RECORD,,