@cmdoss/memwal-sdk 0.8.0 → 1.0.0

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.
Files changed (209) hide show
  1. package/README.md +522 -160
  2. package/dist/client/ClientMemoryManager.d.ts.map +1 -1
  3. package/dist/client/ClientMemoryManager.js +25 -8
  4. package/dist/client/ClientMemoryManager.js.map +1 -1
  5. package/dist/client/PersonalDataWallet.d.ts.map +1 -1
  6. package/dist/client/SimplePDWClient.d.ts +62 -2
  7. package/dist/client/SimplePDWClient.d.ts.map +1 -1
  8. package/dist/client/SimplePDWClient.js +96 -11
  9. package/dist/client/SimplePDWClient.js.map +1 -1
  10. package/dist/client/namespaces/IndexNamespace.d.ts +1 -1
  11. package/dist/client/namespaces/IndexNamespace.d.ts.map +1 -1
  12. package/dist/client/namespaces/IndexNamespace.js +7 -4
  13. package/dist/client/namespaces/IndexNamespace.js.map +1 -1
  14. package/dist/client/namespaces/MemoryNamespace.d.ts +47 -0
  15. package/dist/client/namespaces/MemoryNamespace.d.ts.map +1 -1
  16. package/dist/client/namespaces/MemoryNamespace.js +257 -27
  17. package/dist/client/namespaces/MemoryNamespace.js.map +1 -1
  18. package/dist/client/namespaces/consolidated/AdvancedNamespace.d.ts +215 -0
  19. package/dist/client/namespaces/consolidated/AdvancedNamespace.d.ts.map +1 -0
  20. package/dist/client/namespaces/consolidated/AdvancedNamespace.js +214 -0
  21. package/dist/client/namespaces/consolidated/AdvancedNamespace.js.map +1 -0
  22. package/dist/client/namespaces/consolidated/StorageNamespace.d.ts +3 -1
  23. package/dist/client/namespaces/consolidated/StorageNamespace.d.ts.map +1 -1
  24. package/dist/client/namespaces/consolidated/StorageNamespace.js.map +1 -1
  25. package/dist/client/namespaces/consolidated/index.d.ts +1 -0
  26. package/dist/client/namespaces/consolidated/index.d.ts.map +1 -1
  27. package/dist/client/namespaces/consolidated/index.js +1 -0
  28. package/dist/client/namespaces/consolidated/index.js.map +1 -1
  29. package/dist/config/ConfigurationHelper.js +61 -61
  30. package/dist/config/defaults.d.ts.map +1 -1
  31. package/dist/config/defaults.js +9 -4
  32. package/dist/config/defaults.js.map +1 -1
  33. package/dist/config/index.d.ts +1 -0
  34. package/dist/config/index.d.ts.map +1 -1
  35. package/dist/config/index.js +2 -0
  36. package/dist/config/index.js.map +1 -1
  37. package/dist/config/modelDefaults.d.ts +67 -0
  38. package/dist/config/modelDefaults.d.ts.map +1 -0
  39. package/dist/config/modelDefaults.js +91 -0
  40. package/dist/config/modelDefaults.js.map +1 -0
  41. package/dist/core/types/index.d.ts +4 -0
  42. package/dist/core/types/index.d.ts.map +1 -1
  43. package/dist/core/types/index.js.map +1 -1
  44. package/dist/graph/GraphService.d.ts.map +1 -1
  45. package/dist/graph/GraphService.js +22 -21
  46. package/dist/graph/GraphService.js.map +1 -1
  47. package/dist/index.d.ts +1 -1
  48. package/dist/index.d.ts.map +1 -1
  49. package/dist/index.js +1 -1
  50. package/dist/index.js.map +1 -1
  51. package/dist/infrastructure/walrus/WalrusStorageService.d.ts +6 -0
  52. package/dist/infrastructure/walrus/WalrusStorageService.d.ts.map +1 -1
  53. package/dist/infrastructure/walrus/WalrusStorageService.js +23 -4
  54. package/dist/infrastructure/walrus/WalrusStorageService.js.map +1 -1
  55. package/dist/langchain/createPDWRAG.js +30 -30
  56. package/dist/pipeline/MemoryPipeline.d.ts.map +1 -1
  57. package/dist/pipeline/MemoryPipeline.js +2 -1
  58. package/dist/pipeline/MemoryPipeline.js.map +1 -1
  59. package/dist/services/EmbeddingService.d.ts +9 -0
  60. package/dist/services/EmbeddingService.d.ts.map +1 -1
  61. package/dist/services/EmbeddingService.js +31 -10
  62. package/dist/services/EmbeddingService.js.map +1 -1
  63. package/dist/services/GeminiAIService.d.ts.map +1 -1
  64. package/dist/services/GeminiAIService.js +311 -310
  65. package/dist/services/GeminiAIService.js.map +1 -1
  66. package/dist/services/MemoryIndexService.d.ts +2 -0
  67. package/dist/services/MemoryIndexService.d.ts.map +1 -1
  68. package/dist/services/MemoryIndexService.js +11 -4
  69. package/dist/services/MemoryIndexService.js.map +1 -1
  70. package/dist/services/StorageService.d.ts +4 -1
  71. package/dist/services/StorageService.d.ts.map +1 -1
  72. package/dist/services/StorageService.js.map +1 -1
  73. package/dist/services/VectorService.js +1 -1
  74. package/dist/services/VectorService.js.map +1 -1
  75. package/dist/services/storage/QuiltBatchManager.d.ts +7 -0
  76. package/dist/services/storage/QuiltBatchManager.d.ts.map +1 -1
  77. package/dist/services/storage/QuiltBatchManager.js +24 -5
  78. package/dist/services/storage/QuiltBatchManager.js.map +1 -1
  79. package/dist/services/storage/WalrusStorageManager.d.ts +10 -1
  80. package/dist/services/storage/WalrusStorageManager.d.ts.map +1 -1
  81. package/dist/services/storage/WalrusStorageManager.js +53 -12
  82. package/dist/services/storage/WalrusStorageManager.js.map +1 -1
  83. package/dist/vector/BrowserHnswIndexService.js +3 -3
  84. package/dist/vector/BrowserHnswIndexService.js.map +1 -1
  85. package/dist/vector/HnswWasmService.js +1 -1
  86. package/dist/vector/HnswWasmService.js.map +1 -1
  87. package/dist/vector/NodeHnswService.js +5 -5
  88. package/dist/vector/NodeHnswService.js.map +1 -1
  89. package/dist/vector/createHnswService.d.ts +4 -0
  90. package/dist/vector/createHnswService.d.ts.map +1 -1
  91. package/dist/vector/createHnswService.js +15 -3
  92. package/dist/vector/createHnswService.js.map +1 -1
  93. package/package.json +1 -1
  94. package/src/access/PermissionService.ts +635 -635
  95. package/src/aggregation/AggregationService.ts +389 -389
  96. package/src/ai-sdk/PDWVectorStore.ts +715 -715
  97. package/src/ai-sdk/index.ts +65 -65
  98. package/src/ai-sdk/tools.ts +460 -460
  99. package/src/ai-sdk/types.ts +404 -404
  100. package/src/batch/BatchManager.ts +597 -597
  101. package/src/batch/BatchingService.ts +429 -429
  102. package/src/batch/MemoryProcessingCache.ts +492 -492
  103. package/src/batch/index.ts +30 -30
  104. package/src/browser.ts +200 -200
  105. package/src/client/ClientMemoryManager.ts +1004 -987
  106. package/src/client/PersonalDataWallet.ts +345 -345
  107. package/src/client/SimplePDWClient.ts +1387 -1289
  108. package/src/client/factory.ts +154 -154
  109. package/src/client/namespaces/AnalyticsNamespace.ts +377 -377
  110. package/src/client/namespaces/BatchNamespace.ts +356 -356
  111. package/src/client/namespaces/CacheNamespace.ts +123 -123
  112. package/src/client/namespaces/CapabilityNamespace.ts +217 -217
  113. package/src/client/namespaces/ClassifyNamespace.ts +169 -169
  114. package/src/client/namespaces/ContextNamespace.ts +297 -297
  115. package/src/client/namespaces/EncryptionNamespace.ts +221 -221
  116. package/src/client/namespaces/GraphNamespace.ts +468 -468
  117. package/src/client/namespaces/IndexNamespace.ts +364 -361
  118. package/src/client/namespaces/MemoryNamespace.ts +1704 -1422
  119. package/src/client/namespaces/PermissionsNamespace.ts +254 -254
  120. package/src/client/namespaces/PipelineNamespace.ts +220 -220
  121. package/src/client/namespaces/StorageNamespace.ts +458 -458
  122. package/src/client/namespaces/TxNamespace.ts +260 -260
  123. package/src/client/namespaces/WalletNamespace.ts +243 -243
  124. package/src/client/namespaces/consolidated/AdvancedNamespace.ts +264 -0
  125. package/src/client/namespaces/consolidated/BlockchainNamespace.ts +607 -607
  126. package/src/client/namespaces/consolidated/SecurityNamespace.ts +648 -648
  127. package/src/client/namespaces/consolidated/StorageNamespace.ts +1143 -1141
  128. package/src/client/namespaces/consolidated/index.ts +41 -39
  129. package/src/client/signers/KeypairSigner.ts +108 -108
  130. package/src/client/signers/UnifiedSigner.ts +110 -110
  131. package/src/client/signers/WalletAdapterSigner.ts +159 -159
  132. package/src/client/signers/index.ts +26 -26
  133. package/src/config/ConfigurationHelper.ts +412 -412
  134. package/src/config/defaults.ts +56 -51
  135. package/src/config/index.ts +16 -9
  136. package/src/config/modelDefaults.ts +103 -0
  137. package/src/config/validation.ts +70 -70
  138. package/src/core/index.ts +14 -14
  139. package/src/core/interfaces/IService.ts +307 -307
  140. package/src/core/interfaces/index.ts +8 -8
  141. package/src/core/types/capability.ts +297 -297
  142. package/src/core/types/index.ts +874 -870
  143. package/src/core/types/wallet.ts +270 -270
  144. package/src/core/types.ts +9 -9
  145. package/src/core/wallet.ts +222 -222
  146. package/src/embedding/index.ts +19 -19
  147. package/src/embedding/types.ts +357 -357
  148. package/src/errors/index.ts +602 -602
  149. package/src/errors/recovery.ts +461 -461
  150. package/src/errors/validation.ts +567 -567
  151. package/src/generated/pdw/capability.ts +319 -319
  152. package/src/graph/GraphService.ts +888 -887
  153. package/src/graph/KnowledgeGraphManager.ts +728 -728
  154. package/src/graph/index.ts +25 -25
  155. package/src/index.ts +498 -498
  156. package/src/infrastructure/index.ts +22 -22
  157. package/src/infrastructure/seal/EncryptionService.ts +628 -628
  158. package/src/infrastructure/seal/SealService.ts +613 -613
  159. package/src/infrastructure/seal/index.ts +9 -9
  160. package/src/infrastructure/sui/BlockchainManager.ts +627 -627
  161. package/src/infrastructure/sui/SuiService.ts +888 -888
  162. package/src/infrastructure/sui/index.ts +9 -9
  163. package/src/infrastructure/walrus/StorageManager.ts +604 -604
  164. package/src/infrastructure/walrus/WalrusStorageService.ts +637 -612
  165. package/src/infrastructure/walrus/index.ts +9 -9
  166. package/src/langchain/createPDWRAG.ts +303 -303
  167. package/src/langchain/index.ts +47 -47
  168. package/src/permissions/ConsentRepository.browser.ts +249 -249
  169. package/src/permissions/ConsentRepository.ts +364 -364
  170. package/src/pipeline/MemoryPipeline.ts +863 -862
  171. package/src/pipeline/PipelineManager.ts +683 -683
  172. package/src/pipeline/index.ts +26 -26
  173. package/src/retrieval/AdvancedSearchService.ts +629 -629
  174. package/src/retrieval/MemoryAnalyticsService.ts +711 -711
  175. package/src/retrieval/MemoryDecryptionPipeline.ts +825 -825
  176. package/src/retrieval/index.ts +42 -42
  177. package/src/services/BatchService.ts +352 -352
  178. package/src/services/CapabilityService.ts +464 -464
  179. package/src/services/ClassifierService.ts +465 -465
  180. package/src/services/CrossContextPermissionService.ts +486 -486
  181. package/src/services/EmbeddingService.ts +796 -771
  182. package/src/services/EncryptionService.ts +712 -712
  183. package/src/services/GeminiAIService.ts +754 -753
  184. package/src/services/MemoryIndexService.ts +1009 -1003
  185. package/src/services/MemoryService.ts +369 -369
  186. package/src/services/QueryService.ts +890 -890
  187. package/src/services/StorageService.ts +1185 -1182
  188. package/src/services/TransactionService.ts +838 -838
  189. package/src/services/VectorService.ts +462 -462
  190. package/src/services/ViewService.ts +484 -484
  191. package/src/services/index.ts +25 -25
  192. package/src/services/storage/BlobAttributesManager.ts +333 -333
  193. package/src/services/storage/KnowledgeGraphManager.ts +425 -425
  194. package/src/services/storage/MemorySearchManager.ts +387 -387
  195. package/src/services/storage/QuiltBatchManager.ts +1157 -1130
  196. package/src/services/storage/WalrusMetadataManager.ts +268 -268
  197. package/src/services/storage/WalrusStorageManager.ts +333 -287
  198. package/src/services/storage/index.ts +57 -57
  199. package/src/types/index.ts +13 -13
  200. package/src/utils/index.ts +76 -76
  201. package/src/utils/memoryIndexOnChain.ts +507 -507
  202. package/src/vector/BrowserHnswIndexService.ts +758 -758
  203. package/src/vector/HnswWasmService.ts +731 -731
  204. package/src/vector/IHnswService.ts +233 -233
  205. package/src/vector/NodeHnswService.ts +833 -833
  206. package/src/vector/createHnswService.ts +147 -135
  207. package/src/vector/index.ts +56 -56
  208. package/src/wallet/ContextWalletService.ts +656 -656
  209. package/src/wallet/MainWalletService.ts +317 -317
@@ -1,468 +1,468 @@
1
- /**
2
- * Graph Namespace - Knowledge Graph Operations
3
- *
4
- * Provides knowledge graph extraction and querying:
5
- * - Extract entities and relationships from text
6
- * - Query entities
7
- * - Traverse relationship graphs
8
- * - Get statistics
9
- *
10
- * @module client/namespaces
11
- */
12
-
13
- import type { ServiceContainer } from '../SimplePDWClient';
14
-
15
- /**
16
- * Entity in knowledge graph
17
- */
18
- export interface Entity {
19
- id: string;
20
- name: string;
21
- type: string;
22
- confidence: number;
23
- metadata?: Record<string, any>;
24
- }
25
-
26
- /**
27
- * Relationship between entities
28
- */
29
- export interface Relationship {
30
- id: string;
31
- source: string;
32
- target: string;
33
- type: string;
34
- confidence: number;
35
- metadata?: Record<string, any>;
36
- }
37
-
38
- /**
39
- * Knowledge graph structure
40
- */
41
- export interface KnowledgeGraph {
42
- entities: Entity[];
43
- relationships: Relationship[];
44
- confidence: number;
45
- }
46
-
47
- /**
48
- * Graph query result
49
- */
50
- export interface GraphQueryResult {
51
- entity: Entity;
52
- relationships: Relationship[];
53
- connectedEntities: Entity[];
54
- }
55
-
56
- /**
57
- * Graph path (for traversal)
58
- */
59
- export interface GraphPath {
60
- nodes: Entity[];
61
- edges: Relationship[];
62
- totalConfidence: number;
63
- }
64
-
65
- /**
66
- * Graph statistics
67
- */
68
- export interface GraphStats {
69
- totalEntities: number;
70
- totalRelationships: number;
71
- entityTypes: Record<string, number>;
72
- relationshipTypes: Record<string, number>;
73
- avgConfidence: number;
74
- }
75
-
76
- /**
77
- * Entity filter
78
- */
79
- export interface EntityFilter {
80
- type?: string;
81
- minConfidence?: number;
82
- limit?: number;
83
- }
84
-
85
- /**
86
- * Relationship filter
87
- */
88
- export interface RelationshipFilter {
89
- type?: string;
90
- sourceId?: string;
91
- targetId?: string;
92
- minConfidence?: number;
93
- limit?: number;
94
- }
95
-
96
- /**
97
- * Traverse options
98
- */
99
- export interface TraverseOptions {
100
- maxDepth?: number;
101
- relationshipTypes?: string[];
102
- minConfidence?: number;
103
- }
104
-
105
- /**
106
- * Graph Namespace
107
- *
108
- * Handles knowledge graph operations
109
- */
110
- export class GraphNamespace {
111
- constructor(private services: ServiceContainer) {}
112
-
113
- /**
114
- * Extract knowledge graph from text
115
- *
116
- * Uses AI to extract entities and relationships.
117
- *
118
- * @param content - Text content to analyze
119
- * @returns Extracted knowledge graph
120
- *
121
- * @example
122
- * ```typescript
123
- * const graph = await pdw.graph.extract('Alice works at Google in California');
124
- * // Returns: {
125
- * // entities: [
126
- * // { id: '1', name: 'Alice', type: 'PERSON', confidence: 0.95 },
127
- * // { id: '2', name: 'Google', type: 'ORG', confidence: 0.98 },
128
- * // { id: '3', name: 'California', type: 'LOCATION', confidence: 0.92 }
129
- * // ],
130
- * // relationships: [
131
- * // { source: '1', target: '2', type: 'WORKS_AT', confidence: 0.90 }
132
- * // ]
133
- * // }
134
- * ```
135
- */
136
- async extract(content: string): Promise<KnowledgeGraph> {
137
- try {
138
- const result = await this.services.storage.extractKnowledgeGraph(
139
- content,
140
- '', // blobId (optional for extraction only)
141
- { confidenceThreshold: 0.6 }
142
- );
143
-
144
- return {
145
- entities: result.entities.map((e: any) => ({
146
- id: e.id,
147
- name: e.label || e.label,
148
- type: e.type,
149
- confidence: e.confidence || 0
150
- })),
151
- relationships: result.relationships.map((r: any) => ({
152
- id: `${r.source}-${r.target}`,
153
- source: r.source,
154
- target: r.target,
155
- type: r.type || 'related',
156
- confidence: r.confidence || 0
157
- })),
158
- confidence: result.confidence || 0
159
- };
160
- } catch (error) {
161
- throw new Error(`Graph extraction failed: ${error instanceof Error ? error.message : String(error)}`);
162
- }
163
- }
164
-
165
- /**
166
- * Query graph for a specific entity
167
- *
168
- * Gets entity and its relationships.
169
- *
170
- * @param entityId - Entity ID to query
171
- * @returns Entity with relationships and connected entities
172
- */
173
- async query(entityId: string): Promise<GraphQueryResult> {
174
- try {
175
- // Search by entity ID using searchText (StorageService doesn't have entityId param)
176
- const graphData = await this.services.storage.searchKnowledgeGraph(
177
- this.services.config.userAddress,
178
- { searchText: entityId, limit: 50 }
179
- );
180
-
181
- const entity = graphData.entities.find((e: any) => e.id === entityId);
182
- if (!entity) {
183
- throw new Error(`Entity ${entityId} not found`);
184
- }
185
-
186
- // Get relationships involving this entity
187
- const relationships = graphData.relationships.filter((r: any) =>
188
- r.source === entityId || r.target === entityId
189
- );
190
-
191
- // Get connected entity IDs
192
- const connectedIds = new Set<string>();
193
- relationships.forEach((r: any) => {
194
- if (r.source === entityId) connectedIds.add(r.target);
195
- if (r.target === entityId) connectedIds.add(r.source);
196
- });
197
-
198
- const connectedEntities = graphData.entities.filter((e: any) =>
199
- connectedIds.has(e.id)
200
- );
201
-
202
- return {
203
- entity: {
204
- id: entity.id,
205
- name: entity.label, // Entity has 'label' not 'name'
206
- type: entity.type,
207
- confidence: entity.confidence || 0
208
- },
209
- relationships: relationships.map((r: any) => ({
210
- id: `${r.source}-${r.target}`,
211
- source: r.source,
212
- target: r.target,
213
- type: r.type || 'related',
214
- confidence: r.confidence || 0
215
- })),
216
- connectedEntities: connectedEntities.map((e: any) => ({
217
- id: e.id,
218
- name: e.label || '', // Entity has 'label' not 'name'
219
- type: e.type,
220
- confidence: e.confidence || 0
221
- }))
222
- };
223
- } catch (error) {
224
- throw new Error(`Graph query failed: ${error instanceof Error ? error.message : String(error)}`);
225
- }
226
- }
227
-
228
- /**
229
- * Traverse graph from a starting entity
230
- *
231
- * Follows relationships to discover connected entities.
232
- *
233
- * @param startEntity - Entity ID to start from
234
- * @param options - Traversal options
235
- * @returns Array of paths through the graph
236
- */
237
- async traverse(
238
- startEntity: string,
239
- options: TraverseOptions = {}
240
- ): Promise<GraphPath[]> {
241
- try {
242
- const { maxDepth = 3, relationshipTypes, minConfidence = 0.5 } = options;
243
-
244
- // Get graph data
245
- const graphData = await this.services.storage.searchKnowledgeGraph(
246
- this.services.config.userAddress,
247
- { searchText: startEntity, limit: 100 }
248
- );
249
-
250
- const paths: GraphPath[] = [];
251
- const visited = new Set<string>();
252
-
253
- // BFS traversal
254
- const queue: Array<{
255
- currentEntity: string;
256
- path: Entity[];
257
- edges: Relationship[];
258
- depth: number;
259
- }> = [{
260
- currentEntity: startEntity,
261
- path: [],
262
- edges: [],
263
- depth: 0
264
- }];
265
-
266
- while (queue.length > 0 && paths.length < 20) {
267
- const { currentEntity, path, edges, depth } = queue.shift()!;
268
-
269
- if (depth >= maxDepth || visited.has(currentEntity)) {
270
- if (path.length > 0) {
271
- const totalConfidence = edges.reduce((sum, e) => sum + e.confidence, 0) / edges.length;
272
- paths.push({ nodes: path, edges, totalConfidence });
273
- }
274
- continue;
275
- }
276
-
277
- visited.add(currentEntity);
278
-
279
- // Find entity
280
- const entity = graphData.entities.find((e: any) => e.id === currentEntity);
281
- if (!entity) continue;
282
-
283
- const entityObj: Entity = {
284
- id: entity.id,
285
- name: entity.label || '', // Entity only has 'label'
286
- type: entity.type,
287
- confidence: entity.confidence || 0
288
- };
289
-
290
- // Find outgoing relationships
291
- const outgoing = graphData.relationships.filter((r: any) => {
292
- const matches = r.source === currentEntity;
293
- const typeMatch = !relationshipTypes || relationshipTypes.includes(r.type);
294
- const confMatch = (r.confidence || 0) >= minConfidence;
295
- return matches && typeMatch && confMatch;
296
- });
297
-
298
- // Add to queue
299
- outgoing.forEach((r: any) => {
300
- queue.push({
301
- currentEntity: r.target,
302
- path: [...path, entityObj],
303
- edges: [...edges, {
304
- id: `${r.source}-${r.target}`,
305
- source: r.source,
306
- target: r.target,
307
- type: r.type || 'related',
308
- confidence: r.confidence || 0
309
- }],
310
- depth: depth + 1
311
- });
312
- });
313
- }
314
-
315
- return paths.slice(0, 20); // Limit results
316
- } catch (error) {
317
- throw new Error(`Graph traversal failed: ${error instanceof Error ? error.message : String(error)}`);
318
- }
319
- }
320
-
321
- /**
322
- * Get all entities matching filter
323
- *
324
- * @param filter - Entity filter options
325
- * @returns Array of entities
326
- */
327
- async getEntities(filter: EntityFilter = {}): Promise<Entity[]> {
328
- try {
329
- const graphData = await this.services.storage.searchKnowledgeGraph(
330
- this.services.config.userAddress,
331
- { limit: filter.limit || 100 }
332
- );
333
-
334
- let entities = graphData.entities;
335
-
336
- // Apply filters
337
- if (filter.type) {
338
- entities = entities.filter((e: any) => e.type === filter.type);
339
- }
340
-
341
- if (filter.minConfidence) {
342
- entities = entities.filter((e: any) => (e.confidence || 0) >= filter.minConfidence!);
343
- }
344
-
345
- return entities.map((e: any) => ({
346
- id: e.id,
347
- name: e.label, // Entity only has 'label', not 'name'
348
- type: e.type,
349
- confidence: e.confidence || 0,
350
- metadata: e.metadata
351
- }));
352
- } catch (error) {
353
- throw new Error(`Get entities failed: ${error instanceof Error ? error.message : String(error)}`);
354
- }
355
- }
356
-
357
- /**
358
- * Get all relationships matching filter
359
- *
360
- * @param filter - Relationship filter options
361
- * @returns Array of relationships
362
- */
363
- async getRelationships(filter: RelationshipFilter = {}): Promise<Relationship[]> {
364
- try {
365
- const graphData = await this.services.storage.searchKnowledgeGraph(
366
- this.services.config.userAddress,
367
- {
368
- searchText: filter.sourceId || filter.targetId || '',
369
- limit: filter.limit || 100
370
- }
371
- );
372
-
373
- let relationships = graphData.relationships;
374
-
375
- // Apply filters
376
- if (filter.type) {
377
- relationships = relationships.filter((r: any) => r.type === filter.type);
378
- }
379
-
380
- if (filter.sourceId) {
381
- relationships = relationships.filter((r: any) => r.source === filter.sourceId);
382
- }
383
-
384
- if (filter.targetId) {
385
- relationships = relationships.filter((r: any) => r.target === filter.targetId);
386
- }
387
-
388
- if (filter.minConfidence) {
389
- relationships = relationships.filter((r: any) =>
390
- (r.confidence || 0) >= filter.minConfidence!
391
- );
392
- }
393
-
394
- return relationships.map((r: any) => ({
395
- id: `${r.source}-${r.target}`,
396
- source: r.source,
397
- target: r.target,
398
- type: r.type || 'related',
399
- confidence: r.confidence || 0,
400
- metadata: r.metadata
401
- }));
402
- } catch (error) {
403
- throw new Error(`Get relationships failed: ${error instanceof Error ? error.message : String(error)}`);
404
- }
405
- }
406
-
407
- /**
408
- * Get knowledge graph statistics
409
- *
410
- * Calculates average confidence from entity and relationship confidence scores.
411
- *
412
- * @returns Graph statistics
413
- */
414
- async stats(): Promise<GraphStats> {
415
- try {
416
- const stats = await this.services.storage.getGraphStatistics(
417
- this.services.config.userAddress
418
- );
419
-
420
- // Calculate average confidence from graph entities and relationships
421
- let avgConfidence = 0;
422
-
423
- if (stats.totalEntities > 0 || stats.totalRelationships > 0) {
424
- // Get graph data to calculate average confidence
425
- try {
426
- const graphData = await this.services.storage.searchKnowledgeGraph(
427
- this.services.config.userAddress,
428
- { limit: 1000 }
429
- );
430
-
431
- const confidences: number[] = [];
432
-
433
- // Collect entity confidences
434
- for (const entity of graphData.entities || []) {
435
- if (typeof entity.confidence === 'number') {
436
- confidences.push(entity.confidence);
437
- }
438
- }
439
-
440
- // Collect relationship confidences
441
- for (const rel of graphData.relationships || []) {
442
- if (typeof rel.confidence === 'number') {
443
- confidences.push(rel.confidence);
444
- }
445
- }
446
-
447
- // Calculate average
448
- if (confidences.length > 0) {
449
- avgConfidence = confidences.reduce((sum, c) => sum + c, 0) / confidences.length;
450
- }
451
- } catch {
452
- // If we can't get graph data for confidence calculation, use 0
453
- avgConfidence = 0;
454
- }
455
- }
456
-
457
- return {
458
- totalEntities: stats.totalEntities,
459
- totalRelationships: stats.totalRelationships,
460
- entityTypes: stats.entityTypes,
461
- relationshipTypes: stats.relationshipTypes,
462
- avgConfidence
463
- };
464
- } catch (error) {
465
- throw new Error(`Get graph stats failed: ${error instanceof Error ? error.message : String(error)}`);
466
- }
467
- }
468
- }
1
+ /**
2
+ * Graph Namespace - Knowledge Graph Operations
3
+ *
4
+ * Provides knowledge graph extraction and querying:
5
+ * - Extract entities and relationships from text
6
+ * - Query entities
7
+ * - Traverse relationship graphs
8
+ * - Get statistics
9
+ *
10
+ * @module client/namespaces
11
+ */
12
+
13
+ import type { ServiceContainer } from '../SimplePDWClient';
14
+
15
+ /**
16
+ * Entity in knowledge graph
17
+ */
18
+ export interface Entity {
19
+ id: string;
20
+ name: string;
21
+ type: string;
22
+ confidence: number;
23
+ metadata?: Record<string, any>;
24
+ }
25
+
26
+ /**
27
+ * Relationship between entities
28
+ */
29
+ export interface Relationship {
30
+ id: string;
31
+ source: string;
32
+ target: string;
33
+ type: string;
34
+ confidence: number;
35
+ metadata?: Record<string, any>;
36
+ }
37
+
38
+ /**
39
+ * Knowledge graph structure
40
+ */
41
+ export interface KnowledgeGraph {
42
+ entities: Entity[];
43
+ relationships: Relationship[];
44
+ confidence: number;
45
+ }
46
+
47
+ /**
48
+ * Graph query result
49
+ */
50
+ export interface GraphQueryResult {
51
+ entity: Entity;
52
+ relationships: Relationship[];
53
+ connectedEntities: Entity[];
54
+ }
55
+
56
+ /**
57
+ * Graph path (for traversal)
58
+ */
59
+ export interface GraphPath {
60
+ nodes: Entity[];
61
+ edges: Relationship[];
62
+ totalConfidence: number;
63
+ }
64
+
65
+ /**
66
+ * Graph statistics
67
+ */
68
+ export interface GraphStats {
69
+ totalEntities: number;
70
+ totalRelationships: number;
71
+ entityTypes: Record<string, number>;
72
+ relationshipTypes: Record<string, number>;
73
+ avgConfidence: number;
74
+ }
75
+
76
+ /**
77
+ * Entity filter
78
+ */
79
+ export interface EntityFilter {
80
+ type?: string;
81
+ minConfidence?: number;
82
+ limit?: number;
83
+ }
84
+
85
+ /**
86
+ * Relationship filter
87
+ */
88
+ export interface RelationshipFilter {
89
+ type?: string;
90
+ sourceId?: string;
91
+ targetId?: string;
92
+ minConfidence?: number;
93
+ limit?: number;
94
+ }
95
+
96
+ /**
97
+ * Traverse options
98
+ */
99
+ export interface TraverseOptions {
100
+ maxDepth?: number;
101
+ relationshipTypes?: string[];
102
+ minConfidence?: number;
103
+ }
104
+
105
+ /**
106
+ * Graph Namespace
107
+ *
108
+ * Handles knowledge graph operations
109
+ */
110
+ export class GraphNamespace {
111
+ constructor(private services: ServiceContainer) {}
112
+
113
+ /**
114
+ * Extract knowledge graph from text
115
+ *
116
+ * Uses AI to extract entities and relationships.
117
+ *
118
+ * @param content - Text content to analyze
119
+ * @returns Extracted knowledge graph
120
+ *
121
+ * @example
122
+ * ```typescript
123
+ * const graph = await pdw.graph.extract('Alice works at Google in California');
124
+ * // Returns: {
125
+ * // entities: [
126
+ * // { id: '1', name: 'Alice', type: 'PERSON', confidence: 0.95 },
127
+ * // { id: '2', name: 'Google', type: 'ORG', confidence: 0.98 },
128
+ * // { id: '3', name: 'California', type: 'LOCATION', confidence: 0.92 }
129
+ * // ],
130
+ * // relationships: [
131
+ * // { source: '1', target: '2', type: 'WORKS_AT', confidence: 0.90 }
132
+ * // ]
133
+ * // }
134
+ * ```
135
+ */
136
+ async extract(content: string): Promise<KnowledgeGraph> {
137
+ try {
138
+ const result = await this.services.storage.extractKnowledgeGraph(
139
+ content,
140
+ '', // blobId (optional for extraction only)
141
+ { confidenceThreshold: 0.6 }
142
+ );
143
+
144
+ return {
145
+ entities: result.entities.map((e: any) => ({
146
+ id: e.id,
147
+ name: e.label || e.label,
148
+ type: e.type,
149
+ confidence: e.confidence || 0
150
+ })),
151
+ relationships: result.relationships.map((r: any) => ({
152
+ id: `${r.source}-${r.target}`,
153
+ source: r.source,
154
+ target: r.target,
155
+ type: r.type || 'related',
156
+ confidence: r.confidence || 0
157
+ })),
158
+ confidence: result.confidence || 0
159
+ };
160
+ } catch (error) {
161
+ throw new Error(`Graph extraction failed: ${error instanceof Error ? error.message : String(error)}`);
162
+ }
163
+ }
164
+
165
+ /**
166
+ * Query graph for a specific entity
167
+ *
168
+ * Gets entity and its relationships.
169
+ *
170
+ * @param entityId - Entity ID to query
171
+ * @returns Entity with relationships and connected entities
172
+ */
173
+ async query(entityId: string): Promise<GraphQueryResult> {
174
+ try {
175
+ // Search by entity ID using searchText (StorageService doesn't have entityId param)
176
+ const graphData = await this.services.storage.searchKnowledgeGraph(
177
+ this.services.config.userAddress,
178
+ { searchText: entityId, limit: 50 }
179
+ );
180
+
181
+ const entity = graphData.entities.find((e: any) => e.id === entityId);
182
+ if (!entity) {
183
+ throw new Error(`Entity ${entityId} not found`);
184
+ }
185
+
186
+ // Get relationships involving this entity
187
+ const relationships = graphData.relationships.filter((r: any) =>
188
+ r.source === entityId || r.target === entityId
189
+ );
190
+
191
+ // Get connected entity IDs
192
+ const connectedIds = new Set<string>();
193
+ relationships.forEach((r: any) => {
194
+ if (r.source === entityId) connectedIds.add(r.target);
195
+ if (r.target === entityId) connectedIds.add(r.source);
196
+ });
197
+
198
+ const connectedEntities = graphData.entities.filter((e: any) =>
199
+ connectedIds.has(e.id)
200
+ );
201
+
202
+ return {
203
+ entity: {
204
+ id: entity.id,
205
+ name: entity.label, // Entity has 'label' not 'name'
206
+ type: entity.type,
207
+ confidence: entity.confidence || 0
208
+ },
209
+ relationships: relationships.map((r: any) => ({
210
+ id: `${r.source}-${r.target}`,
211
+ source: r.source,
212
+ target: r.target,
213
+ type: r.type || 'related',
214
+ confidence: r.confidence || 0
215
+ })),
216
+ connectedEntities: connectedEntities.map((e: any) => ({
217
+ id: e.id,
218
+ name: e.label || '', // Entity has 'label' not 'name'
219
+ type: e.type,
220
+ confidence: e.confidence || 0
221
+ }))
222
+ };
223
+ } catch (error) {
224
+ throw new Error(`Graph query failed: ${error instanceof Error ? error.message : String(error)}`);
225
+ }
226
+ }
227
+
228
+ /**
229
+ * Traverse graph from a starting entity
230
+ *
231
+ * Follows relationships to discover connected entities.
232
+ *
233
+ * @param startEntity - Entity ID to start from
234
+ * @param options - Traversal options
235
+ * @returns Array of paths through the graph
236
+ */
237
+ async traverse(
238
+ startEntity: string,
239
+ options: TraverseOptions = {}
240
+ ): Promise<GraphPath[]> {
241
+ try {
242
+ const { maxDepth = 3, relationshipTypes, minConfidence = 0.5 } = options;
243
+
244
+ // Get graph data
245
+ const graphData = await this.services.storage.searchKnowledgeGraph(
246
+ this.services.config.userAddress,
247
+ { searchText: startEntity, limit: 100 }
248
+ );
249
+
250
+ const paths: GraphPath[] = [];
251
+ const visited = new Set<string>();
252
+
253
+ // BFS traversal
254
+ const queue: Array<{
255
+ currentEntity: string;
256
+ path: Entity[];
257
+ edges: Relationship[];
258
+ depth: number;
259
+ }> = [{
260
+ currentEntity: startEntity,
261
+ path: [],
262
+ edges: [],
263
+ depth: 0
264
+ }];
265
+
266
+ while (queue.length > 0 && paths.length < 20) {
267
+ const { currentEntity, path, edges, depth } = queue.shift()!;
268
+
269
+ if (depth >= maxDepth || visited.has(currentEntity)) {
270
+ if (path.length > 0) {
271
+ const totalConfidence = edges.reduce((sum, e) => sum + e.confidence, 0) / edges.length;
272
+ paths.push({ nodes: path, edges, totalConfidence });
273
+ }
274
+ continue;
275
+ }
276
+
277
+ visited.add(currentEntity);
278
+
279
+ // Find entity
280
+ const entity = graphData.entities.find((e: any) => e.id === currentEntity);
281
+ if (!entity) continue;
282
+
283
+ const entityObj: Entity = {
284
+ id: entity.id,
285
+ name: entity.label || '', // Entity only has 'label'
286
+ type: entity.type,
287
+ confidence: entity.confidence || 0
288
+ };
289
+
290
+ // Find outgoing relationships
291
+ const outgoing = graphData.relationships.filter((r: any) => {
292
+ const matches = r.source === currentEntity;
293
+ const typeMatch = !relationshipTypes || relationshipTypes.includes(r.type);
294
+ const confMatch = (r.confidence || 0) >= minConfidence;
295
+ return matches && typeMatch && confMatch;
296
+ });
297
+
298
+ // Add to queue
299
+ outgoing.forEach((r: any) => {
300
+ queue.push({
301
+ currentEntity: r.target,
302
+ path: [...path, entityObj],
303
+ edges: [...edges, {
304
+ id: `${r.source}-${r.target}`,
305
+ source: r.source,
306
+ target: r.target,
307
+ type: r.type || 'related',
308
+ confidence: r.confidence || 0
309
+ }],
310
+ depth: depth + 1
311
+ });
312
+ });
313
+ }
314
+
315
+ return paths.slice(0, 20); // Limit results
316
+ } catch (error) {
317
+ throw new Error(`Graph traversal failed: ${error instanceof Error ? error.message : String(error)}`);
318
+ }
319
+ }
320
+
321
+ /**
322
+ * Get all entities matching filter
323
+ *
324
+ * @param filter - Entity filter options
325
+ * @returns Array of entities
326
+ */
327
+ async getEntities(filter: EntityFilter = {}): Promise<Entity[]> {
328
+ try {
329
+ const graphData = await this.services.storage.searchKnowledgeGraph(
330
+ this.services.config.userAddress,
331
+ { limit: filter.limit || 100 }
332
+ );
333
+
334
+ let entities = graphData.entities;
335
+
336
+ // Apply filters
337
+ if (filter.type) {
338
+ entities = entities.filter((e: any) => e.type === filter.type);
339
+ }
340
+
341
+ if (filter.minConfidence) {
342
+ entities = entities.filter((e: any) => (e.confidence || 0) >= filter.minConfidence!);
343
+ }
344
+
345
+ return entities.map((e: any) => ({
346
+ id: e.id,
347
+ name: e.label, // Entity only has 'label', not 'name'
348
+ type: e.type,
349
+ confidence: e.confidence || 0,
350
+ metadata: e.metadata
351
+ }));
352
+ } catch (error) {
353
+ throw new Error(`Get entities failed: ${error instanceof Error ? error.message : String(error)}`);
354
+ }
355
+ }
356
+
357
+ /**
358
+ * Get all relationships matching filter
359
+ *
360
+ * @param filter - Relationship filter options
361
+ * @returns Array of relationships
362
+ */
363
+ async getRelationships(filter: RelationshipFilter = {}): Promise<Relationship[]> {
364
+ try {
365
+ const graphData = await this.services.storage.searchKnowledgeGraph(
366
+ this.services.config.userAddress,
367
+ {
368
+ searchText: filter.sourceId || filter.targetId || '',
369
+ limit: filter.limit || 100
370
+ }
371
+ );
372
+
373
+ let relationships = graphData.relationships;
374
+
375
+ // Apply filters
376
+ if (filter.type) {
377
+ relationships = relationships.filter((r: any) => r.type === filter.type);
378
+ }
379
+
380
+ if (filter.sourceId) {
381
+ relationships = relationships.filter((r: any) => r.source === filter.sourceId);
382
+ }
383
+
384
+ if (filter.targetId) {
385
+ relationships = relationships.filter((r: any) => r.target === filter.targetId);
386
+ }
387
+
388
+ if (filter.minConfidence) {
389
+ relationships = relationships.filter((r: any) =>
390
+ (r.confidence || 0) >= filter.minConfidence!
391
+ );
392
+ }
393
+
394
+ return relationships.map((r: any) => ({
395
+ id: `${r.source}-${r.target}`,
396
+ source: r.source,
397
+ target: r.target,
398
+ type: r.type || 'related',
399
+ confidence: r.confidence || 0,
400
+ metadata: r.metadata
401
+ }));
402
+ } catch (error) {
403
+ throw new Error(`Get relationships failed: ${error instanceof Error ? error.message : String(error)}`);
404
+ }
405
+ }
406
+
407
+ /**
408
+ * Get knowledge graph statistics
409
+ *
410
+ * Calculates average confidence from entity and relationship confidence scores.
411
+ *
412
+ * @returns Graph statistics
413
+ */
414
+ async stats(): Promise<GraphStats> {
415
+ try {
416
+ const stats = await this.services.storage.getGraphStatistics(
417
+ this.services.config.userAddress
418
+ );
419
+
420
+ // Calculate average confidence from graph entities and relationships
421
+ let avgConfidence = 0;
422
+
423
+ if (stats.totalEntities > 0 || stats.totalRelationships > 0) {
424
+ // Get graph data to calculate average confidence
425
+ try {
426
+ const graphData = await this.services.storage.searchKnowledgeGraph(
427
+ this.services.config.userAddress,
428
+ { limit: 1000 }
429
+ );
430
+
431
+ const confidences: number[] = [];
432
+
433
+ // Collect entity confidences
434
+ for (const entity of graphData.entities || []) {
435
+ if (typeof entity.confidence === 'number') {
436
+ confidences.push(entity.confidence);
437
+ }
438
+ }
439
+
440
+ // Collect relationship confidences
441
+ for (const rel of graphData.relationships || []) {
442
+ if (typeof rel.confidence === 'number') {
443
+ confidences.push(rel.confidence);
444
+ }
445
+ }
446
+
447
+ // Calculate average
448
+ if (confidences.length > 0) {
449
+ avgConfidence = confidences.reduce((sum, c) => sum + c, 0) / confidences.length;
450
+ }
451
+ } catch {
452
+ // If we can't get graph data for confidence calculation, use 0
453
+ avgConfidence = 0;
454
+ }
455
+ }
456
+
457
+ return {
458
+ totalEntities: stats.totalEntities,
459
+ totalRelationships: stats.totalRelationships,
460
+ entityTypes: stats.entityTypes,
461
+ relationshipTypes: stats.relationshipTypes,
462
+ avgConfidence
463
+ };
464
+ } catch (error) {
465
+ throw new Error(`Get graph stats failed: ${error instanceof Error ? error.message : String(error)}`);
466
+ }
467
+ }
468
+ }