@cmdoss/memwal-sdk 0.6.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.
- package/ARCHITECTURE.md +463 -0
- package/BENCHMARKS.md +238 -0
- package/README.md +142 -0
- package/dist/access/PermissionService.d.ts +179 -0
- package/dist/access/PermissionService.d.ts.map +1 -0
- package/dist/access/PermissionService.js +445 -0
- package/dist/access/PermissionService.js.map +1 -0
- package/dist/access/index.d.ts +8 -0
- package/dist/access/index.d.ts.map +1 -0
- package/dist/access/index.js +7 -0
- package/dist/access/index.js.map +1 -0
- package/dist/aggregation/AggregationService.d.ts +132 -0
- package/dist/aggregation/AggregationService.d.ts.map +1 -0
- package/dist/aggregation/AggregationService.js +225 -0
- package/dist/aggregation/AggregationService.js.map +1 -0
- package/dist/aggregation/index.d.ts +8 -0
- package/dist/aggregation/index.d.ts.map +1 -0
- package/dist/aggregation/index.js +7 -0
- package/dist/aggregation/index.js.map +1 -0
- package/dist/ai-sdk/PDWVectorStore.d.ts +124 -0
- package/dist/ai-sdk/PDWVectorStore.d.ts.map +1 -0
- package/dist/ai-sdk/PDWVectorStore.js +557 -0
- package/dist/ai-sdk/PDWVectorStore.js.map +1 -0
- package/dist/ai-sdk/index.d.ts +45 -0
- package/dist/ai-sdk/index.d.ts.map +1 -0
- package/dist/ai-sdk/index.js +45 -0
- package/dist/ai-sdk/index.js.map +1 -0
- package/dist/ai-sdk/tools.d.ts +153 -0
- package/dist/ai-sdk/tools.d.ts.map +1 -0
- package/dist/ai-sdk/tools.js +312 -0
- package/dist/ai-sdk/tools.js.map +1 -0
- package/dist/ai-sdk/types.d.ts +336 -0
- package/dist/ai-sdk/types.d.ts.map +1 -0
- package/dist/ai-sdk/types.js +36 -0
- package/dist/ai-sdk/types.js.map +1 -0
- package/dist/api/client.d.ts +43 -0
- package/dist/api/client.d.ts.map +1 -0
- package/dist/api/client.js +136 -0
- package/dist/api/client.js.map +1 -0
- package/dist/batch/BatchManager.d.ts +147 -0
- package/dist/batch/BatchManager.d.ts.map +1 -0
- package/dist/batch/BatchManager.js +427 -0
- package/dist/batch/BatchManager.js.map +1 -0
- package/dist/batch/BatchingService.d.ts +122 -0
- package/dist/batch/BatchingService.d.ts.map +1 -0
- package/dist/batch/BatchingService.js +301 -0
- package/dist/batch/BatchingService.js.map +1 -0
- package/dist/batch/MemoryProcessingCache.d.ts +147 -0
- package/dist/batch/MemoryProcessingCache.d.ts.map +1 -0
- package/dist/batch/MemoryProcessingCache.js +349 -0
- package/dist/batch/MemoryProcessingCache.js.map +1 -0
- package/dist/batch/index.d.ts +13 -0
- package/dist/batch/index.d.ts.map +1 -0
- package/dist/batch/index.js +10 -0
- package/dist/batch/index.js.map +1 -0
- package/dist/browser.d.ts +73 -0
- package/dist/browser.d.ts.map +1 -0
- package/dist/browser.js +66 -0
- package/dist/browser.js.map +1 -0
- package/dist/chat/index.d.ts +13 -0
- package/dist/chat/index.d.ts.map +1 -0
- package/dist/chat/index.js +14 -0
- package/dist/chat/index.js.map +1 -0
- package/dist/client/ClientMemoryManager.d.ts +202 -0
- package/dist/client/ClientMemoryManager.d.ts.map +1 -0
- package/dist/client/ClientMemoryManager.js +764 -0
- package/dist/client/ClientMemoryManager.js.map +1 -0
- package/dist/client/PersonalDataWallet.d.ts +406 -0
- package/dist/client/PersonalDataWallet.d.ts.map +1 -0
- package/dist/client/PersonalDataWallet.js +229 -0
- package/dist/client/PersonalDataWallet.js.map +1 -0
- package/dist/client/SimplePDWClient.d.ts +534 -0
- package/dist/client/SimplePDWClient.d.ts.map +1 -0
- package/dist/client/SimplePDWClient.js +876 -0
- package/dist/client/SimplePDWClient.js.map +1 -0
- package/dist/client/factory.d.ts +99 -0
- package/dist/client/factory.d.ts.map +1 -0
- package/dist/client/factory.js +126 -0
- package/dist/client/factory.js.map +1 -0
- package/dist/client/namespaces/AnalyticsNamespace.d.ts +178 -0
- package/dist/client/namespaces/AnalyticsNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/AnalyticsNamespace.js +261 -0
- package/dist/client/namespaces/AnalyticsNamespace.js.map +1 -0
- package/dist/client/namespaces/BatchNamespace.d.ts +120 -0
- package/dist/client/namespaces/BatchNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/BatchNamespace.js +261 -0
- package/dist/client/namespaces/BatchNamespace.js.map +1 -0
- package/dist/client/namespaces/CacheNamespace.d.ts +80 -0
- package/dist/client/namespaces/CacheNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/CacheNamespace.js +100 -0
- package/dist/client/namespaces/CacheNamespace.js.map +1 -0
- package/dist/client/namespaces/CapabilityNamespace.d.ts +145 -0
- package/dist/client/namespaces/CapabilityNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/CapabilityNamespace.js +181 -0
- package/dist/client/namespaces/CapabilityNamespace.js.map +1 -0
- package/dist/client/namespaces/ChatNamespace.d.ts +110 -0
- package/dist/client/namespaces/ChatNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/ChatNamespace.js +123 -0
- package/dist/client/namespaces/ChatNamespace.js.map +1 -0
- package/dist/client/namespaces/ClassifyNamespace.d.ts +96 -0
- package/dist/client/namespaces/ClassifyNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/ClassifyNamespace.js +149 -0
- package/dist/client/namespaces/ClassifyNamespace.js.map +1 -0
- package/dist/client/namespaces/ContextNamespace.d.ts +150 -0
- package/dist/client/namespaces/ContextNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/ContextNamespace.js +250 -0
- package/dist/client/namespaces/ContextNamespace.js.map +1 -0
- package/dist/client/namespaces/EmbeddingsNamespace.d.ts +64 -0
- package/dist/client/namespaces/EmbeddingsNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/EmbeddingsNamespace.js +86 -0
- package/dist/client/namespaces/EmbeddingsNamespace.js.map +1 -0
- package/dist/client/namespaces/EncryptionNamespace.d.ts +128 -0
- package/dist/client/namespaces/EncryptionNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/EncryptionNamespace.js +161 -0
- package/dist/client/namespaces/EncryptionNamespace.js.map +1 -0
- package/dist/client/namespaces/GraphNamespace.d.ts +168 -0
- package/dist/client/namespaces/GraphNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/GraphNamespace.js +314 -0
- package/dist/client/namespaces/GraphNamespace.js.map +1 -0
- package/dist/client/namespaces/IndexNamespace.d.ts +141 -0
- package/dist/client/namespaces/IndexNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/IndexNamespace.js +238 -0
- package/dist/client/namespaces/IndexNamespace.js.map +1 -0
- package/dist/client/namespaces/MemoryNamespace.d.ts +277 -0
- package/dist/client/namespaces/MemoryNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/MemoryNamespace.js +907 -0
- package/dist/client/namespaces/MemoryNamespace.js.map +1 -0
- package/dist/client/namespaces/PermissionsNamespace.d.ts +114 -0
- package/dist/client/namespaces/PermissionsNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/PermissionsNamespace.js +179 -0
- package/dist/client/namespaces/PermissionsNamespace.js.map +1 -0
- package/dist/client/namespaces/PipelineNamespace.d.ts +125 -0
- package/dist/client/namespaces/PipelineNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/PipelineNamespace.js +171 -0
- package/dist/client/namespaces/PipelineNamespace.js.map +1 -0
- package/dist/client/namespaces/SearchNamespace.d.ts +382 -0
- package/dist/client/namespaces/SearchNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/SearchNamespace.js +821 -0
- package/dist/client/namespaces/SearchNamespace.js.map +1 -0
- package/dist/client/namespaces/StorageNamespace.d.ts +180 -0
- package/dist/client/namespaces/StorageNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/StorageNamespace.js +354 -0
- package/dist/client/namespaces/StorageNamespace.js.map +1 -0
- package/dist/client/namespaces/TxNamespace.d.ts +143 -0
- package/dist/client/namespaces/TxNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/TxNamespace.js +208 -0
- package/dist/client/namespaces/TxNamespace.js.map +1 -0
- package/dist/client/namespaces/WalletNamespace.d.ts +124 -0
- package/dist/client/namespaces/WalletNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/WalletNamespace.js +197 -0
- package/dist/client/namespaces/WalletNamespace.js.map +1 -0
- package/dist/client/namespaces/consolidated/AINamespace.d.ts +265 -0
- package/dist/client/namespaces/consolidated/AINamespace.d.ts.map +1 -0
- package/dist/client/namespaces/consolidated/AINamespace.js +390 -0
- package/dist/client/namespaces/consolidated/AINamespace.js.map +1 -0
- package/dist/client/namespaces/consolidated/BlockchainNamespace.d.ts +265 -0
- package/dist/client/namespaces/consolidated/BlockchainNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/consolidated/BlockchainNamespace.js +412 -0
- package/dist/client/namespaces/consolidated/BlockchainNamespace.js.map +1 -0
- package/dist/client/namespaces/consolidated/SecurityNamespace.d.ts +354 -0
- package/dist/client/namespaces/consolidated/SecurityNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/consolidated/SecurityNamespace.js +522 -0
- package/dist/client/namespaces/consolidated/SecurityNamespace.js.map +1 -0
- package/dist/client/namespaces/consolidated/StorageNamespace.d.ts +235 -0
- package/dist/client/namespaces/consolidated/StorageNamespace.d.ts.map +1 -0
- package/dist/client/namespaces/consolidated/StorageNamespace.js +351 -0
- package/dist/client/namespaces/consolidated/StorageNamespace.js.map +1 -0
- package/dist/client/namespaces/consolidated/index.d.ts +17 -0
- package/dist/client/namespaces/consolidated/index.d.ts.map +1 -0
- package/dist/client/namespaces/consolidated/index.js +13 -0
- package/dist/client/namespaces/consolidated/index.js.map +1 -0
- package/dist/client/signers/KeypairSigner.d.ts +55 -0
- package/dist/client/signers/KeypairSigner.d.ts.map +1 -0
- package/dist/client/signers/KeypairSigner.js +84 -0
- package/dist/client/signers/KeypairSigner.js.map +1 -0
- package/dist/client/signers/UnifiedSigner.d.ts +88 -0
- package/dist/client/signers/UnifiedSigner.d.ts.map +1 -0
- package/dist/client/signers/UnifiedSigner.js +13 -0
- package/dist/client/signers/UnifiedSigner.js.map +1 -0
- package/dist/client/signers/WalletAdapterSigner.d.ts +94 -0
- package/dist/client/signers/WalletAdapterSigner.d.ts.map +1 -0
- package/dist/client/signers/WalletAdapterSigner.js +91 -0
- package/dist/client/signers/WalletAdapterSigner.js.map +1 -0
- package/dist/client/signers/index.d.ts +14 -0
- package/dist/client/signers/index.d.ts.map +1 -0
- package/dist/client/signers/index.js +12 -0
- package/dist/client/signers/index.js.map +1 -0
- package/dist/config/ConfigurationHelper.d.ts +167 -0
- package/dist/config/ConfigurationHelper.d.ts.map +1 -0
- package/dist/config/ConfigurationHelper.js +283 -0
- package/dist/config/ConfigurationHelper.js.map +1 -0
- package/dist/config/defaults.d.ts +9 -0
- package/dist/config/defaults.d.ts.map +1 -0
- package/dist/config/defaults.js +49 -0
- package/dist/config/defaults.js.map +1 -0
- package/dist/config/index.d.ts +9 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +8 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/validation.d.ts +12 -0
- package/dist/config/validation.d.ts.map +1 -0
- package/dist/config/validation.js +61 -0
- package/dist/config/validation.js.map +1 -0
- package/dist/core/index.d.ts +11 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +13 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/interfaces/IService.d.ts +162 -0
- package/dist/core/interfaces/IService.d.ts.map +1 -0
- package/dist/core/interfaces/IService.js +159 -0
- package/dist/core/interfaces/IService.js.map +1 -0
- package/dist/core/interfaces/index.d.ts +7 -0
- package/dist/core/interfaces/index.d.ts.map +1 -0
- package/dist/core/interfaces/index.js +7 -0
- package/dist/core/interfaces/index.js.map +1 -0
- package/dist/core/types/capability.d.ts +268 -0
- package/dist/core/types/capability.d.ts.map +1 -0
- package/dist/core/types/capability.js +16 -0
- package/dist/core/types/capability.js.map +1 -0
- package/dist/core/types/index.d.ts +750 -0
- package/dist/core/types/index.d.ts.map +1 -0
- package/dist/core/types/index.js +6 -0
- package/dist/core/types/index.js.map +1 -0
- package/dist/core/types/wallet.d.ts +254 -0
- package/dist/core/types/wallet.d.ts.map +1 -0
- package/dist/core/types/wallet.js +27 -0
- package/dist/core/types/wallet.js.map +1 -0
- package/dist/core/types.d.ts +8 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +8 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/wallet.d.ts +209 -0
- package/dist/core/wallet.d.ts.map +1 -0
- package/dist/core/wallet.js +27 -0
- package/dist/core/wallet.js.map +1 -0
- package/dist/embedding/index.d.ts +9 -0
- package/dist/embedding/index.d.ts.map +1 -0
- package/dist/embedding/index.js +8 -0
- package/dist/embedding/index.js.map +1 -0
- package/dist/embedding/types.d.ts +302 -0
- package/dist/embedding/types.d.ts.map +1 -0
- package/dist/embedding/types.js +9 -0
- package/dist/embedding/types.js.map +1 -0
- package/dist/encryption/index.d.ts +14 -0
- package/dist/encryption/index.d.ts.map +1 -0
- package/dist/encryption/index.js +14 -0
- package/dist/encryption/index.js.map +1 -0
- package/dist/errors/index.d.ts +149 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +301 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/recovery.d.ts +128 -0
- package/dist/errors/recovery.d.ts.map +1 -0
- package/dist/errors/recovery.js +320 -0
- package/dist/errors/recovery.js.map +1 -0
- package/dist/errors/validation.d.ts +106 -0
- package/dist/errors/validation.d.ts.map +1 -0
- package/dist/errors/validation.js +354 -0
- package/dist/errors/validation.js.map +1 -0
- package/dist/generated/pdw/capability.d.ts +223 -0
- package/dist/generated/pdw/capability.d.ts.map +1 -0
- package/dist/generated/pdw/capability.js +238 -0
- package/dist/generated/pdw/capability.js.map +1 -0
- package/dist/generated/pdw/deps/sui/object.d.ts +9 -0
- package/dist/generated/pdw/deps/sui/object.d.ts.map +1 -0
- package/dist/generated/pdw/deps/sui/object.js +11 -0
- package/dist/generated/pdw/deps/sui/object.js.map +1 -0
- package/dist/generated/pdw/deps/sui/vec_map.d.ts +37 -0
- package/dist/generated/pdw/deps/sui/vec_map.d.ts.map +1 -0
- package/dist/generated/pdw/deps/sui/vec_map.js +28 -0
- package/dist/generated/pdw/deps/sui/vec_map.js.map +1 -0
- package/dist/generated/pdw/memory.d.ts +676 -0
- package/dist/generated/pdw/memory.d.ts.map +1 -0
- package/dist/generated/pdw/memory.js +681 -0
- package/dist/generated/pdw/memory.js.map +1 -0
- package/dist/generated/pdw/wallet.d.ts +78 -0
- package/dist/generated/pdw/wallet.d.ts.map +1 -0
- package/dist/generated/pdw/wallet.js +89 -0
- package/dist/generated/pdw/wallet.js.map +1 -0
- package/dist/generated/utils/index.d.ts +12 -0
- package/dist/generated/utils/index.d.ts.map +1 -0
- package/dist/generated/utils/index.js +132 -0
- package/dist/generated/utils/index.js.map +1 -0
- package/dist/graph/BrowserKnowledgeGraphManager.d.ts +101 -0
- package/dist/graph/BrowserKnowledgeGraphManager.d.ts.map +1 -0
- package/dist/graph/BrowserKnowledgeGraphManager.js +411 -0
- package/dist/graph/BrowserKnowledgeGraphManager.js.map +1 -0
- package/dist/graph/GraphService.d.ts +194 -0
- package/dist/graph/GraphService.d.ts.map +1 -0
- package/dist/graph/GraphService.js +662 -0
- package/dist/graph/GraphService.js.map +1 -0
- package/dist/graph/KnowledgeGraphManager.d.ts +161 -0
- package/dist/graph/KnowledgeGraphManager.d.ts.map +1 -0
- package/dist/graph/KnowledgeGraphManager.js +495 -0
- package/dist/graph/KnowledgeGraphManager.js.map +1 -0
- package/dist/graph/index.d.ts +11 -0
- package/dist/graph/index.d.ts.map +1 -0
- package/dist/graph/index.js +9 -0
- package/dist/graph/index.js.map +1 -0
- package/dist/hooks.wip/index.d.ts +55 -0
- package/dist/hooks.wip/index.d.ts.map +1 -0
- package/dist/hooks.wip/index.js +58 -0
- package/dist/hooks.wip/index.js.map +1 -0
- package/dist/hooks.wip/useCreateMemory.d.ts +111 -0
- package/dist/hooks.wip/useCreateMemory.d.ts.map +1 -0
- package/dist/hooks.wip/useCreateMemory.js +149 -0
- package/dist/hooks.wip/useCreateMemory.js.map +1 -0
- package/dist/hooks.wip/useCreateMemoryBatch.d.ts +122 -0
- package/dist/hooks.wip/useCreateMemoryBatch.d.ts.map +1 -0
- package/dist/hooks.wip/useCreateMemoryBatch.js +221 -0
- package/dist/hooks.wip/useCreateMemoryBatch.js.map +1 -0
- package/dist/hooks.wip/useKnowledgeGraph.d.ts +66 -0
- package/dist/hooks.wip/useKnowledgeGraph.d.ts.map +1 -0
- package/dist/hooks.wip/useKnowledgeGraph.js +229 -0
- package/dist/hooks.wip/useKnowledgeGraph.js.map +1 -0
- package/dist/hooks.wip/useMemoryChat.d.ts +106 -0
- package/dist/hooks.wip/useMemoryChat.d.ts.map +1 -0
- package/dist/hooks.wip/useMemoryChat.js +284 -0
- package/dist/hooks.wip/useMemoryChat.js.map +1 -0
- package/dist/hooks.wip/useMemoryIndex.d.ts +90 -0
- package/dist/hooks.wip/useMemoryIndex.d.ts.map +1 -0
- package/dist/hooks.wip/useMemoryIndex.js +218 -0
- package/dist/hooks.wip/useMemoryIndex.js.map +1 -0
- package/dist/hooks.wip/useMemoryManager.d.ts +35 -0
- package/dist/hooks.wip/useMemoryManager.d.ts.map +1 -0
- package/dist/hooks.wip/useMemoryManager.js +86 -0
- package/dist/hooks.wip/useMemoryManager.js.map +1 -0
- package/dist/hooks.wip/useMemorySearch.d.ts +100 -0
- package/dist/hooks.wip/useMemorySearch.d.ts.map +1 -0
- package/dist/hooks.wip/useMemorySearch.js +278 -0
- package/dist/hooks.wip/useMemorySearch.js.map +1 -0
- package/dist/hooks.wip/useMemoryServices.d.ts +80 -0
- package/dist/hooks.wip/useMemoryServices.d.ts.map +1 -0
- package/dist/hooks.wip/useMemoryServices.js +264 -0
- package/dist/hooks.wip/useMemoryServices.js.map +1 -0
- package/dist/hooks.wip/usePDWRAG.d.ts +112 -0
- package/dist/hooks.wip/usePDWRAG.d.ts.map +1 -0
- package/dist/hooks.wip/usePDWRAG.js +121 -0
- package/dist/hooks.wip/usePDWRAG.js.map +1 -0
- package/dist/hooks.wip/usePDWVectorStore.d.ts +68 -0
- package/dist/hooks.wip/usePDWVectorStore.d.ts.map +1 -0
- package/dist/hooks.wip/usePDWVectorStore.js +102 -0
- package/dist/hooks.wip/usePDWVectorStore.js.map +1 -0
- package/dist/hooks.wip/useRetrieveEmbedding.d.ts +138 -0
- package/dist/hooks.wip/useRetrieveEmbedding.d.ts.map +1 -0
- package/dist/hooks.wip/useRetrieveEmbedding.js +121 -0
- package/dist/hooks.wip/useRetrieveEmbedding.js.map +1 -0
- package/dist/hooks.wip/useSearchMemories.d.ts +103 -0
- package/dist/hooks.wip/useSearchMemories.d.ts.map +1 -0
- package/dist/hooks.wip/useSearchMemories.js +146 -0
- package/dist/hooks.wip/useSearchMemories.js.map +1 -0
- package/dist/hooks.wip/useStoreEmbedding.d.ts +174 -0
- package/dist/hooks.wip/useStoreEmbedding.d.ts.map +1 -0
- package/dist/hooks.wip/useStoreEmbedding.js +167 -0
- package/dist/hooks.wip/useStoreEmbedding.js.map +1 -0
- package/dist/hooks.wip/useWalletMemories.d.ts +119 -0
- package/dist/hooks.wip/useWalletMemories.d.ts.map +1 -0
- package/dist/hooks.wip/useWalletMemories.js +166 -0
- package/dist/hooks.wip/useWalletMemories.js.map +1 -0
- package/dist/hooks.wip/utils/cache.d.ts +25 -0
- package/dist/hooks.wip/utils/cache.d.ts.map +1 -0
- package/dist/hooks.wip/utils/cache.js +38 -0
- package/dist/hooks.wip/utils/cache.js.map +1 -0
- package/dist/hooks.wip/utils/types.d.ts +138 -0
- package/dist/hooks.wip/utils/types.d.ts.map +1 -0
- package/dist/hooks.wip/utils/types.js +5 -0
- package/dist/hooks.wip/utils/types.js.map +1 -0
- package/dist/index.d.ts +190 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +298 -0
- package/dist/index.js.map +1 -0
- package/dist/infrastructure/ai/EmbeddingService.d.ts +101 -0
- package/dist/infrastructure/ai/EmbeddingService.d.ts.map +1 -0
- package/dist/infrastructure/ai/EmbeddingService.js +242 -0
- package/dist/infrastructure/ai/EmbeddingService.js.map +1 -0
- package/dist/infrastructure/ai/GeminiAIService.d.ts +84 -0
- package/dist/infrastructure/ai/GeminiAIService.d.ts.map +1 -0
- package/dist/infrastructure/ai/GeminiAIService.js +300 -0
- package/dist/infrastructure/ai/GeminiAIService.js.map +1 -0
- package/dist/infrastructure/ai/index.d.ts +8 -0
- package/dist/infrastructure/ai/index.d.ts.map +1 -0
- package/dist/infrastructure/ai/index.js +8 -0
- package/dist/infrastructure/ai/index.js.map +1 -0
- package/dist/infrastructure/index.d.ts +16 -0
- package/dist/infrastructure/index.d.ts.map +1 -0
- package/dist/infrastructure/index.js +19 -0
- package/dist/infrastructure/index.js.map +1 -0
- package/dist/infrastructure/seal/EncryptionService.d.ts +162 -0
- package/dist/infrastructure/seal/EncryptionService.d.ts.map +1 -0
- package/dist/infrastructure/seal/EncryptionService.js +466 -0
- package/dist/infrastructure/seal/EncryptionService.js.map +1 -0
- package/dist/infrastructure/seal/SealService.d.ts +132 -0
- package/dist/infrastructure/seal/SealService.d.ts.map +1 -0
- package/dist/infrastructure/seal/SealService.js +473 -0
- package/dist/infrastructure/seal/SealService.js.map +1 -0
- package/dist/infrastructure/seal/index.d.ts +8 -0
- package/dist/infrastructure/seal/index.d.ts.map +1 -0
- package/dist/infrastructure/seal/index.js +8 -0
- package/dist/infrastructure/seal/index.js.map +1 -0
- package/dist/infrastructure/sui/BlockchainManager.d.ts +161 -0
- package/dist/infrastructure/sui/BlockchainManager.d.ts.map +1 -0
- package/dist/infrastructure/sui/BlockchainManager.js +421 -0
- package/dist/infrastructure/sui/BlockchainManager.js.map +1 -0
- package/dist/infrastructure/sui/SuiService.d.ts +179 -0
- package/dist/infrastructure/sui/SuiService.d.ts.map +1 -0
- package/dist/infrastructure/sui/SuiService.js +658 -0
- package/dist/infrastructure/sui/SuiService.js.map +1 -0
- package/dist/infrastructure/sui/index.d.ts +8 -0
- package/dist/infrastructure/sui/index.d.ts.map +1 -0
- package/dist/infrastructure/sui/index.js +8 -0
- package/dist/infrastructure/sui/index.js.map +1 -0
- package/dist/infrastructure/walrus/StorageManager.d.ts +207 -0
- package/dist/infrastructure/walrus/StorageManager.d.ts.map +1 -0
- package/dist/infrastructure/walrus/StorageManager.js +413 -0
- package/dist/infrastructure/walrus/StorageManager.js.map +1 -0
- package/dist/infrastructure/walrus/WalrusStorageService.d.ts +177 -0
- package/dist/infrastructure/walrus/WalrusStorageService.d.ts.map +1 -0
- package/dist/infrastructure/walrus/WalrusStorageService.js +403 -0
- package/dist/infrastructure/walrus/WalrusStorageService.js.map +1 -0
- package/dist/infrastructure/walrus/index.d.ts +8 -0
- package/dist/infrastructure/walrus/index.d.ts.map +1 -0
- package/dist/infrastructure/walrus/index.js +8 -0
- package/dist/infrastructure/walrus/index.js.map +1 -0
- package/dist/langchain/PDWEmbeddings.d.ts +77 -0
- package/dist/langchain/PDWEmbeddings.d.ts.map +1 -0
- package/dist/langchain/PDWEmbeddings.js +96 -0
- package/dist/langchain/PDWEmbeddings.js.map +1 -0
- package/dist/langchain/PDWVectorStore.d.ts +173 -0
- package/dist/langchain/PDWVectorStore.d.ts.map +1 -0
- package/dist/langchain/PDWVectorStore.js +304 -0
- package/dist/langchain/PDWVectorStore.js.map +1 -0
- package/dist/langchain/createPDWRAG.d.ts +115 -0
- package/dist/langchain/createPDWRAG.d.ts.map +1 -0
- package/dist/langchain/createPDWRAG.js +181 -0
- package/dist/langchain/createPDWRAG.js.map +1 -0
- package/dist/langchain/index.d.ts +35 -0
- package/dist/langchain/index.d.ts.map +1 -0
- package/dist/langchain/index.js +35 -0
- package/dist/langchain/index.js.map +1 -0
- package/dist/memory/index.d.ts +13 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +14 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/permissions/ConsentRepository.d.ts +71 -0
- package/dist/permissions/ConsentRepository.d.ts.map +1 -0
- package/dist/permissions/ConsentRepository.js +297 -0
- package/dist/permissions/ConsentRepository.js.map +1 -0
- package/dist/permissions/index.d.ts +9 -0
- package/dist/permissions/index.d.ts.map +1 -0
- package/dist/permissions/index.js +8 -0
- package/dist/permissions/index.js.map +1 -0
- package/dist/pipeline/MemoryPipeline.d.ts +191 -0
- package/dist/pipeline/MemoryPipeline.d.ts.map +1 -0
- package/dist/pipeline/MemoryPipeline.js +588 -0
- package/dist/pipeline/MemoryPipeline.js.map +1 -0
- package/dist/pipeline/PipelineManager.d.ts +178 -0
- package/dist/pipeline/PipelineManager.d.ts.map +1 -0
- package/dist/pipeline/PipelineManager.js +485 -0
- package/dist/pipeline/PipelineManager.js.map +1 -0
- package/dist/pipeline/index.d.ts +13 -0
- package/dist/pipeline/index.d.ts.map +1 -0
- package/dist/pipeline/index.js +11 -0
- package/dist/pipeline/index.js.map +1 -0
- package/dist/retrieval/AdvancedSearchService.d.ts +231 -0
- package/dist/retrieval/AdvancedSearchService.d.ts.map +1 -0
- package/dist/retrieval/AdvancedSearchService.js +384 -0
- package/dist/retrieval/AdvancedSearchService.js.map +1 -0
- package/dist/retrieval/MemoryAnalyticsService.d.ts +227 -0
- package/dist/retrieval/MemoryAnalyticsService.d.ts.map +1 -0
- package/dist/retrieval/MemoryAnalyticsService.js +417 -0
- package/dist/retrieval/MemoryAnalyticsService.js.map +1 -0
- package/dist/retrieval/MemoryDecryptionPipeline.d.ts +191 -0
- package/dist/retrieval/MemoryDecryptionPipeline.d.ts.map +1 -0
- package/dist/retrieval/MemoryDecryptionPipeline.js +623 -0
- package/dist/retrieval/MemoryDecryptionPipeline.js.map +1 -0
- package/dist/retrieval/MemoryRetrievalService.d.ts +248 -0
- package/dist/retrieval/MemoryRetrievalService.d.ts.map +1 -0
- package/dist/retrieval/MemoryRetrievalService.js +519 -0
- package/dist/retrieval/MemoryRetrievalService.js.map +1 -0
- package/dist/retrieval/index.d.ts +14 -0
- package/dist/retrieval/index.d.ts.map +1 -0
- package/dist/retrieval/index.js +10 -0
- package/dist/retrieval/index.js.map +1 -0
- package/dist/services/BatchService.d.ts +109 -0
- package/dist/services/BatchService.d.ts.map +1 -0
- package/dist/services/BatchService.js +259 -0
- package/dist/services/BatchService.js.map +1 -0
- package/dist/services/CapabilityService.d.ts +141 -0
- package/dist/services/CapabilityService.d.ts.map +1 -0
- package/dist/services/CapabilityService.js +361 -0
- package/dist/services/CapabilityService.js.map +1 -0
- package/dist/services/ChatService.d.ts +89 -0
- package/dist/services/ChatService.d.ts.map +1 -0
- package/dist/services/ChatService.js +319 -0
- package/dist/services/ChatService.js.map +1 -0
- package/dist/services/ClassifierService.d.ts +104 -0
- package/dist/services/ClassifierService.d.ts.map +1 -0
- package/dist/services/ClassifierService.js +374 -0
- package/dist/services/ClassifierService.js.map +1 -0
- package/dist/services/CrossContextPermissionService.d.ts +149 -0
- package/dist/services/CrossContextPermissionService.d.ts.map +1 -0
- package/dist/services/CrossContextPermissionService.js +337 -0
- package/dist/services/CrossContextPermissionService.js.map +1 -0
- package/dist/services/EmbeddingService.d.ts +206 -0
- package/dist/services/EmbeddingService.d.ts.map +1 -0
- package/dist/services/EmbeddingService.js +504 -0
- package/dist/services/EmbeddingService.js.map +1 -0
- package/dist/services/EncryptionService.d.ts +201 -0
- package/dist/services/EncryptionService.d.ts.map +1 -0
- package/dist/services/EncryptionService.js +558 -0
- package/dist/services/EncryptionService.js.map +1 -0
- package/dist/services/GeminiAIService.d.ts +112 -0
- package/dist/services/GeminiAIService.d.ts.map +1 -0
- package/dist/services/GeminiAIService.js +389 -0
- package/dist/services/GeminiAIService.js.map +1 -0
- package/dist/services/IndexManager.d.ts +238 -0
- package/dist/services/IndexManager.d.ts.map +1 -0
- package/dist/services/IndexManager.js +691 -0
- package/dist/services/IndexManager.js.map +1 -0
- package/dist/services/MemoryIndexService.d.ts +222 -0
- package/dist/services/MemoryIndexService.d.ts.map +1 -0
- package/dist/services/MemoryIndexService.js +695 -0
- package/dist/services/MemoryIndexService.js.map +1 -0
- package/dist/services/MemoryService.d.ts +156 -0
- package/dist/services/MemoryService.d.ts.map +1 -0
- package/dist/services/MemoryService.js +273 -0
- package/dist/services/MemoryService.js.map +1 -0
- package/dist/services/QueryService.d.ts +182 -0
- package/dist/services/QueryService.d.ts.map +1 -0
- package/dist/services/QueryService.js +631 -0
- package/dist/services/QueryService.js.map +1 -0
- package/dist/services/StorageService.d.ts +523 -0
- package/dist/services/StorageService.d.ts.map +1 -0
- package/dist/services/StorageService.js +627 -0
- package/dist/services/StorageService.js.map +1 -0
- package/dist/services/TransactionService.d.ts +179 -0
- package/dist/services/TransactionService.d.ts.map +1 -0
- package/dist/services/TransactionService.js +639 -0
- package/dist/services/TransactionService.js.map +1 -0
- package/dist/services/VectorService.d.ts +122 -0
- package/dist/services/VectorService.d.ts.map +1 -0
- package/dist/services/VectorService.js +371 -0
- package/dist/services/VectorService.js.map +1 -0
- package/dist/services/ViewService.d.ts +126 -0
- package/dist/services/ViewService.d.ts.map +1 -0
- package/dist/services/ViewService.js +356 -0
- package/dist/services/ViewService.js.map +1 -0
- package/dist/services/index.d.ts +12 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +11 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/storage/BlobAttributesManager.d.ts +60 -0
- package/dist/services/storage/BlobAttributesManager.d.ts.map +1 -0
- package/dist/services/storage/BlobAttributesManager.js +265 -0
- package/dist/services/storage/BlobAttributesManager.js.map +1 -0
- package/dist/services/storage/KnowledgeGraphManager.d.ts +162 -0
- package/dist/services/storage/KnowledgeGraphManager.d.ts.map +1 -0
- package/dist/services/storage/KnowledgeGraphManager.js +303 -0
- package/dist/services/storage/KnowledgeGraphManager.js.map +1 -0
- package/dist/services/storage/MemorySearchManager.d.ts +154 -0
- package/dist/services/storage/MemorySearchManager.d.ts.map +1 -0
- package/dist/services/storage/MemorySearchManager.js +260 -0
- package/dist/services/storage/MemorySearchManager.js.map +1 -0
- package/dist/services/storage/QuiltBatchManager.d.ts +185 -0
- package/dist/services/storage/QuiltBatchManager.d.ts.map +1 -0
- package/dist/services/storage/QuiltBatchManager.js +385 -0
- package/dist/services/storage/QuiltBatchManager.js.map +1 -0
- package/dist/services/storage/WalrusMetadataManager.d.ts +89 -0
- package/dist/services/storage/WalrusMetadataManager.d.ts.map +1 -0
- package/dist/services/storage/WalrusMetadataManager.js +177 -0
- package/dist/services/storage/WalrusMetadataManager.js.map +1 -0
- package/dist/services/storage/WalrusStorageManager.d.ts +113 -0
- package/dist/services/storage/WalrusStorageManager.d.ts.map +1 -0
- package/dist/services/storage/WalrusStorageManager.js +211 -0
- package/dist/services/storage/WalrusStorageManager.js.map +1 -0
- package/dist/services/storage/index.d.ts +24 -0
- package/dist/services/storage/index.d.ts.map +1 -0
- package/dist/services/storage/index.js +18 -0
- package/dist/services/storage/index.js.map +1 -0
- package/dist/transactions/index.d.ts +13 -0
- package/dist/transactions/index.d.ts.map +1 -0
- package/dist/transactions/index.js +14 -0
- package/dist/transactions/index.js.map +1 -0
- package/dist/types/index.d.ts +12 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +13 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/wallet.d.ts +12 -0
- package/dist/types/wallet.d.ts.map +1 -0
- package/dist/types/wallet.js +13 -0
- package/dist/types/wallet.js.map +1 -0
- package/dist/utils/index.d.ts +21 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +30 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/rebuildIndex.d.ts +79 -0
- package/dist/utils/rebuildIndex.d.ts.map +1 -0
- package/dist/utils/rebuildIndex.js +211 -0
- package/dist/utils/rebuildIndex.js.map +1 -0
- package/dist/utils/rebuildIndexNode.d.ts +70 -0
- package/dist/utils/rebuildIndexNode.d.ts.map +1 -0
- package/dist/utils/rebuildIndexNode.js +236 -0
- package/dist/utils/rebuildIndexNode.js.map +1 -0
- package/dist/vector/BrowserHnswIndexService.d.ts +93 -0
- package/dist/vector/BrowserHnswIndexService.d.ts.map +1 -0
- package/dist/vector/BrowserHnswIndexService.js +581 -0
- package/dist/vector/BrowserHnswIndexService.js.map +1 -0
- package/dist/vector/HnswWasmService.d.ts +97 -0
- package/dist/vector/HnswWasmService.d.ts.map +1 -0
- package/dist/vector/HnswWasmService.js +518 -0
- package/dist/vector/HnswWasmService.js.map +1 -0
- package/dist/vector/IHnswService.d.ts +179 -0
- package/dist/vector/IHnswService.d.ts.map +1 -0
- package/dist/vector/IHnswService.js +25 -0
- package/dist/vector/IHnswService.js.map +1 -0
- package/dist/vector/NodeHnswService.d.ts +80 -0
- package/dist/vector/NodeHnswService.d.ts.map +1 -0
- package/dist/vector/NodeHnswService.js +589 -0
- package/dist/vector/NodeHnswService.js.map +1 -0
- package/dist/vector/VectorManager.d.ts +142 -0
- package/dist/vector/VectorManager.d.ts.map +1 -0
- package/dist/vector/VectorManager.js +339 -0
- package/dist/vector/VectorManager.js.map +1 -0
- package/dist/vector/createHnswService.d.ts +51 -0
- package/dist/vector/createHnswService.d.ts.map +1 -0
- package/dist/vector/createHnswService.js +120 -0
- package/dist/vector/createHnswService.js.map +1 -0
- package/dist/vector/index.d.ts +24 -0
- package/dist/vector/index.d.ts.map +1 -0
- package/dist/vector/index.js +24 -0
- package/dist/vector/index.js.map +1 -0
- package/dist/view/ViewService.d.ts +136 -0
- package/dist/view/ViewService.d.ts.map +1 -0
- package/dist/view/ViewService.js +325 -0
- package/dist/view/ViewService.js.map +1 -0
- package/dist/view/index.d.ts +7 -0
- package/dist/view/index.d.ts.map +1 -0
- package/dist/view/index.js +7 -0
- package/dist/view/index.js.map +1 -0
- package/dist/wallet/ContextWalletService.d.ts +172 -0
- package/dist/wallet/ContextWalletService.d.ts.map +1 -0
- package/dist/wallet/ContextWalletService.js +510 -0
- package/dist/wallet/ContextWalletService.js.map +1 -0
- package/dist/wallet/MainWalletService.d.ts +114 -0
- package/dist/wallet/MainWalletService.d.ts.map +1 -0
- package/dist/wallet/MainWalletService.js +259 -0
- package/dist/wallet/MainWalletService.js.map +1 -0
- package/dist/wallet/index.d.ts +16 -0
- package/dist/wallet/index.d.ts.map +1 -0
- package/dist/wallet/index.js +14 -0
- package/dist/wallet/index.js.map +1 -0
- package/package.json +150 -0
- package/src/access/PermissionService.ts +636 -0
- package/src/access/index.ts +8 -0
- package/src/aggregation/AggregationService.ts +390 -0
- package/src/aggregation/index.ts +8 -0
- package/src/ai-sdk/PDWVectorStore.ts +712 -0
- package/src/ai-sdk/index.ts +65 -0
- package/src/ai-sdk/tools.ts +460 -0
- package/src/ai-sdk/types.ts +404 -0
- package/src/batch/BatchManager.ts +598 -0
- package/src/batch/BatchingService.ts +430 -0
- package/src/batch/MemoryProcessingCache.ts +493 -0
- package/src/batch/index.ts +31 -0
- package/src/browser.ts +196 -0
- package/src/client/ClientMemoryManager.ts +982 -0
- package/src/client/PersonalDataWallet.ts +346 -0
- package/src/client/SimplePDWClient.ts +1180 -0
- package/src/client/factory.ts +155 -0
- package/src/client/namespaces/AnalyticsNamespace.ts +377 -0
- package/src/client/namespaces/BatchNamespace.ts +356 -0
- package/src/client/namespaces/CacheNamespace.ts +123 -0
- package/src/client/namespaces/CapabilityNamespace.ts +217 -0
- package/src/client/namespaces/ClassifyNamespace.ts +169 -0
- package/src/client/namespaces/ContextNamespace.ts +297 -0
- package/src/client/namespaces/EmbeddingsNamespace.ts +99 -0
- package/src/client/namespaces/EncryptionNamespace.ts +221 -0
- package/src/client/namespaces/GraphNamespace.ts +468 -0
- package/src/client/namespaces/IndexNamespace.ts +283 -0
- package/src/client/namespaces/MemoryNamespace.ts +1135 -0
- package/src/client/namespaces/PermissionsNamespace.ts +254 -0
- package/src/client/namespaces/PipelineNamespace.ts +220 -0
- package/src/client/namespaces/SearchNamespace.ts +1036 -0
- package/src/client/namespaces/StorageNamespace.ts +458 -0
- package/src/client/namespaces/TxNamespace.ts +260 -0
- package/src/client/namespaces/WalletNamespace.ts +243 -0
- package/src/client/namespaces/consolidated/AINamespace.ts +449 -0
- package/src/client/namespaces/consolidated/BlockchainNamespace.ts +492 -0
- package/src/client/namespaces/consolidated/SecurityNamespace.ts +648 -0
- package/src/client/namespaces/consolidated/StorageNamespace.ts +440 -0
- package/src/client/namespaces/consolidated/index.ts +39 -0
- package/src/client/signers/KeypairSigner.ts +101 -0
- package/src/client/signers/UnifiedSigner.ts +99 -0
- package/src/client/signers/WalletAdapterSigner.ts +149 -0
- package/src/client/signers/index.ts +19 -0
- package/src/config/ConfigurationHelper.ts +413 -0
- package/src/config/defaults.ts +52 -0
- package/src/config/index.ts +9 -0
- package/src/config/validation.ts +71 -0
- package/src/core/index.ts +14 -0
- package/src/core/interfaces/IService.ts +307 -0
- package/src/core/interfaces/index.ts +8 -0
- package/src/core/types/capability.ts +297 -0
- package/src/core/types/index.ts +871 -0
- package/src/core/types/wallet.ts +271 -0
- package/src/core/types.ts +9 -0
- package/src/core/wallet.ts +223 -0
- package/src/embedding/index.ts +20 -0
- package/src/embedding/types.ts +358 -0
- package/src/errors/index.ts +603 -0
- package/src/errors/recovery.ts +462 -0
- package/src/errors/validation.ts +568 -0
- package/src/generated/pdw/capability.ts +319 -0
- package/src/generated/pdw/deps/sui/object.ts +13 -0
- package/src/generated/pdw/deps/sui/vec_map.ts +33 -0
- package/src/generated/pdw/memory.ts +1088 -0
- package/src/generated/pdw/wallet.ts +124 -0
- package/src/generated/utils/index.ts +159 -0
- package/src/graph/GraphService.ts +888 -0
- package/src/graph/KnowledgeGraphManager.ts +729 -0
- package/src/graph/index.ts +26 -0
- package/src/index.ts +458 -0
- package/src/infrastructure/index.ts +22 -0
- package/src/infrastructure/seal/EncryptionService.ts +604 -0
- package/src/infrastructure/seal/SealService.ts +616 -0
- package/src/infrastructure/seal/index.ts +9 -0
- package/src/infrastructure/sui/BlockchainManager.ts +628 -0
- package/src/infrastructure/sui/SuiService.ts +888 -0
- package/src/infrastructure/sui/index.ts +9 -0
- package/src/infrastructure/walrus/StorageManager.ts +605 -0
- package/src/infrastructure/walrus/WalrusStorageService.ts +613 -0
- package/src/infrastructure/walrus/index.ts +9 -0
- package/src/langchain/PDWEmbeddings.ts +145 -0
- package/src/langchain/PDWVectorStore.ts +456 -0
- package/src/langchain/README.md +116 -0
- package/src/langchain/createPDWRAG.ts +303 -0
- package/src/langchain/index.ts +47 -0
- package/src/permissions/ConsentRepository.ts +364 -0
- package/src/permissions/index.ts +9 -0
- package/src/pipeline/MemoryPipeline.ts +863 -0
- package/src/pipeline/PipelineManager.ts +684 -0
- package/src/pipeline/index.ts +27 -0
- package/src/retrieval/AdvancedSearchService.ts +630 -0
- package/src/retrieval/MemoryAnalyticsService.ts +712 -0
- package/src/retrieval/MemoryDecryptionPipeline.ts +825 -0
- package/src/retrieval/MemoryRetrievalService.ts +831 -0
- package/src/retrieval/index.ts +43 -0
- package/src/services/BatchService.ts +353 -0
- package/src/services/CapabilityService.ts +448 -0
- package/src/services/ClassifierService.ts +466 -0
- package/src/services/CrossContextPermissionService.ts +484 -0
- package/src/services/EmbeddingService.ts +706 -0
- package/src/services/EncryptionService.ts +712 -0
- package/src/services/GeminiAIService.ts +497 -0
- package/src/services/IndexManager.ts +1004 -0
- package/src/services/MemoryIndexService.ts +922 -0
- package/src/services/MemoryService.ts +370 -0
- package/src/services/QueryService.ts +891 -0
- package/src/services/StorageService.ts +1111 -0
- package/src/services/TransactionService.ts +791 -0
- package/src/services/VectorService.ts +462 -0
- package/src/services/ViewService.ts +485 -0
- package/src/services/index.ts +25 -0
- package/src/services/storage/BlobAttributesManager.ts +342 -0
- package/src/services/storage/KnowledgeGraphManager.ts +425 -0
- package/src/services/storage/MemorySearchManager.ts +387 -0
- package/src/services/storage/QuiltBatchManager.ts +532 -0
- package/src/services/storage/WalrusMetadataManager.ts +271 -0
- package/src/services/storage/WalrusStorageManager.ts +290 -0
- package/src/services/storage/index.ts +52 -0
- package/src/types/index.ts +13 -0
- package/src/utils/index.ts +68 -0
- package/src/utils/rebuildIndex.ts +290 -0
- package/src/utils/rebuildIndexNode.ts +341 -0
- package/src/vector/BrowserHnswIndexService.ts +758 -0
- package/src/vector/HnswWasmService.ts +679 -0
- package/src/vector/IHnswService.ts +224 -0
- package/src/vector/NodeHnswService.ts +713 -0
- package/src/vector/VectorManager.ts +479 -0
- package/src/vector/createHnswService.ts +135 -0
- package/src/vector/index.ts +57 -0
- package/src/wallet/ContextWalletService.ts +657 -0
- package/src/wallet/MainWalletService.ts +318 -0
- package/src/wallet/index.ts +17 -0
|
@@ -0,0 +1,712 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* EncryptionService - SEAL-based encryption and access control
|
|
3
|
+
*
|
|
4
|
+
* Provides identity-based encryption using Mysten's SEAL SDK with decentralized
|
|
5
|
+
* key management and onchain access control policies.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { SessionKey } from '@mysten/seal';
|
|
9
|
+
import { Transaction } from '@mysten/sui/transactions';
|
|
10
|
+
import { fromHex, toHex } from '@mysten/sui/utils';
|
|
11
|
+
import { keccak_256 } from '@noble/hashes/sha3';
|
|
12
|
+
import { SealService } from '../infrastructure/seal/SealService';
|
|
13
|
+
import { CrossContextPermissionService } from './CrossContextPermissionService';
|
|
14
|
+
import type {
|
|
15
|
+
ClientWithCoreApi,
|
|
16
|
+
PDWConfig,
|
|
17
|
+
AccessPermission,
|
|
18
|
+
AccessControlOptions,
|
|
19
|
+
Thunk,
|
|
20
|
+
SealEncryptionResult,
|
|
21
|
+
SealDecryptionOptions
|
|
22
|
+
} from '../types';
|
|
23
|
+
|
|
24
|
+
export interface AccessGrantOptions {
|
|
25
|
+
ownerAddress: string;
|
|
26
|
+
recipientAddress: string;
|
|
27
|
+
contentId: string;
|
|
28
|
+
accessLevel: 'read' | 'write';
|
|
29
|
+
expiresIn?: number; // milliseconds from now
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export interface AccessRevokeOptions {
|
|
33
|
+
ownerAddress: string;
|
|
34
|
+
recipientAddress: string;
|
|
35
|
+
contentId: string;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export class EncryptionService {
|
|
39
|
+
private sealService: SealService;
|
|
40
|
+
private suiClient: any;
|
|
41
|
+
private packageId: string;
|
|
42
|
+
private sessionKeyCache = new Map<string, SessionKey>();
|
|
43
|
+
private permissionService: CrossContextPermissionService;
|
|
44
|
+
|
|
45
|
+
constructor(
|
|
46
|
+
private client: ClientWithCoreApi,
|
|
47
|
+
private config: PDWConfig
|
|
48
|
+
) {
|
|
49
|
+
this.suiClient = (client as any).client || client;
|
|
50
|
+
this.packageId = config.packageId || '';
|
|
51
|
+
this.sealService = this.initializeSealService();
|
|
52
|
+
|
|
53
|
+
// Initialize permission service for OAuth-style access control
|
|
54
|
+
this.permissionService = new CrossContextPermissionService(
|
|
55
|
+
{
|
|
56
|
+
packageId: this.packageId,
|
|
57
|
+
accessRegistryId: config.accessRegistryId || ''
|
|
58
|
+
},
|
|
59
|
+
this.suiClient
|
|
60
|
+
);
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Initialize SEAL service with proper configuration
|
|
65
|
+
*/
|
|
66
|
+
private initializeSealService(): SealService {
|
|
67
|
+
const encryptionConfig = this.config.encryptionConfig;
|
|
68
|
+
|
|
69
|
+
if (!encryptionConfig?.enabled) {
|
|
70
|
+
console.warn('Encryption is disabled in configuration - creating SealService anyway');
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// Default testnet key servers (replace with actual server object IDs)
|
|
74
|
+
const defaultKeyServers = [
|
|
75
|
+
'0x73d05d62c18d9374e3ea529e8e0ed6161da1a141a94d3f76ae3fe4e99356db75',
|
|
76
|
+
'0xf5d14a81a982144ae441cd7d64b09027f116a468bd36e7eca494f750591623c8'
|
|
77
|
+
];
|
|
78
|
+
|
|
79
|
+
const keyServerIds = encryptionConfig?.keyServers || defaultKeyServers;
|
|
80
|
+
|
|
81
|
+
// Create SealService with proper configuration
|
|
82
|
+
const sealConfig = {
|
|
83
|
+
suiClient: this.suiClient,
|
|
84
|
+
packageId: this.packageId,
|
|
85
|
+
keyServerUrls: [], // Empty for now, URLs handled separately if needed
|
|
86
|
+
keyServerObjectIds: keyServerIds,
|
|
87
|
+
network: process.env.NODE_ENV === 'production' ? 'mainnet' as const : 'testnet' as const,
|
|
88
|
+
threshold: 2,
|
|
89
|
+
enableMetrics: true,
|
|
90
|
+
retryAttempts: 3,
|
|
91
|
+
timeoutMs: 30000
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
return new SealService(sealConfig);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Build access approval transaction for SEAL key servers (LEGACY)
|
|
99
|
+
*
|
|
100
|
+
* @deprecated Use buildAccessTransactionForWallet instead for wallet-based permissions
|
|
101
|
+
*/
|
|
102
|
+
async buildAccessTransaction(
|
|
103
|
+
userAddress: string,
|
|
104
|
+
accessType: 'read' | 'write' = 'read'
|
|
105
|
+
): Promise<Transaction> {
|
|
106
|
+
console.warn('buildAccessTransaction is deprecated - use buildAccessTransactionForWallet for wallet-based permissions');
|
|
107
|
+
|
|
108
|
+
return this.buildAccessTransactionForWallet(userAddress, userAddress, accessType);
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
/**
|
|
112
|
+
* Build access approval transaction using capability pattern
|
|
113
|
+
*
|
|
114
|
+
* Uses pdw::capability::seal_approve which validates:
|
|
115
|
+
* - User owns the MemoryCap object
|
|
116
|
+
* - Provided key_id matches computed key from owner + nonce
|
|
117
|
+
*
|
|
118
|
+
* @param keyId - SEAL key ID bytes (computed from owner + nonce)
|
|
119
|
+
* @param memoryCapId - MemoryCap object ID on Sui
|
|
120
|
+
* @returns Transaction for SEAL key server approval
|
|
121
|
+
*/
|
|
122
|
+
buildCapabilityApproveTransaction(
|
|
123
|
+
keyId: Uint8Array,
|
|
124
|
+
memoryCapId: string
|
|
125
|
+
): Transaction {
|
|
126
|
+
return this.permissionService.buildSealApproveTransaction(keyId, memoryCapId);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* Build access approval transaction for a requesting wallet address
|
|
131
|
+
* Uses CrossContextPermissionService for proper permission validation
|
|
132
|
+
*
|
|
133
|
+
* @deprecated Use buildCapabilityApproveTransaction for capability-based access
|
|
134
|
+
* @param userAddress - User's wallet address (used as SEAL identity)
|
|
135
|
+
* @param requestingWallet - Wallet requesting access
|
|
136
|
+
* @param accessType - Access level (read/write)
|
|
137
|
+
* @returns Transaction for SEAL key server approval
|
|
138
|
+
*/
|
|
139
|
+
async buildAccessTransactionForWallet(
|
|
140
|
+
userAddress: string,
|
|
141
|
+
requestingWallet: string,
|
|
142
|
+
accessType: 'read' | 'write' = 'read'
|
|
143
|
+
): Promise<Transaction> {
|
|
144
|
+
// Legacy: Convert user address to bytes for SEAL identity
|
|
145
|
+
const identityBytes = fromHex(userAddress.replace('0x', ''));
|
|
146
|
+
|
|
147
|
+
// Use legacy method if memoryCapId is not available
|
|
148
|
+
return this.permissionService.buildSealApproveTransactionLegacy(
|
|
149
|
+
identityBytes,
|
|
150
|
+
requestingWallet
|
|
151
|
+
);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Encrypt data using SEAL via SealService
|
|
156
|
+
*
|
|
157
|
+
* @param data - Data to encrypt
|
|
158
|
+
* @param userAddress - User's wallet address (used as SEAL identity/id)
|
|
159
|
+
* @param threshold - Minimum key servers required for decryption (default: 2)
|
|
160
|
+
* @returns Encrypted data and backup key
|
|
161
|
+
*/
|
|
162
|
+
async encrypt(
|
|
163
|
+
data: Uint8Array,
|
|
164
|
+
userAddress: string,
|
|
165
|
+
threshold?: number
|
|
166
|
+
): Promise<{ encryptedObject: Uint8Array; backupKey: Uint8Array }> {
|
|
167
|
+
try {
|
|
168
|
+
console.log('🔒 EncryptionService: Starting SEAL encryption...');
|
|
169
|
+
console.log(` User address (identity): ${userAddress}`);
|
|
170
|
+
console.log(` Data size: ${data.length} bytes`);
|
|
171
|
+
console.log(` Threshold: ${threshold || 2} key servers`);
|
|
172
|
+
|
|
173
|
+
const result = await this.sealService.encryptData({
|
|
174
|
+
data,
|
|
175
|
+
id: userAddress, // Use user's address as SEAL identity
|
|
176
|
+
threshold: threshold || 2
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
console.log('✅ EncryptionService: SEAL encryption successful');
|
|
180
|
+
console.log(` Encrypted size: ${result.encryptedObject.length} bytes`);
|
|
181
|
+
console.log(` Backup key generated: ${result.key.length} bytes`);
|
|
182
|
+
|
|
183
|
+
return {
|
|
184
|
+
encryptedObject: result.encryptedObject,
|
|
185
|
+
backupKey: result.key
|
|
186
|
+
};
|
|
187
|
+
} catch (error) {
|
|
188
|
+
throw new Error(`Encryption failed: ${error}`);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* Decrypt data using SEAL with session keys via SealService
|
|
194
|
+
* Handles both new binary format (Uint8Array) and legacy base64 format
|
|
195
|
+
*
|
|
196
|
+
* Supports two access control patterns:
|
|
197
|
+
* 1. Capability pattern (recommended): Requires memoryCapId and keyId
|
|
198
|
+
* 2. Legacy allowlist pattern: Uses requestingWallet for permission check
|
|
199
|
+
*/
|
|
200
|
+
async decrypt(options: SealDecryptionOptions): Promise<Uint8Array> {
|
|
201
|
+
try {
|
|
202
|
+
console.log('🔓 EncryptionService: Starting SEAL decryption...');
|
|
203
|
+
console.log(` User address: ${options.userAddress}`);
|
|
204
|
+
const requestingWallet = options.requestingWallet ?? options.userAddress;
|
|
205
|
+
|
|
206
|
+
// Get or create session key
|
|
207
|
+
let activeSessionKey = options.sessionKey;
|
|
208
|
+
if (!activeSessionKey) {
|
|
209
|
+
console.log('🔄 Creating session key...');
|
|
210
|
+
activeSessionKey = await this.getOrCreateSessionKey(options.userAddress);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
// Build access transaction if not provided
|
|
214
|
+
let txBytes = options.signedTxBytes;
|
|
215
|
+
if (!txBytes) {
|
|
216
|
+
// Check if capability pattern is being used
|
|
217
|
+
if (options.memoryCapId && options.keyId) {
|
|
218
|
+
console.log('🔄 Building capability-based access transaction...');
|
|
219
|
+
console.log(` MemoryCap ID: ${options.memoryCapId}`);
|
|
220
|
+
console.log(` Key ID length: ${options.keyId.length} bytes`);
|
|
221
|
+
|
|
222
|
+
const tx = this.buildCapabilityApproveTransaction(options.keyId, options.memoryCapId);
|
|
223
|
+
// CRITICAL: Set sender before building - required by Transaction.build()
|
|
224
|
+
tx.setSender(requestingWallet);
|
|
225
|
+
console.log(` Transaction sender set to: ${requestingWallet}`);
|
|
226
|
+
// SEAL REQUIREMENT: Must use onlyTransactionKind: true for PTB validation
|
|
227
|
+
txBytes = await tx.build({ client: this.suiClient, onlyTransactionKind: true });
|
|
228
|
+
} else {
|
|
229
|
+
// Fallback to legacy allowlist pattern
|
|
230
|
+
console.log('🔄 Building legacy access transaction (allowlist pattern)...');
|
|
231
|
+
console.warn(' ⚠️ Consider using capability pattern with memoryCapId and keyId');
|
|
232
|
+
console.log(` Requesting wallet: ${requestingWallet}`);
|
|
233
|
+
|
|
234
|
+
const tx = await this.buildAccessTransactionForWallet(
|
|
235
|
+
options.userAddress,
|
|
236
|
+
requestingWallet,
|
|
237
|
+
'read'
|
|
238
|
+
);
|
|
239
|
+
// CRITICAL: Set sender before building - required by Transaction.build()
|
|
240
|
+
tx.setSender(requestingWallet);
|
|
241
|
+
console.log(` Transaction sender set to: ${requestingWallet}`);
|
|
242
|
+
// SEAL REQUIREMENT: Must use onlyTransactionKind: true for PTB validation
|
|
243
|
+
txBytes = await tx.build({ client: this.suiClient, onlyTransactionKind: true });
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
if (!txBytes) {
|
|
248
|
+
throw new Error('Failed to build SEAL approval transaction bytes');
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
// ✅ CRITICAL: Handle both binary and legacy formats
|
|
252
|
+
let encryptedBytes: Uint8Array;
|
|
253
|
+
|
|
254
|
+
if (options.encryptedContent && options.encryptedContent instanceof Uint8Array) {
|
|
255
|
+
// **NEW BINARY FORMAT** (preferred - matches memory-workflow-seal.ts)
|
|
256
|
+
encryptedBytes = options.encryptedContent;
|
|
257
|
+
console.log('✅ Using new binary format (Uint8Array)');
|
|
258
|
+
console.log(` Binary data size: ${encryptedBytes.length} bytes`);
|
|
259
|
+
console.log(` Format: Direct binary (preserves SEAL integrity)`);
|
|
260
|
+
} else if (options.encryptedData) {
|
|
261
|
+
// **LEGACY BASE64 FORMAT** (deprecated but supported for backward compatibility)
|
|
262
|
+
console.log('⚠️ Using legacy base64 format (deprecated)');
|
|
263
|
+
const encryptedDataBase64 = options.encryptedData;
|
|
264
|
+
const binaryString = atob(encryptedDataBase64);
|
|
265
|
+
encryptedBytes = new Uint8Array(binaryString.length);
|
|
266
|
+
for (let i = 0; i < binaryString.length; i++) {
|
|
267
|
+
encryptedBytes[i] = binaryString.charCodeAt(i);
|
|
268
|
+
}
|
|
269
|
+
console.log(` Converted from base64: ${encryptedDataBase64.length} chars → ${encryptedBytes.length} bytes`);
|
|
270
|
+
console.log(' Recommendation: Use encryptedContent (Uint8Array) for better performance');
|
|
271
|
+
} else {
|
|
272
|
+
throw new Error('No encrypted data provided. Use either encryptedContent (Uint8Array) or encryptedData (base64 string)');
|
|
273
|
+
}
|
|
274
|
+
|
|
275
|
+
console.log('🔄 Calling SEAL decryption...');
|
|
276
|
+
console.log(` Encrypted data length: ${encryptedBytes.length} bytes`);
|
|
277
|
+
console.log(` Session key available: ${!!activeSessionKey}`);
|
|
278
|
+
console.log(` Transaction bytes length: ${txBytes.length} bytes`);
|
|
279
|
+
|
|
280
|
+
// Use SealService for decryption (matches memory-workflow-seal.ts pattern)
|
|
281
|
+
const decryptResult = await this.sealService.decryptData({
|
|
282
|
+
encryptedObject: encryptedBytes,
|
|
283
|
+
sessionKey: activeSessionKey,
|
|
284
|
+
txBytes
|
|
285
|
+
});
|
|
286
|
+
|
|
287
|
+
console.log(`✅ EncryptionService: SEAL decryption successful`);
|
|
288
|
+
console.log(` Decrypted data size: ${decryptResult.length} bytes`);
|
|
289
|
+
console.log(` Binary integrity preserved throughout process`);
|
|
290
|
+
|
|
291
|
+
return decryptResult;
|
|
292
|
+
} catch (error) {
|
|
293
|
+
throw new Error(`Decryption failed: ${error}`);
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
// ==================== SESSION KEY MANAGEMENT ====================
|
|
298
|
+
|
|
299
|
+
/**
|
|
300
|
+
* Create a new session key for a user via SealService
|
|
301
|
+
*
|
|
302
|
+
* Two usage patterns:
|
|
303
|
+
* 1. Frontend: Pass signPersonalMessageFn from @mysten/dapp-kit useSignPersonalMessage hook
|
|
304
|
+
* 2. Backend: Pass keypair for direct signing (auto-converts format)
|
|
305
|
+
*/
|
|
306
|
+
async createSessionKey(
|
|
307
|
+
userAddress: string,
|
|
308
|
+
signer?: {
|
|
309
|
+
// Frontend pattern: dapp-kit signPersonalMessage function
|
|
310
|
+
signPersonalMessageFn?: (message: string) => Promise<{ signature: string }>;
|
|
311
|
+
// Backend pattern: Ed25519Keypair for direct signing
|
|
312
|
+
keypair?: any;
|
|
313
|
+
}
|
|
314
|
+
): Promise<SessionKey> {
|
|
315
|
+
try {
|
|
316
|
+
console.log('🔄 EncryptionService: Creating SEAL session key...');
|
|
317
|
+
console.log(` User address: ${userAddress}`);
|
|
318
|
+
console.log(` TTL: 30 minutes (maximum allowed)`);
|
|
319
|
+
|
|
320
|
+
const sessionResult = await this.sealService.createSession({
|
|
321
|
+
address: userAddress,
|
|
322
|
+
packageId: this.packageId,
|
|
323
|
+
ttlMin: 30, // Use 30 minutes (maximum allowed)
|
|
324
|
+
});
|
|
325
|
+
|
|
326
|
+
// Handle signing based on provided signer type
|
|
327
|
+
if (signer?.signPersonalMessageFn) {
|
|
328
|
+
// Frontend pattern: Use dapp-kit signPersonalMessage (RECOMMENDED)
|
|
329
|
+
console.log('🔄 Signing with dapp-kit signPersonalMessage (recommended)...');
|
|
330
|
+
const personalMessage = sessionResult.personalMessage;
|
|
331
|
+
|
|
332
|
+
// Convert to string if it's a byte array
|
|
333
|
+
const messageString = typeof personalMessage === 'string'
|
|
334
|
+
? personalMessage
|
|
335
|
+
: new TextDecoder().decode(personalMessage);
|
|
336
|
+
|
|
337
|
+
console.log(` Message (first 100 chars): ${messageString.substring(0, 100)}...`);
|
|
338
|
+
|
|
339
|
+
// Use dapp-kit signPersonalMessage - returns signature in correct format
|
|
340
|
+
const result = await signer.signPersonalMessageFn(messageString);
|
|
341
|
+
|
|
342
|
+
console.log(` Signature from dapp-kit: ${result.signature.substring(0, 20)}...`);
|
|
343
|
+
console.log(` ✅ Using dapp-kit signature format (already compatible with SEAL)`);
|
|
344
|
+
|
|
345
|
+
// Set signature directly - dapp-kit returns it in SEAL-compatible format
|
|
346
|
+
await sessionResult.sessionKey.setPersonalMessageSignature(result.signature);
|
|
347
|
+
console.log('✅ Personal message signed with dapp-kit');
|
|
348
|
+
|
|
349
|
+
} else if (signer?.keypair) {
|
|
350
|
+
// Backend pattern: Use Ed25519Keypair with format conversion
|
|
351
|
+
console.log('🔄 Signing with Ed25519Keypair (backend fallback)...');
|
|
352
|
+
const personalMessage = sessionResult.personalMessage;
|
|
353
|
+
|
|
354
|
+
// Convert to string if it's a byte array
|
|
355
|
+
const messageString = typeof personalMessage === 'string'
|
|
356
|
+
? personalMessage
|
|
357
|
+
: new TextDecoder().decode(personalMessage);
|
|
358
|
+
|
|
359
|
+
console.log(` Message (first 100 chars): ${messageString.substring(0, 100)}...`);
|
|
360
|
+
|
|
361
|
+
// Sign with keypair
|
|
362
|
+
const messageSignature = await signer.keypair.signPersonalMessage(new TextEncoder().encode(messageString));
|
|
363
|
+
|
|
364
|
+
// CRITICAL FIX: Use signature as-is from Ed25519Keypair (SEAL expects original format)
|
|
365
|
+
// According to SEAL documentation, pass signature directly from keypair.signPersonalMessage()
|
|
366
|
+
console.log(` ✅ Using signature as-is from Ed25519Keypair (SEAL-compatible format)`);
|
|
367
|
+
console.log(` Original signature: ${messageSignature.signature.substring(0, 20)}...`);
|
|
368
|
+
|
|
369
|
+
// Set signature exactly as returned by keypair (no conversion needed)
|
|
370
|
+
await sessionResult.sessionKey.setPersonalMessageSignature(messageSignature.signature);
|
|
371
|
+
console.log('✅ Personal message signed with Ed25519Keypair');
|
|
372
|
+
|
|
373
|
+
} else {
|
|
374
|
+
console.log('⚠️ No signer provided - session key created but not signed');
|
|
375
|
+
console.log(' Note: Call setPersonalMessageSignature() later with wallet-signed message');
|
|
376
|
+
console.log(' Frontend: Use dapp-kit useSignPersonalMessage hook');
|
|
377
|
+
console.log(' Backend: Provide Ed25519Keypair');
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
// Cache the session key
|
|
381
|
+
this.sessionKeyCache.set(userAddress, sessionResult.sessionKey);
|
|
382
|
+
|
|
383
|
+
console.log('✅ EncryptionService: Session key created and cached');
|
|
384
|
+
return sessionResult.sessionKey;
|
|
385
|
+
} catch (error) {
|
|
386
|
+
throw new Error(`Failed to create session key: ${error}`);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
|
|
390
|
+
/**
|
|
391
|
+
* Get cached session key or create new one
|
|
392
|
+
*/
|
|
393
|
+
async getOrCreateSessionKey(userAddress: string): Promise<SessionKey> {
|
|
394
|
+
const cached = this.sessionKeyCache.get(userAddress);
|
|
395
|
+
if (cached) {
|
|
396
|
+
return cached;
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
return this.createSessionKey(userAddress);
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
/**
|
|
403
|
+
* Export session key for persistence
|
|
404
|
+
*/
|
|
405
|
+
async exportSessionKey(sessionKey: SessionKey): Promise<string> {
|
|
406
|
+
try {
|
|
407
|
+
const exported = sessionKey.export();
|
|
408
|
+
return JSON.stringify(exported);
|
|
409
|
+
} catch (error) {
|
|
410
|
+
throw new Error(`Failed to export session key: ${error}`);
|
|
411
|
+
}
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
/**
|
|
415
|
+
* Import previously exported session key
|
|
416
|
+
*/
|
|
417
|
+
async importSessionKey(exportedKey: string, userAddress?: string): Promise<SessionKey> {
|
|
418
|
+
try {
|
|
419
|
+
const keyData = JSON.parse(exportedKey);
|
|
420
|
+
const sessionKey = SessionKey.import(keyData, this.suiClient);
|
|
421
|
+
|
|
422
|
+
if (userAddress) {
|
|
423
|
+
this.sessionKeyCache.set(userAddress, sessionKey);
|
|
424
|
+
}
|
|
425
|
+
|
|
426
|
+
return sessionKey;
|
|
427
|
+
} catch (error) {
|
|
428
|
+
throw new Error(`Failed to import session key: ${error}`);
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
// ==================== ACCESS CONTROL TRANSACTIONS ====================
|
|
433
|
+
|
|
434
|
+
/**
|
|
435
|
+
* Create SEAL approval transaction bytes (matches memory-workflow-seal.ts pattern)
|
|
436
|
+
* Returns raw PTB format bytes for SEAL verification
|
|
437
|
+
*/
|
|
438
|
+
async createSealApproveTransaction(userAddress: string, contentOwner: string): Promise<Uint8Array> {
|
|
439
|
+
try {
|
|
440
|
+
console.log('🔄 EncryptionService: Creating SEAL approval transaction...');
|
|
441
|
+
console.log(` User address: ${userAddress}`);
|
|
442
|
+
console.log(` Content owner: ${contentOwner}`);
|
|
443
|
+
|
|
444
|
+
// Create the approval transaction (not signed, just bytes)
|
|
445
|
+
const tx = await this.buildAccessTransactionForWallet(userAddress, contentOwner, 'read');
|
|
446
|
+
// CRITICAL: Set sender before building - required by Transaction.build()
|
|
447
|
+
tx.setSender(contentOwner);
|
|
448
|
+
const txBytes = await tx.build({ client: this.suiClient });
|
|
449
|
+
|
|
450
|
+
console.log(`✅ Created SEAL approval transaction bytes (${txBytes.length} bytes)`);
|
|
451
|
+
console.log(' Format: Raw PTB (Programmable Transaction Block) for SEAL verification');
|
|
452
|
+
|
|
453
|
+
return txBytes;
|
|
454
|
+
} catch (error) {
|
|
455
|
+
throw new Error(`Failed to create SEAL approval transaction: ${error}`);
|
|
456
|
+
}
|
|
457
|
+
}
|
|
458
|
+
|
|
459
|
+
/**
|
|
460
|
+
* Build transaction to grant access to another user
|
|
461
|
+
*/
|
|
462
|
+
async buildGrantAccessTransaction(options: AccessGrantOptions): Promise<Transaction> {
|
|
463
|
+
const { ownerAddress, recipientAddress, contentId, accessLevel, expiresIn } = options;
|
|
464
|
+
const tx = new Transaction();
|
|
465
|
+
|
|
466
|
+
const expiresAt = expiresIn ? Date.now() + expiresIn : Date.now() + 86400000; // 24h default
|
|
467
|
+
|
|
468
|
+
tx.moveCall({
|
|
469
|
+
target: `${this.packageId}::seal_access_control::grant_access`,
|
|
470
|
+
arguments: [
|
|
471
|
+
tx.pure.address(ownerAddress),
|
|
472
|
+
tx.pure.address(recipientAddress),
|
|
473
|
+
tx.pure.string(contentId),
|
|
474
|
+
tx.pure.string(accessLevel),
|
|
475
|
+
tx.pure.u64(expiresAt),
|
|
476
|
+
],
|
|
477
|
+
});
|
|
478
|
+
|
|
479
|
+
return tx;
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
/**
|
|
483
|
+
* Build transaction to revoke access from a user
|
|
484
|
+
*/
|
|
485
|
+
async buildRevokeAccessTransaction(options: AccessRevokeOptions): Promise<Transaction> {
|
|
486
|
+
const { ownerAddress, recipientAddress, contentId } = options;
|
|
487
|
+
const tx = new Transaction();
|
|
488
|
+
|
|
489
|
+
tx.moveCall({
|
|
490
|
+
target: `${this.packageId}::seal_access_control::revoke_access`,
|
|
491
|
+
arguments: [
|
|
492
|
+
tx.pure.address(ownerAddress),
|
|
493
|
+
tx.pure.address(recipientAddress),
|
|
494
|
+
tx.pure.string(contentId),
|
|
495
|
+
],
|
|
496
|
+
});
|
|
497
|
+
|
|
498
|
+
return tx;
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
/**
|
|
502
|
+
* Build transaction to register content ownership
|
|
503
|
+
*/
|
|
504
|
+
async buildRegisterContentTransaction(
|
|
505
|
+
ownerAddress: string,
|
|
506
|
+
contentId: string,
|
|
507
|
+
contentHash: string
|
|
508
|
+
): Promise<Transaction> {
|
|
509
|
+
const tx = new Transaction();
|
|
510
|
+
|
|
511
|
+
tx.moveCall({
|
|
512
|
+
target: `${this.packageId}::seal_access_control::register_content`,
|
|
513
|
+
arguments: [
|
|
514
|
+
tx.pure.address(ownerAddress),
|
|
515
|
+
tx.pure.string(contentId),
|
|
516
|
+
tx.pure.string(contentHash),
|
|
517
|
+
tx.pure.string(''), // encryption_info
|
|
518
|
+
],
|
|
519
|
+
});
|
|
520
|
+
|
|
521
|
+
return tx;
|
|
522
|
+
}
|
|
523
|
+
|
|
524
|
+
// ==================== TRANSACTION BUILDERS ====================
|
|
525
|
+
|
|
526
|
+
get tx() {
|
|
527
|
+
return {
|
|
528
|
+
/**
|
|
529
|
+
* Grant access to encrypted memory
|
|
530
|
+
*/
|
|
531
|
+
grantAccess: (options: AccessGrantOptions) => {
|
|
532
|
+
return this.buildGrantAccessTransaction(options);
|
|
533
|
+
},
|
|
534
|
+
|
|
535
|
+
/**
|
|
536
|
+
* Revoke access to encrypted memory
|
|
537
|
+
*/
|
|
538
|
+
revokeAccess: (options: AccessRevokeOptions) => {
|
|
539
|
+
return this.buildRevokeAccessTransaction(options);
|
|
540
|
+
},
|
|
541
|
+
|
|
542
|
+
/**
|
|
543
|
+
* Register content ownership
|
|
544
|
+
*/
|
|
545
|
+
registerContent: (ownerAddress: string, contentId: string, contentHash: string) => {
|
|
546
|
+
return this.buildRegisterContentTransaction(ownerAddress, contentId, contentHash);
|
|
547
|
+
},
|
|
548
|
+
|
|
549
|
+
/**
|
|
550
|
+
* Build access approval transaction
|
|
551
|
+
*/
|
|
552
|
+
buildAccessTransaction: (userAddress: string, accessType: 'read' | 'write' = 'read') => {
|
|
553
|
+
return this.buildAccessTransaction(userAddress, accessType);
|
|
554
|
+
},
|
|
555
|
+
};
|
|
556
|
+
}
|
|
557
|
+
|
|
558
|
+
// ==================== MOVE CALL BUILDERS ====================
|
|
559
|
+
|
|
560
|
+
get call() {
|
|
561
|
+
return {
|
|
562
|
+
/**
|
|
563
|
+
* Move call for granting access
|
|
564
|
+
*/
|
|
565
|
+
grantAccess: (options: AccessGrantOptions): Thunk => {
|
|
566
|
+
return async (tx) => {
|
|
567
|
+
const grantTx = await this.buildGrantAccessTransaction(options);
|
|
568
|
+
return grantTx;
|
|
569
|
+
};
|
|
570
|
+
},
|
|
571
|
+
|
|
572
|
+
/**
|
|
573
|
+
* Move call for revoking access
|
|
574
|
+
*/
|
|
575
|
+
revokeAccess: (options: AccessRevokeOptions): Thunk => {
|
|
576
|
+
return async (tx) => {
|
|
577
|
+
const revokeTx = await this.buildRevokeAccessTransaction(options);
|
|
578
|
+
return revokeTx;
|
|
579
|
+
};
|
|
580
|
+
},
|
|
581
|
+
};
|
|
582
|
+
}
|
|
583
|
+
|
|
584
|
+
// ==================== ACCESS CONTROL QUERIES ====================
|
|
585
|
+
|
|
586
|
+
/**
|
|
587
|
+
* Check if a user has access to decrypt content
|
|
588
|
+
*/
|
|
589
|
+
async hasAccess(
|
|
590
|
+
userAddress: string,
|
|
591
|
+
contentId: string,
|
|
592
|
+
ownerAddress: string
|
|
593
|
+
): Promise<boolean> {
|
|
594
|
+
try {
|
|
595
|
+
if (userAddress === ownerAddress) {
|
|
596
|
+
return true;
|
|
597
|
+
}
|
|
598
|
+
|
|
599
|
+
const tx = new Transaction();
|
|
600
|
+
tx.moveCall({
|
|
601
|
+
target: `${this.packageId}::seal_access_control::check_access`,
|
|
602
|
+
arguments: [
|
|
603
|
+
tx.pure.address(userAddress),
|
|
604
|
+
tx.pure.string(contentId),
|
|
605
|
+
tx.pure.address(ownerAddress),
|
|
606
|
+
],
|
|
607
|
+
});
|
|
608
|
+
|
|
609
|
+
const result = await this.suiClient.devInspectTransactionBlock({
|
|
610
|
+
transactionBlock: tx,
|
|
611
|
+
sender: userAddress,
|
|
612
|
+
});
|
|
613
|
+
|
|
614
|
+
return result.effects.status.status === 'success';
|
|
615
|
+
} catch (error) {
|
|
616
|
+
console.error(`Error checking access: ${error}`);
|
|
617
|
+
return false;
|
|
618
|
+
}
|
|
619
|
+
}
|
|
620
|
+
|
|
621
|
+
// ==================== VIEW METHODS ====================
|
|
622
|
+
|
|
623
|
+
get view() {
|
|
624
|
+
return {
|
|
625
|
+
/**
|
|
626
|
+
* Get access permissions for memories
|
|
627
|
+
*/
|
|
628
|
+
getAccessPermissions: async (userAddress: string, memoryId?: string): Promise<AccessPermission[]> => {
|
|
629
|
+
// Note: This would typically require event queries or indexing
|
|
630
|
+
// For now, return empty array as this requires additional infrastructure
|
|
631
|
+
console.warn('getAccessPermissions: This method requires event indexing infrastructure');
|
|
632
|
+
return [];
|
|
633
|
+
},
|
|
634
|
+
|
|
635
|
+
/**
|
|
636
|
+
* Check if user has access to content
|
|
637
|
+
*/
|
|
638
|
+
hasAccess: (userAddress: string, contentId: string, ownerAddress: string) => {
|
|
639
|
+
return this.hasAccess(userAddress, contentId, ownerAddress);
|
|
640
|
+
},
|
|
641
|
+
};
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
// ==================== UTILITY METHODS ====================
|
|
645
|
+
|
|
646
|
+
/**
|
|
647
|
+
* Compute SEAL key_id from owner address and nonce
|
|
648
|
+
*
|
|
649
|
+
* Mirrors the Move implementation in capability.move:
|
|
650
|
+
* key_id = keccak256(owner || nonce)
|
|
651
|
+
*
|
|
652
|
+
* @param ownerAddress - Owner's Sui address
|
|
653
|
+
* @param nonce - Nonce from MemoryCap object (32 bytes keccak hash)
|
|
654
|
+
* @returns key_id bytes for SEAL approval (32 bytes)
|
|
655
|
+
*/
|
|
656
|
+
computeKeyId(ownerAddress: string, nonce: Uint8Array): Uint8Array {
|
|
657
|
+
// Convert owner address to bytes (BCS format - 32 bytes)
|
|
658
|
+
const ownerBytes = fromHex(ownerAddress.replace('0x', '').padStart(64, '0'));
|
|
659
|
+
|
|
660
|
+
// Concatenate owner || nonce (matches Move: bcs::to_bytes(&owner) + nonce)
|
|
661
|
+
const data = new Uint8Array(ownerBytes.length + nonce.length);
|
|
662
|
+
data.set(ownerBytes, 0);
|
|
663
|
+
data.set(nonce, ownerBytes.length);
|
|
664
|
+
|
|
665
|
+
// Use keccak256 hash (matches Move implementation exactly)
|
|
666
|
+
const keyId = keccak_256(data);
|
|
667
|
+
|
|
668
|
+
console.log(`🔑 Computed key_id from owner ${ownerAddress.slice(0, 10)}... and nonce (${nonce.length} bytes)`);
|
|
669
|
+
return keyId;
|
|
670
|
+
}
|
|
671
|
+
|
|
672
|
+
/**
|
|
673
|
+
* Generate content hash for verification
|
|
674
|
+
*/
|
|
675
|
+
private async generateContentHash(data: Uint8Array): Promise<string> {
|
|
676
|
+
// Create a new Uint8Array to ensure proper typing
|
|
677
|
+
const dataArray = new Uint8Array(data);
|
|
678
|
+
const hashBuffer = await crypto.subtle.digest('SHA-256', dataArray);
|
|
679
|
+
const hashArray = Array.from(new Uint8Array(hashBuffer));
|
|
680
|
+
return hashArray.map(b => b.toString(16).padStart(2, '0')).join('');
|
|
681
|
+
}
|
|
682
|
+
|
|
683
|
+
/**
|
|
684
|
+
* Verify content integrity
|
|
685
|
+
*/
|
|
686
|
+
async verifyContentHash(data: Uint8Array, expectedHash: string): Promise<boolean> {
|
|
687
|
+
const actualHash = await this.generateContentHash(data);
|
|
688
|
+
return actualHash === expectedHash;
|
|
689
|
+
}
|
|
690
|
+
|
|
691
|
+
/**
|
|
692
|
+
* Check if SEAL service is available
|
|
693
|
+
*/
|
|
694
|
+
isAvailable(): boolean {
|
|
695
|
+
return this.sealService !== null;
|
|
696
|
+
}
|
|
697
|
+
|
|
698
|
+
/**
|
|
699
|
+
* Get SEAL service configuration info
|
|
700
|
+
*/
|
|
701
|
+
getClientInfo(): {
|
|
702
|
+
isInitialized: boolean;
|
|
703
|
+
packageId: string;
|
|
704
|
+
encryptionEnabled: boolean;
|
|
705
|
+
} {
|
|
706
|
+
return {
|
|
707
|
+
isInitialized: this.sealService !== null,
|
|
708
|
+
packageId: this.packageId,
|
|
709
|
+
encryptionEnabled: this.config.encryptionConfig?.enabled || false,
|
|
710
|
+
};
|
|
711
|
+
}
|
|
712
|
+
}
|