@cmdoss/memwal-sdk 0.6.2 → 0.8.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 (247) hide show
  1. package/ARCHITECTURE.md +547 -547
  2. package/BENCHMARKS.md +238 -238
  3. package/README.md +310 -181
  4. package/dist/ai-sdk/tools.d.ts +2 -2
  5. package/dist/ai-sdk/tools.js +2 -2
  6. package/dist/client/ClientMemoryManager.js +2 -2
  7. package/dist/client/ClientMemoryManager.js.map +1 -1
  8. package/dist/client/PersonalDataWallet.d.ts.map +1 -1
  9. package/dist/client/SimplePDWClient.d.ts +29 -1
  10. package/dist/client/SimplePDWClient.d.ts.map +1 -1
  11. package/dist/client/SimplePDWClient.js +45 -13
  12. package/dist/client/SimplePDWClient.js.map +1 -1
  13. package/dist/client/namespaces/EmbeddingsNamespace.d.ts +1 -1
  14. package/dist/client/namespaces/EmbeddingsNamespace.js +1 -1
  15. package/dist/client/namespaces/MemoryNamespace.d.ts +31 -0
  16. package/dist/client/namespaces/MemoryNamespace.d.ts.map +1 -1
  17. package/dist/client/namespaces/MemoryNamespace.js +272 -39
  18. package/dist/client/namespaces/MemoryNamespace.js.map +1 -1
  19. package/dist/client/namespaces/consolidated/AINamespace.d.ts +2 -2
  20. package/dist/client/namespaces/consolidated/AINamespace.js +2 -2
  21. package/dist/client/namespaces/consolidated/BlockchainNamespace.d.ts +12 -2
  22. package/dist/client/namespaces/consolidated/BlockchainNamespace.d.ts.map +1 -1
  23. package/dist/client/namespaces/consolidated/BlockchainNamespace.js +62 -4
  24. package/dist/client/namespaces/consolidated/BlockchainNamespace.js.map +1 -1
  25. package/dist/client/namespaces/consolidated/StorageNamespace.d.ts +67 -2
  26. package/dist/client/namespaces/consolidated/StorageNamespace.d.ts.map +1 -1
  27. package/dist/client/namespaces/consolidated/StorageNamespace.js +549 -16
  28. package/dist/client/namespaces/consolidated/StorageNamespace.js.map +1 -1
  29. package/dist/config/ConfigurationHelper.js +61 -61
  30. package/dist/config/defaults.js +2 -2
  31. package/dist/config/defaults.js.map +1 -1
  32. package/dist/graph/GraphService.js +21 -21
  33. package/dist/graph/GraphService.js.map +1 -1
  34. package/dist/index.d.ts +3 -1
  35. package/dist/index.d.ts.map +1 -1
  36. package/dist/index.js +3 -1
  37. package/dist/index.js.map +1 -1
  38. package/dist/infrastructure/seal/EncryptionService.d.ts +9 -5
  39. package/dist/infrastructure/seal/EncryptionService.d.ts.map +1 -1
  40. package/dist/infrastructure/seal/EncryptionService.js +37 -15
  41. package/dist/infrastructure/seal/EncryptionService.js.map +1 -1
  42. package/dist/infrastructure/seal/SealService.d.ts +13 -5
  43. package/dist/infrastructure/seal/SealService.d.ts.map +1 -1
  44. package/dist/infrastructure/seal/SealService.js +36 -34
  45. package/dist/infrastructure/seal/SealService.js.map +1 -1
  46. package/dist/langchain/createPDWRAG.js +30 -30
  47. package/dist/retrieval/MemoryDecryptionPipeline.d.ts.map +1 -1
  48. package/dist/retrieval/MemoryDecryptionPipeline.js +2 -1
  49. package/dist/retrieval/MemoryDecryptionPipeline.js.map +1 -1
  50. package/dist/retrieval/MemoryRetrievalService.d.ts +31 -0
  51. package/dist/retrieval/MemoryRetrievalService.d.ts.map +1 -1
  52. package/dist/retrieval/MemoryRetrievalService.js +44 -4
  53. package/dist/retrieval/MemoryRetrievalService.js.map +1 -1
  54. package/dist/services/CapabilityService.d.ts.map +1 -1
  55. package/dist/services/CapabilityService.js +30 -14
  56. package/dist/services/CapabilityService.js.map +1 -1
  57. package/dist/services/CrossContextPermissionService.d.ts.map +1 -1
  58. package/dist/services/CrossContextPermissionService.js +9 -7
  59. package/dist/services/CrossContextPermissionService.js.map +1 -1
  60. package/dist/services/EmbeddingService.d.ts +28 -1
  61. package/dist/services/EmbeddingService.d.ts.map +1 -1
  62. package/dist/services/EmbeddingService.js +54 -0
  63. package/dist/services/EmbeddingService.js.map +1 -1
  64. package/dist/services/EncryptionService.d.ts.map +1 -1
  65. package/dist/services/EncryptionService.js +6 -5
  66. package/dist/services/EncryptionService.js.map +1 -1
  67. package/dist/services/GeminiAIService.js +309 -309
  68. package/dist/services/IndexManager.d.ts +5 -1
  69. package/dist/services/IndexManager.d.ts.map +1 -1
  70. package/dist/services/IndexManager.js +17 -40
  71. package/dist/services/IndexManager.js.map +1 -1
  72. package/dist/services/QueryService.js +1 -1
  73. package/dist/services/QueryService.js.map +1 -1
  74. package/dist/services/StorageService.d.ts +11 -0
  75. package/dist/services/StorageService.d.ts.map +1 -1
  76. package/dist/services/StorageService.js +73 -10
  77. package/dist/services/StorageService.js.map +1 -1
  78. package/dist/services/TransactionService.d.ts +20 -0
  79. package/dist/services/TransactionService.d.ts.map +1 -1
  80. package/dist/services/TransactionService.js +43 -0
  81. package/dist/services/TransactionService.js.map +1 -1
  82. package/dist/services/ViewService.js +2 -2
  83. package/dist/services/ViewService.js.map +1 -1
  84. package/dist/services/storage/QuiltBatchManager.d.ts +101 -1
  85. package/dist/services/storage/QuiltBatchManager.d.ts.map +1 -1
  86. package/dist/services/storage/QuiltBatchManager.js +410 -20
  87. package/dist/services/storage/QuiltBatchManager.js.map +1 -1
  88. package/dist/services/storage/index.d.ts +1 -1
  89. package/dist/services/storage/index.d.ts.map +1 -1
  90. package/dist/services/storage/index.js.map +1 -1
  91. package/dist/utils/LRUCache.d.ts +106 -0
  92. package/dist/utils/LRUCache.d.ts.map +1 -0
  93. package/dist/utils/LRUCache.js +281 -0
  94. package/dist/utils/LRUCache.js.map +1 -0
  95. package/dist/utils/index.d.ts +1 -0
  96. package/dist/utils/index.d.ts.map +1 -1
  97. package/dist/utils/index.js +2 -0
  98. package/dist/utils/index.js.map +1 -1
  99. package/dist/utils/memoryIndexOnChain.d.ts +212 -0
  100. package/dist/utils/memoryIndexOnChain.d.ts.map +1 -0
  101. package/dist/utils/memoryIndexOnChain.js +312 -0
  102. package/dist/utils/memoryIndexOnChain.js.map +1 -0
  103. package/dist/utils/rebuildIndexNode.d.ts +29 -0
  104. package/dist/utils/rebuildIndexNode.d.ts.map +1 -1
  105. package/dist/utils/rebuildIndexNode.js +366 -98
  106. package/dist/utils/rebuildIndexNode.js.map +1 -1
  107. package/dist/vector/HnswWasmService.d.ts +20 -5
  108. package/dist/vector/HnswWasmService.d.ts.map +1 -1
  109. package/dist/vector/HnswWasmService.js +73 -40
  110. package/dist/vector/HnswWasmService.js.map +1 -1
  111. package/dist/vector/IHnswService.d.ts +10 -1
  112. package/dist/vector/IHnswService.d.ts.map +1 -1
  113. package/dist/vector/IHnswService.js.map +1 -1
  114. package/dist/vector/NodeHnswService.d.ts +16 -0
  115. package/dist/vector/NodeHnswService.d.ts.map +1 -1
  116. package/dist/vector/NodeHnswService.js +84 -5
  117. package/dist/vector/NodeHnswService.js.map +1 -1
  118. package/dist/vector/createHnswService.d.ts +1 -1
  119. package/dist/vector/createHnswService.js +1 -1
  120. package/dist/vector/index.d.ts +1 -1
  121. package/dist/vector/index.js +1 -1
  122. package/package.json +157 -157
  123. package/src/access/PermissionService.ts +635 -635
  124. package/src/aggregation/AggregationService.ts +389 -389
  125. package/src/ai-sdk/PDWVectorStore.ts +715 -715
  126. package/src/ai-sdk/index.ts +65 -65
  127. package/src/ai-sdk/tools.ts +460 -460
  128. package/src/ai-sdk/types.ts +404 -404
  129. package/src/batch/BatchManager.ts +597 -597
  130. package/src/batch/BatchingService.ts +429 -429
  131. package/src/batch/MemoryProcessingCache.ts +492 -492
  132. package/src/batch/index.ts +30 -30
  133. package/src/browser.ts +200 -200
  134. package/src/client/ClientMemoryManager.ts +987 -987
  135. package/src/client/PersonalDataWallet.ts +345 -345
  136. package/src/client/SimplePDWClient.ts +1289 -1222
  137. package/src/client/factory.ts +154 -154
  138. package/src/client/namespaces/AnalyticsNamespace.ts +377 -377
  139. package/src/client/namespaces/BatchNamespace.ts +356 -356
  140. package/src/client/namespaces/CacheNamespace.ts +123 -123
  141. package/src/client/namespaces/CapabilityNamespace.ts +217 -217
  142. package/src/client/namespaces/ClassifyNamespace.ts +169 -169
  143. package/src/client/namespaces/ContextNamespace.ts +297 -297
  144. package/src/client/namespaces/EmbeddingsNamespace.ts +99 -99
  145. package/src/client/namespaces/EncryptionNamespace.ts +221 -221
  146. package/src/client/namespaces/GraphNamespace.ts +468 -468
  147. package/src/client/namespaces/IndexNamespace.ts +361 -361
  148. package/src/client/namespaces/MemoryNamespace.ts +1422 -1135
  149. package/src/client/namespaces/PermissionsNamespace.ts +254 -254
  150. package/src/client/namespaces/PipelineNamespace.ts +220 -220
  151. package/src/client/namespaces/SearchNamespace.ts +1049 -1049
  152. package/src/client/namespaces/StorageNamespace.ts +458 -458
  153. package/src/client/namespaces/TxNamespace.ts +260 -260
  154. package/src/client/namespaces/WalletNamespace.ts +243 -243
  155. package/src/client/namespaces/consolidated/AINamespace.ts +449 -449
  156. package/src/client/namespaces/consolidated/BlockchainNamespace.ts +607 -546
  157. package/src/client/namespaces/consolidated/SecurityNamespace.ts +648 -648
  158. package/src/client/namespaces/consolidated/StorageNamespace.ts +1141 -497
  159. package/src/client/namespaces/consolidated/index.ts +39 -39
  160. package/src/client/signers/KeypairSigner.ts +108 -108
  161. package/src/client/signers/UnifiedSigner.ts +110 -110
  162. package/src/client/signers/WalletAdapterSigner.ts +159 -159
  163. package/src/client/signers/index.ts +26 -26
  164. package/src/config/ConfigurationHelper.ts +412 -412
  165. package/src/config/defaults.ts +51 -51
  166. package/src/config/index.ts +8 -8
  167. package/src/config/validation.ts +70 -70
  168. package/src/core/index.ts +14 -14
  169. package/src/core/interfaces/IService.ts +307 -307
  170. package/src/core/interfaces/index.ts +8 -8
  171. package/src/core/types/capability.ts +297 -297
  172. package/src/core/types/index.ts +870 -870
  173. package/src/core/types/wallet.ts +270 -270
  174. package/src/core/types.ts +9 -9
  175. package/src/core/wallet.ts +222 -222
  176. package/src/embedding/index.ts +19 -19
  177. package/src/embedding/types.ts +357 -357
  178. package/src/errors/index.ts +602 -602
  179. package/src/errors/recovery.ts +461 -461
  180. package/src/errors/validation.ts +567 -567
  181. package/src/generated/pdw/capability.ts +319 -319
  182. package/src/graph/GraphService.ts +887 -887
  183. package/src/graph/KnowledgeGraphManager.ts +728 -728
  184. package/src/graph/index.ts +25 -25
  185. package/src/index.ts +498 -474
  186. package/src/infrastructure/index.ts +22 -22
  187. package/src/infrastructure/seal/EncryptionService.ts +628 -603
  188. package/src/infrastructure/seal/SealService.ts +613 -615
  189. package/src/infrastructure/seal/index.ts +9 -9
  190. package/src/infrastructure/sui/BlockchainManager.ts +627 -627
  191. package/src/infrastructure/sui/SuiService.ts +888 -888
  192. package/src/infrastructure/sui/index.ts +9 -9
  193. package/src/infrastructure/walrus/StorageManager.ts +604 -604
  194. package/src/infrastructure/walrus/WalrusStorageService.ts +612 -612
  195. package/src/infrastructure/walrus/index.ts +9 -9
  196. package/src/langchain/PDWEmbeddings.ts +145 -145
  197. package/src/langchain/PDWVectorStore.ts +456 -456
  198. package/src/langchain/createPDWRAG.ts +303 -303
  199. package/src/langchain/index.ts +47 -47
  200. package/src/permissions/ConsentRepository.browser.ts +249 -249
  201. package/src/permissions/ConsentRepository.ts +364 -364
  202. package/src/pipeline/MemoryPipeline.ts +862 -862
  203. package/src/pipeline/PipelineManager.ts +683 -683
  204. package/src/pipeline/index.ts +26 -26
  205. package/src/retrieval/AdvancedSearchService.ts +629 -629
  206. package/src/retrieval/MemoryAnalyticsService.ts +711 -711
  207. package/src/retrieval/MemoryDecryptionPipeline.ts +825 -824
  208. package/src/retrieval/MemoryRetrievalService.ts +904 -830
  209. package/src/retrieval/index.ts +42 -42
  210. package/src/services/BatchService.ts +352 -352
  211. package/src/services/CapabilityService.ts +464 -448
  212. package/src/services/ClassifierService.ts +465 -465
  213. package/src/services/CrossContextPermissionService.ts +486 -484
  214. package/src/services/EmbeddingService.ts +771 -706
  215. package/src/services/EncryptionService.ts +712 -711
  216. package/src/services/GeminiAIService.ts +753 -753
  217. package/src/services/IndexManager.ts +977 -1004
  218. package/src/services/MemoryIndexService.ts +1003 -1003
  219. package/src/services/MemoryService.ts +369 -369
  220. package/src/services/QueryService.ts +890 -890
  221. package/src/services/StorageService.ts +1182 -1111
  222. package/src/services/TransactionService.ts +838 -790
  223. package/src/services/VectorService.ts +462 -462
  224. package/src/services/ViewService.ts +484 -484
  225. package/src/services/index.ts +25 -25
  226. package/src/services/storage/BlobAttributesManager.ts +333 -333
  227. package/src/services/storage/KnowledgeGraphManager.ts +425 -425
  228. package/src/services/storage/MemorySearchManager.ts +387 -387
  229. package/src/services/storage/QuiltBatchManager.ts +1130 -660
  230. package/src/services/storage/WalrusMetadataManager.ts +268 -268
  231. package/src/services/storage/WalrusStorageManager.ts +287 -287
  232. package/src/services/storage/index.ts +57 -52
  233. package/src/types/index.ts +13 -13
  234. package/src/utils/LRUCache.ts +378 -0
  235. package/src/utils/index.ts +76 -68
  236. package/src/utils/memoryIndexOnChain.ts +507 -0
  237. package/src/utils/rebuildIndex.ts +290 -290
  238. package/src/utils/rebuildIndexNode.ts +771 -424
  239. package/src/vector/BrowserHnswIndexService.ts +758 -758
  240. package/src/vector/HnswWasmService.ts +731 -679
  241. package/src/vector/IHnswService.ts +233 -224
  242. package/src/vector/NodeHnswService.ts +833 -735
  243. package/src/vector/VectorManager.ts +478 -478
  244. package/src/vector/createHnswService.ts +135 -135
  245. package/src/vector/index.ts +56 -56
  246. package/src/wallet/ContextWalletService.ts +656 -656
  247. package/src/wallet/MainWalletService.ts +317 -317
@@ -0,0 +1,507 @@
1
+ /**
2
+ * Memory Index On-Chain Utilities
3
+ *
4
+ * Utilities for managing MemoryIndex object on Sui blockchain:
5
+ * - Reading current MemoryIndex state from chain
6
+ * - Updating blob IDs after Walrus sync
7
+ * - Creating new MemoryIndex if doesn't exist
8
+ *
9
+ * Environment Variables:
10
+ * - MEMORY_INDEX_ID: Sui object ID of the MemoryIndex
11
+ * - INDEX_BLOB_ID: Current Walrus blob ID for HNSW index (updated after sync)
12
+ * - GRAPH_BLOB_ID: Current Walrus blob ID for knowledge graph
13
+ */
14
+
15
+ import { SuiClient } from '@mysten/sui/client';
16
+ import { Transaction } from '@mysten/sui/transactions';
17
+ import type { Signer } from '@mysten/sui/cryptography';
18
+
19
+ /**
20
+ * On-chain MemoryIndex object structure
21
+ */
22
+ export interface OnChainMemoryIndex {
23
+ /** Sui object ID */
24
+ objectId: string;
25
+ /** Owner address */
26
+ owner: string;
27
+ /** Version number for optimistic locking */
28
+ version: number;
29
+ /** Walrus blob ID for HNSW index */
30
+ indexBlobId: string;
31
+ /** Walrus blob ID for knowledge graph */
32
+ graphBlobId: string;
33
+ }
34
+
35
+ /**
36
+ * Options for getting MemoryIndex from chain
37
+ */
38
+ export interface GetMemoryIndexOptions {
39
+ /** Sui client instance */
40
+ client: SuiClient;
41
+ /** MemoryIndex object ID (from MEMORY_INDEX_ID env var) */
42
+ memoryIndexId: string;
43
+ }
44
+
45
+ /**
46
+ * Options for updating MemoryIndex on-chain
47
+ */
48
+ export interface UpdateMemoryIndexOnChainOptions {
49
+ /** Sui client instance */
50
+ client: SuiClient;
51
+ /** Signer for transaction */
52
+ signer: Signer;
53
+ /** Package ID of the PDW contract */
54
+ packageId: string;
55
+ /** MemoryIndex object ID */
56
+ memoryIndexId: string;
57
+ /** Current version for optimistic locking */
58
+ expectedVersion: number;
59
+ /** New index blob ID from Walrus */
60
+ newIndexBlobId: string;
61
+ /** New graph blob ID from Walrus */
62
+ newGraphBlobId: string;
63
+ /** Optional gas budget */
64
+ gasBudget?: number;
65
+ }
66
+
67
+ /**
68
+ * Options for creating a new MemoryIndex
69
+ */
70
+ export interface CreateMemoryIndexOnChainOptions {
71
+ /** Sui client instance */
72
+ client: SuiClient;
73
+ /** Signer for transaction */
74
+ signer: Signer;
75
+ /** Package ID of the PDW contract */
76
+ packageId: string;
77
+ /** Initial index blob ID (can be placeholder) */
78
+ indexBlobId: string;
79
+ /** Initial graph blob ID (can be placeholder) */
80
+ graphBlobId: string;
81
+ /** Optional gas budget */
82
+ gasBudget?: number;
83
+ }
84
+
85
+ /**
86
+ * Result of updating MemoryIndex
87
+ */
88
+ export interface UpdateMemoryIndexResult {
89
+ success: boolean;
90
+ /** Transaction digest */
91
+ digest?: string;
92
+ /** New version number after update */
93
+ newVersion?: number;
94
+ /** Error message if failed */
95
+ error?: string;
96
+ }
97
+
98
+ /**
99
+ * Result of creating MemoryIndex
100
+ */
101
+ export interface CreateMemoryIndexResult {
102
+ success: boolean;
103
+ /** Created MemoryIndex object ID */
104
+ memoryIndexId?: string;
105
+ /** Transaction digest */
106
+ digest?: string;
107
+ /** Error message if failed */
108
+ error?: string;
109
+ }
110
+
111
+ /**
112
+ * Read MemoryIndex object from Sui blockchain
113
+ *
114
+ * @param options - Options containing client and memoryIndexId
115
+ * @returns The MemoryIndex object data or null if not found
116
+ *
117
+ * @example
118
+ * ```typescript
119
+ * const memoryIndex = await getMemoryIndex({
120
+ * client: suiClient,
121
+ * memoryIndexId: process.env.MEMORY_INDEX_ID!
122
+ * });
123
+ *
124
+ * if (memoryIndex) {
125
+ * console.log(`Version: ${memoryIndex.version}`);
126
+ * console.log(`Index Blob: ${memoryIndex.indexBlobId}`);
127
+ * }
128
+ * ```
129
+ */
130
+ export async function getMemoryIndex(
131
+ options: GetMemoryIndexOptions
132
+ ): Promise<OnChainMemoryIndex | null> {
133
+ const { client, memoryIndexId } = options;
134
+
135
+ if (!memoryIndexId) {
136
+ console.warn('⚠️ MEMORY_INDEX_ID not provided');
137
+ return null;
138
+ }
139
+
140
+ try {
141
+ const object = await client.getObject({
142
+ id: memoryIndexId,
143
+ options: {
144
+ showContent: true,
145
+ showOwner: true,
146
+ }
147
+ });
148
+
149
+ if (!object.data?.content || object.data.content.dataType !== 'moveObject') {
150
+ console.warn(`⚠️ MemoryIndex object ${memoryIndexId} not found or not a Move object`);
151
+ return null;
152
+ }
153
+
154
+ const fields = (object.data.content as any).fields;
155
+ const owner = object.data.owner;
156
+
157
+ // Extract owner address
158
+ let ownerAddress = '';
159
+ if (owner && typeof owner === 'object' && 'AddressOwner' in owner) {
160
+ ownerAddress = (owner as { AddressOwner: string }).AddressOwner;
161
+ }
162
+
163
+ return {
164
+ objectId: memoryIndexId,
165
+ owner: ownerAddress,
166
+ version: Number(fields.version || 1),
167
+ indexBlobId: fields.index_blob_id || '',
168
+ graphBlobId: fields.graph_blob_id || '',
169
+ };
170
+ } catch (error) {
171
+ console.error(`❌ Failed to read MemoryIndex ${memoryIndexId}:`, error);
172
+ return null;
173
+ }
174
+ }
175
+
176
+ /**
177
+ * Update MemoryIndex on-chain with new blob IDs
178
+ *
179
+ * Call this after uploading index/graph to Walrus to update the on-chain reference.
180
+ * Uses optimistic locking (expectedVersion must match current version).
181
+ *
182
+ * @param options - Update options
183
+ * @returns Result with success status and new version
184
+ *
185
+ * @example
186
+ * ```typescript
187
+ * // First, read current state
188
+ * const current = await getMemoryIndex({ client, memoryIndexId });
189
+ *
190
+ * // Then upload to Walrus and get new blob ID
191
+ * const newBlobId = await uploadIndexToWalrus();
192
+ *
193
+ * // Finally, update on-chain
194
+ * const result = await updateMemoryIndexOnChain({
195
+ * client,
196
+ * signer: keypair,
197
+ * packageId: process.env.PACKAGE_ID!,
198
+ * memoryIndexId: process.env.MEMORY_INDEX_ID!,
199
+ * expectedVersion: current.version,
200
+ * newIndexBlobId: newBlobId,
201
+ * newGraphBlobId: current.graphBlobId, // Keep existing if not changed
202
+ * });
203
+ * ```
204
+ */
205
+ export async function updateMemoryIndexOnChain(
206
+ options: UpdateMemoryIndexOnChainOptions
207
+ ): Promise<UpdateMemoryIndexResult> {
208
+ const {
209
+ client,
210
+ signer,
211
+ packageId,
212
+ memoryIndexId,
213
+ expectedVersion,
214
+ newIndexBlobId,
215
+ newGraphBlobId,
216
+ gasBudget = 10_000_000,
217
+ } = options;
218
+
219
+ try {
220
+ console.log(`\n📝 Updating MemoryIndex on-chain...`);
221
+ console.log(` Object ID: ${memoryIndexId}`);
222
+ console.log(` Expected version: ${expectedVersion}`);
223
+ console.log(` New index blob: ${newIndexBlobId}`);
224
+ console.log(` New graph blob: ${newGraphBlobId}`);
225
+
226
+ const tx = new Transaction();
227
+ tx.setGasBudget(gasBudget);
228
+
229
+ // Convert strings to vector<u8> for Move
230
+ const newIndexBlobIdBytes = Array.from(new TextEncoder().encode(newIndexBlobId));
231
+ const newGraphBlobIdBytes = Array.from(new TextEncoder().encode(newGraphBlobId));
232
+
233
+ tx.moveCall({
234
+ target: `${packageId}::memory::update_memory_index`,
235
+ arguments: [
236
+ tx.object(memoryIndexId), // &mut MemoryIndex
237
+ tx.pure.u64(expectedVersion), // expected_version: u64
238
+ tx.pure.vector('u8', newIndexBlobIdBytes), // new_index_blob_id: vector<u8>
239
+ tx.pure.vector('u8', newGraphBlobIdBytes), // new_graph_blob_id: vector<u8>
240
+ ]
241
+ });
242
+
243
+ const result = await client.signAndExecuteTransaction({
244
+ transaction: tx,
245
+ signer,
246
+ options: {
247
+ showEffects: true,
248
+ showObjectChanges: true,
249
+ },
250
+ });
251
+
252
+ if (result.effects?.status?.status !== 'success') {
253
+ const error = result.effects?.status?.error || 'Unknown error';
254
+ console.error(`❌ Transaction failed: ${error}`);
255
+ return { success: false, error };
256
+ }
257
+
258
+ const newVersion = expectedVersion + 1;
259
+ console.log(`✅ MemoryIndex updated successfully`);
260
+ console.log(` Transaction: ${result.digest}`);
261
+ console.log(` New version: ${newVersion}`);
262
+
263
+ return {
264
+ success: true,
265
+ digest: result.digest,
266
+ newVersion,
267
+ };
268
+ } catch (error) {
269
+ const errorMsg = error instanceof Error ? error.message : String(error);
270
+ console.error(`❌ Failed to update MemoryIndex:`, errorMsg);
271
+ return { success: false, error: errorMsg };
272
+ }
273
+ }
274
+
275
+ /**
276
+ * Create a new MemoryIndex on-chain
277
+ *
278
+ * Use this when setting up a new wallet or if MEMORY_INDEX_ID doesn't exist.
279
+ *
280
+ * @param options - Creation options
281
+ * @returns Result with created object ID
282
+ *
283
+ * @example
284
+ * ```typescript
285
+ * const result = await createMemoryIndexOnChain({
286
+ * client,
287
+ * signer: keypair,
288
+ * packageId: process.env.PACKAGE_ID!,
289
+ * indexBlobId: 'placeholder-index',
290
+ * graphBlobId: 'placeholder-graph',
291
+ * });
292
+ *
293
+ * if (result.success) {
294
+ * console.log(`Created MemoryIndex: ${result.memoryIndexId}`);
295
+ * // Save to .env: MEMORY_INDEX_ID=${result.memoryIndexId}
296
+ * }
297
+ * ```
298
+ */
299
+ export async function createMemoryIndexOnChain(
300
+ options: CreateMemoryIndexOnChainOptions
301
+ ): Promise<CreateMemoryIndexResult> {
302
+ const {
303
+ client,
304
+ signer,
305
+ packageId,
306
+ indexBlobId,
307
+ graphBlobId,
308
+ gasBudget = 10_000_000,
309
+ } = options;
310
+
311
+ try {
312
+ console.log(`\n📝 Creating new MemoryIndex on-chain...`);
313
+ console.log(` Package ID: ${packageId}`);
314
+ console.log(` Index blob: ${indexBlobId}`);
315
+ console.log(` Graph blob: ${graphBlobId}`);
316
+
317
+ const tx = new Transaction();
318
+ tx.setGasBudget(gasBudget);
319
+
320
+ // Convert strings to vector<u8> for Move
321
+ const indexBlobIdBytes = Array.from(new TextEncoder().encode(indexBlobId));
322
+ const graphBlobIdBytes = Array.from(new TextEncoder().encode(graphBlobId));
323
+
324
+ tx.moveCall({
325
+ target: `${packageId}::memory::create_memory_index`,
326
+ arguments: [
327
+ tx.pure.vector('u8', indexBlobIdBytes),
328
+ tx.pure.vector('u8', graphBlobIdBytes),
329
+ ]
330
+ });
331
+
332
+ const result = await client.signAndExecuteTransaction({
333
+ transaction: tx,
334
+ signer,
335
+ options: {
336
+ showEffects: true,
337
+ showObjectChanges: true,
338
+ },
339
+ });
340
+
341
+ if (result.effects?.status?.status !== 'success') {
342
+ const error = result.effects?.status?.error || 'Unknown error';
343
+ console.error(`❌ Transaction failed: ${error}`);
344
+ return { success: false, error };
345
+ }
346
+
347
+ // Find the created MemoryIndex object
348
+ const createdObject = result.objectChanges?.find(
349
+ (change) => change.type === 'created' && change.objectType?.includes('::memory::MemoryIndex')
350
+ );
351
+
352
+ if (!createdObject || createdObject.type !== 'created') {
353
+ return { success: false, error: 'MemoryIndex object not found in transaction result' };
354
+ }
355
+
356
+ const memoryIndexId = createdObject.objectId;
357
+ console.log(`✅ MemoryIndex created successfully`);
358
+ console.log(` Object ID: ${memoryIndexId}`);
359
+ console.log(` Transaction: ${result.digest}`);
360
+ console.log(`\n Add to .env:`);
361
+ console.log(` MEMORY_INDEX_ID=${memoryIndexId}`);
362
+
363
+ return {
364
+ success: true,
365
+ memoryIndexId,
366
+ digest: result.digest,
367
+ };
368
+ } catch (error) {
369
+ const errorMsg = error instanceof Error ? error.message : String(error);
370
+ console.error(`❌ Failed to create MemoryIndex:`, errorMsg);
371
+ return { success: false, error: errorMsg };
372
+ }
373
+ }
374
+
375
+ /**
376
+ * Sync index to Walrus and update on-chain MemoryIndex
377
+ *
378
+ * Convenience function that combines:
379
+ * 1. Reading current MemoryIndex state
380
+ * 2. Uploading index to Walrus
381
+ * 3. Updating on-chain blob ID
382
+ *
383
+ * @param options - Combined sync options
384
+ * @returns Result with new blob ID and transaction digest
385
+ */
386
+ export interface SyncAndUpdateOptions {
387
+ client: SuiClient;
388
+ signer: Signer;
389
+ packageId: string;
390
+ memoryIndexId: string;
391
+ /** Function to upload index to Walrus, returns new blob ID */
392
+ uploadToWalrus: () => Promise<string>;
393
+ /** Optional: also update graph blob ID */
394
+ newGraphBlobId?: string;
395
+ }
396
+
397
+ export interface SyncAndUpdateResult {
398
+ success: boolean;
399
+ newIndexBlobId?: string;
400
+ newGraphBlobId?: string;
401
+ digest?: string;
402
+ newVersion?: number;
403
+ error?: string;
404
+ }
405
+
406
+ export async function syncIndexAndUpdateOnChain(
407
+ options: SyncAndUpdateOptions
408
+ ): Promise<SyncAndUpdateResult> {
409
+ const {
410
+ client,
411
+ signer,
412
+ packageId,
413
+ memoryIndexId,
414
+ uploadToWalrus,
415
+ newGraphBlobId,
416
+ } = options;
417
+
418
+ try {
419
+ // Step 1: Read current state
420
+ console.log(`\n🔍 Reading current MemoryIndex state...`);
421
+ const current = await getMemoryIndex({ client, memoryIndexId });
422
+
423
+ if (!current) {
424
+ return { success: false, error: 'MemoryIndex not found on-chain' };
425
+ }
426
+
427
+ console.log(` Current version: ${current.version}`);
428
+ console.log(` Current index blob: ${current.indexBlobId}`);
429
+
430
+ // Step 2: Upload to Walrus
431
+ console.log(`\n☁️ Uploading index to Walrus...`);
432
+ const newIndexBlobId = await uploadToWalrus();
433
+ console.log(` New index blob: ${newIndexBlobId}`);
434
+
435
+ // Step 3: Update on-chain
436
+ const graphBlobId = newGraphBlobId || current.graphBlobId;
437
+ const updateResult = await updateMemoryIndexOnChain({
438
+ client,
439
+ signer,
440
+ packageId,
441
+ memoryIndexId,
442
+ expectedVersion: current.version,
443
+ newIndexBlobId,
444
+ newGraphBlobId: graphBlobId,
445
+ });
446
+
447
+ if (!updateResult.success) {
448
+ return { success: false, error: updateResult.error };
449
+ }
450
+
451
+ return {
452
+ success: true,
453
+ newIndexBlobId,
454
+ newGraphBlobId: graphBlobId,
455
+ digest: updateResult.digest,
456
+ newVersion: updateResult.newVersion,
457
+ };
458
+ } catch (error) {
459
+ const errorMsg = error instanceof Error ? error.message : String(error);
460
+ return { success: false, error: errorMsg };
461
+ }
462
+ }
463
+
464
+ /**
465
+ * Upload placeholder blob to Walrus
466
+ * Used when creating initial MemoryIndex
467
+ */
468
+ export async function uploadPlaceholderToWalrus(
469
+ walrusPublisherUrl: string,
470
+ type: 'index' | 'graph'
471
+ ): Promise<string> {
472
+ const content = JSON.stringify({
473
+ type: type === 'index' ? 'hnsw-index-placeholder' : 'knowledge-graph',
474
+ version: 1,
475
+ created: new Date().toISOString(),
476
+ note: type === 'index'
477
+ ? 'Placeholder for HNSW index. Actual index synced after adding memories.'
478
+ : 'Empty knowledge graph. Will be populated as memories are processed.',
479
+ ...(type === 'graph' ? { nodes: [], edges: [] } : {}),
480
+ });
481
+
482
+ const response = await fetch(walrusPublisherUrl, {
483
+ method: 'PUT',
484
+ headers: { 'Content-Type': 'application/octet-stream' },
485
+ body: new TextEncoder().encode(content),
486
+ });
487
+
488
+ if (!response.ok) {
489
+ throw new Error(`Walrus upload failed: ${response.status}`);
490
+ }
491
+
492
+ const result = await response.json();
493
+
494
+ // Handle different response formats
495
+ let blobId: string;
496
+ if (result.newlyCreated?.blobObject?.blobId) {
497
+ blobId = result.newlyCreated.blobObject.blobId;
498
+ } else if (result.alreadyCertified?.blobId) {
499
+ blobId = result.alreadyCertified.blobId;
500
+ } else if (result.blobId) {
501
+ blobId = result.blobId;
502
+ } else {
503
+ throw new Error('Could not extract blobId from Walrus response');
504
+ }
505
+
506
+ return blobId;
507
+ }