@opendatalabs/vana-sdk 0.1.0-alpha.d44f792 → 0.1.0-alpha.d596df3

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 (889) hide show
  1. package/README.md +68 -13
  2. package/dist/__tests__/waitForTransactionEvents.test.d.ts +1 -0
  3. package/dist/browser.cjs +29 -0
  4. package/dist/browser.cjs.map +1 -0
  5. package/dist/browser.d.ts +36 -0
  6. package/dist/browser.js +5 -0
  7. package/dist/browser.js.map +1 -0
  8. package/dist/{chains.browser.cjs → chains/definitions.cjs} +16 -17
  9. package/dist/chains/definitions.cjs.map +1 -0
  10. package/dist/{chains.browser.d.cts → chains/definitions.d.ts} +9 -11
  11. package/dist/chains/definitions.js +67 -0
  12. package/dist/chains/definitions.js.map +1 -0
  13. package/dist/chains/index.cjs +37 -0
  14. package/dist/chains/index.cjs.map +1 -0
  15. package/dist/chains/index.d.ts +34 -0
  16. package/dist/chains/index.js +15 -0
  17. package/dist/chains/index.js.map +1 -0
  18. package/dist/chains.browser.d.ts +5 -50
  19. package/dist/chains.browser.js +7 -57
  20. package/dist/chains.browser.js.map +1 -1
  21. package/dist/chains.cjs +6 -65
  22. package/dist/chains.cjs.map +1 -1
  23. package/dist/chains.d.ts +8 -2
  24. package/dist/chains.js +7 -57
  25. package/dist/chains.js.map +1 -1
  26. package/dist/chains.node.cjs +6 -65
  27. package/dist/chains.node.cjs.map +1 -1
  28. package/dist/chains.node.d.ts +8 -2
  29. package/dist/chains.node.js +7 -57
  30. package/dist/chains.node.js.map +1 -1
  31. package/dist/config/addresses.cjs +325 -0
  32. package/dist/config/addresses.cjs.map +1 -0
  33. package/dist/config/addresses.d.ts +364 -0
  34. package/dist/config/addresses.js +295 -0
  35. package/dist/config/addresses.js.map +1 -0
  36. package/dist/config/chains.cjs +93 -0
  37. package/dist/config/chains.cjs.map +1 -0
  38. package/dist/config/chains.d.ts +180 -0
  39. package/dist/config/chains.js +67 -0
  40. package/dist/config/chains.js.map +1 -0
  41. package/dist/config/default-services.cjs +60 -0
  42. package/dist/config/default-services.cjs.map +1 -0
  43. package/dist/config/default-services.d.ts +46 -0
  44. package/dist/config/default-services.js +33 -0
  45. package/dist/config/default-services.js.map +1 -0
  46. package/dist/config/default-services.test.d.ts +1 -0
  47. package/dist/config/features.cjs +52 -0
  48. package/dist/config/features.cjs.map +1 -0
  49. package/dist/config/features.d.ts +62 -0
  50. package/dist/config/features.js +28 -0
  51. package/dist/config/features.js.map +1 -0
  52. package/dist/config/tests/addresses.test.d.ts +1 -0
  53. package/dist/contracts/contractController.cjs +126 -0
  54. package/dist/contracts/contractController.cjs.map +1 -0
  55. package/dist/contracts/contractController.d.ts +135 -0
  56. package/dist/contracts/contractController.js +100 -0
  57. package/dist/contracts/contractController.js.map +1 -0
  58. package/dist/contracts/tests/contractController.test.d.ts +1 -0
  59. package/dist/controllers/__tests__/data-consistency-integration.test.d.ts +7 -0
  60. package/dist/controllers/__tests__/operations.processQueue.test.d.ts +1 -0
  61. package/dist/controllers/__tests__/schemas-edge-cases.test.d.ts +1 -0
  62. package/dist/controllers/base.cjs +116 -0
  63. package/dist/controllers/base.cjs.map +1 -0
  64. package/dist/controllers/base.d.ts +94 -0
  65. package/dist/controllers/base.js +92 -0
  66. package/dist/controllers/base.js.map +1 -0
  67. package/dist/controllers/data-error-handling.test.d.ts +1 -0
  68. package/dist/controllers/data.cjs +2627 -0
  69. package/dist/controllers/data.cjs.map +1 -0
  70. package/dist/controllers/data.d.ts +1060 -0
  71. package/dist/controllers/data.js +2620 -0
  72. package/dist/controllers/data.js.map +1 -0
  73. package/dist/controllers/operations.cjs +430 -0
  74. package/dist/controllers/operations.cjs.map +1 -0
  75. package/dist/controllers/operations.d.ts +229 -0
  76. package/dist/controllers/operations.js +406 -0
  77. package/dist/controllers/operations.js.map +1 -0
  78. package/dist/controllers/permissions.cjs +4304 -0
  79. package/dist/controllers/permissions.cjs.map +1 -0
  80. package/dist/controllers/permissions.d.ts +1393 -0
  81. package/dist/controllers/permissions.js +4280 -0
  82. package/dist/controllers/permissions.js.map +1 -0
  83. package/dist/controllers/protocol.cjs +183 -0
  84. package/dist/controllers/protocol.cjs.map +1 -0
  85. package/dist/controllers/protocol.d.ts +138 -0
  86. package/dist/controllers/protocol.js +163 -0
  87. package/dist/controllers/protocol.js.map +1 -0
  88. package/dist/controllers/schemas.cjs +609 -0
  89. package/dist/controllers/schemas.cjs.map +1 -0
  90. package/dist/controllers/schemas.d.ts +254 -0
  91. package/dist/controllers/schemas.js +585 -0
  92. package/dist/controllers/schemas.js.map +1 -0
  93. package/dist/controllers/server-additional.test.d.ts +1 -0
  94. package/dist/controllers/server.cjs +434 -0
  95. package/dist/controllers/server.cjs.map +1 -0
  96. package/dist/controllers/server.d.ts +225 -0
  97. package/dist/controllers/server.js +415 -0
  98. package/dist/controllers/server.js.map +1 -0
  99. package/dist/core/__tests__/health.test.d.ts +1 -0
  100. package/dist/core/__tests__/inMemoryNonceManager.test.d.ts +1 -0
  101. package/dist/core/__tests__/nonceManager.test.d.ts +1 -0
  102. package/dist/core/__tests__/pollingManager.test.d.ts +4 -0
  103. package/dist/core/apiClient.cjs +378 -0
  104. package/dist/core/apiClient.cjs.map +1 -0
  105. package/dist/core/apiClient.d.ts +286 -0
  106. package/dist/core/apiClient.js +359 -0
  107. package/dist/core/apiClient.js.map +1 -0
  108. package/dist/core/client.cjs +70 -0
  109. package/dist/core/client.cjs.map +1 -0
  110. package/dist/core/client.d.ts +89 -0
  111. package/dist/core/client.js +47 -0
  112. package/dist/core/client.js.map +1 -0
  113. package/dist/core/core.test.d.ts +1 -0
  114. package/dist/core/generics.cjs +417 -0
  115. package/dist/core/generics.cjs.map +1 -0
  116. package/dist/core/generics.d.ts +205 -0
  117. package/dist/core/generics.js +386 -0
  118. package/dist/core/generics.js.map +1 -0
  119. package/dist/core/health.cjs +289 -0
  120. package/dist/core/health.cjs.map +1 -0
  121. package/dist/core/health.d.ts +143 -0
  122. package/dist/core/health.js +265 -0
  123. package/dist/core/health.js.map +1 -0
  124. package/dist/core/inMemoryNonceManager.cjs +138 -0
  125. package/dist/core/inMemoryNonceManager.cjs.map +1 -0
  126. package/dist/core/inMemoryNonceManager.d.ts +69 -0
  127. package/dist/core/inMemoryNonceManager.js +114 -0
  128. package/dist/core/inMemoryNonceManager.js.map +1 -0
  129. package/dist/core/nonceManager.cjs +304 -0
  130. package/dist/core/nonceManager.cjs.map +1 -0
  131. package/dist/core/nonceManager.d.ts +116 -0
  132. package/dist/core/nonceManager.js +280 -0
  133. package/dist/core/nonceManager.js.map +1 -0
  134. package/dist/core/pollingManager.cjs +292 -0
  135. package/dist/core/pollingManager.cjs.map +1 -0
  136. package/dist/core/pollingManager.d.ts +120 -0
  137. package/dist/core/pollingManager.js +268 -0
  138. package/dist/core/pollingManager.js.map +1 -0
  139. package/dist/core/tests/apiClient.test.d.ts +1 -0
  140. package/dist/core/tests/client.test.d.ts +1 -0
  141. package/dist/core/tests/generics.test.d.ts +1 -0
  142. package/dist/core.cjs +731 -0
  143. package/dist/core.cjs.map +1 -0
  144. package/dist/core.d.ts +449 -0
  145. package/dist/core.js +706 -0
  146. package/dist/core.js.map +1 -0
  147. package/dist/crypto/ecies/__tests__/base.test.d.ts +4 -0
  148. package/dist/crypto/ecies/__tests__/compatibility.test.d.ts +8 -0
  149. package/dist/crypto/ecies/__tests__/constants.test.d.ts +4 -0
  150. package/dist/crypto/ecies/__tests__/native-parity.test.d.ts +7 -0
  151. package/dist/crypto/ecies/__tests__/normalization.test.d.ts +1 -0
  152. package/dist/crypto/ecies/__tests__/test-vectors.cjs +102 -0
  153. package/dist/crypto/ecies/__tests__/test-vectors.cjs.map +1 -0
  154. package/dist/crypto/ecies/__tests__/test-vectors.d.ts +38 -0
  155. package/dist/crypto/ecies/__tests__/test-vectors.js +77 -0
  156. package/dist/crypto/ecies/__tests__/test-vectors.js.map +1 -0
  157. package/dist/crypto/ecies/base.cjs +245 -0
  158. package/dist/crypto/ecies/base.cjs.map +1 -0
  159. package/dist/crypto/ecies/base.d.ts +140 -0
  160. package/dist/crypto/ecies/base.js +221 -0
  161. package/dist/crypto/ecies/base.js.map +1 -0
  162. package/dist/crypto/ecies/browser.cjs +165 -0
  163. package/dist/crypto/ecies/browser.cjs.map +1 -0
  164. package/dist/crypto/ecies/browser.d.ts +43 -0
  165. package/dist/crypto/ecies/browser.js +131 -0
  166. package/dist/crypto/ecies/browser.js.map +1 -0
  167. package/dist/crypto/ecies/constants.cjs +131 -0
  168. package/dist/crypto/ecies/constants.cjs.map +1 -0
  169. package/dist/crypto/ecies/constants.d.ts +120 -0
  170. package/dist/crypto/ecies/constants.js +101 -0
  171. package/dist/crypto/ecies/constants.js.map +1 -0
  172. package/dist/crypto/ecies/index.cjs +35 -0
  173. package/dist/crypto/ecies/index.cjs.map +1 -0
  174. package/dist/crypto/ecies/index.d.ts +8 -0
  175. package/dist/crypto/ecies/index.js +13 -0
  176. package/dist/crypto/ecies/index.js.map +1 -0
  177. package/dist/crypto/ecies/interface.cjs +87 -0
  178. package/dist/crypto/ecies/interface.cjs.map +1 -0
  179. package/dist/crypto/ecies/interface.d.ts +174 -0
  180. package/dist/crypto/ecies/interface.js +60 -0
  181. package/dist/crypto/ecies/interface.js.map +1 -0
  182. package/dist/crypto/ecies/node.cjs +167 -0
  183. package/dist/crypto/ecies/node.cjs.map +1 -0
  184. package/dist/crypto/ecies/node.d.ts +45 -0
  185. package/dist/crypto/ecies/node.js +139 -0
  186. package/dist/crypto/ecies/node.js.map +1 -0
  187. package/dist/crypto/ecies/test-vectors/eccrypto-vectors.json +72 -0
  188. package/dist/crypto/ecies/utils.cjs +52 -0
  189. package/dist/crypto/ecies/utils.cjs.map +1 -0
  190. package/dist/crypto/ecies/utils.d.ts +30 -0
  191. package/dist/crypto/ecies/utils.js +26 -0
  192. package/dist/crypto/ecies/utils.js.map +1 -0
  193. package/dist/crypto/services/WalletKeyEncryptionService.cjs +128 -0
  194. package/dist/crypto/services/WalletKeyEncryptionService.cjs.map +1 -0
  195. package/dist/crypto/services/WalletKeyEncryptionService.d.ts +88 -0
  196. package/dist/crypto/services/WalletKeyEncryptionService.js +108 -0
  197. package/dist/crypto/services/WalletKeyEncryptionService.js.map +1 -0
  198. package/dist/crypto/services/WalletKeyEncryptionService.test.d.ts +1 -0
  199. package/dist/diagnostics.cjs +37 -0
  200. package/dist/diagnostics.cjs.map +1 -0
  201. package/dist/diagnostics.d.ts +24 -0
  202. package/dist/diagnostics.js +13 -0
  203. package/dist/diagnostics.js.map +1 -0
  204. package/dist/diagnostics.test.d.ts +1 -0
  205. package/dist/errors.cjs +186 -0
  206. package/dist/errors.cjs.map +1 -0
  207. package/dist/errors.d.ts +452 -0
  208. package/dist/errors.js +148 -0
  209. package/dist/errors.js.map +1 -0
  210. package/dist/generated/abi/ComputeEngineImplementation.cjs +1313 -0
  211. package/dist/generated/abi/ComputeEngineImplementation.cjs.map +1 -0
  212. package/dist/generated/abi/ComputeEngineImplementation.d.ts +995 -0
  213. package/dist/generated/abi/ComputeEngineImplementation.js +1289 -0
  214. package/dist/generated/abi/ComputeEngineImplementation.js.map +1 -0
  215. package/dist/generated/abi/ComputeInstructionRegistryImplementation.cjs +734 -0
  216. package/dist/generated/abi/ComputeInstructionRegistryImplementation.cjs.map +1 -0
  217. package/dist/generated/abi/ComputeInstructionRegistryImplementation.d.ts +544 -0
  218. package/dist/generated/abi/ComputeInstructionRegistryImplementation.js +710 -0
  219. package/dist/generated/abi/ComputeInstructionRegistryImplementation.js.map +1 -0
  220. package/dist/generated/abi/DATFactoryImplementation.cjs +882 -0
  221. package/dist/generated/abi/DATFactoryImplementation.cjs.map +1 -0
  222. package/dist/generated/abi/DATFactoryImplementation.d.ts +660 -0
  223. package/dist/generated/abi/DATFactoryImplementation.js +858 -0
  224. package/dist/generated/abi/DATFactoryImplementation.js.map +1 -0
  225. package/dist/generated/abi/DATImplementation.cjs +934 -0
  226. package/dist/generated/abi/DATImplementation.cjs.map +1 -0
  227. package/dist/generated/abi/DATImplementation.d.ts +692 -0
  228. package/dist/generated/abi/DATImplementation.js +910 -0
  229. package/dist/generated/abi/DATImplementation.js.map +1 -0
  230. package/dist/generated/abi/DATPausableImplementation.cjs +1523 -0
  231. package/dist/generated/abi/DATPausableImplementation.cjs.map +1 -0
  232. package/dist/generated/abi/DATPausableImplementation.d.ts +1144 -0
  233. package/dist/generated/abi/DATPausableImplementation.js +1499 -0
  234. package/dist/generated/abi/DATPausableImplementation.js.map +1 -0
  235. package/dist/generated/abi/DATVotesImplementation.cjs +1460 -0
  236. package/dist/generated/abi/DATVotesImplementation.cjs.map +1 -0
  237. package/dist/generated/abi/DATVotesImplementation.d.ts +1094 -0
  238. package/dist/generated/abi/DATVotesImplementation.js +1436 -0
  239. package/dist/generated/abi/DATVotesImplementation.js.map +1 -0
  240. package/dist/generated/abi/DLPPerformanceImplementation.cjs +1160 -0
  241. package/dist/generated/abi/DLPPerformanceImplementation.cjs.map +1 -0
  242. package/dist/generated/abi/DLPPerformanceImplementation.d.ts +882 -0
  243. package/dist/generated/abi/DLPPerformanceImplementation.js +1136 -0
  244. package/dist/generated/abi/DLPPerformanceImplementation.js.map +1 -0
  245. package/dist/generated/abi/DLPRegistryImplementation.cjs +1469 -0
  246. package/dist/generated/abi/DLPRegistryImplementation.cjs.map +1 -0
  247. package/dist/generated/abi/DLPRegistryImplementation.d.ts +1122 -0
  248. package/dist/generated/abi/DLPRegistryImplementation.js +1445 -0
  249. package/dist/generated/abi/DLPRegistryImplementation.js.map +1 -0
  250. package/dist/generated/abi/DLPRegistryTreasuryImplementation.cjs +612 -0
  251. package/dist/generated/abi/DLPRegistryTreasuryImplementation.cjs.map +1 -0
  252. package/dist/generated/abi/DLPRegistryTreasuryImplementation.d.ts +451 -0
  253. package/dist/generated/abi/DLPRegistryTreasuryImplementation.js +588 -0
  254. package/dist/generated/abi/DLPRegistryTreasuryImplementation.js.map +1 -0
  255. package/dist/generated/abi/DLPRewardDeployerImplementation.cjs +948 -0
  256. package/dist/generated/abi/DLPRewardDeployerImplementation.cjs.map +1 -0
  257. package/dist/generated/abi/DLPRewardDeployerImplementation.d.ts +713 -0
  258. package/dist/generated/abi/DLPRewardDeployerImplementation.js +924 -0
  259. package/dist/generated/abi/DLPRewardDeployerImplementation.js.map +1 -0
  260. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.cjs +612 -0
  261. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.cjs.map +1 -0
  262. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.d.ts +451 -0
  263. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.js +588 -0
  264. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.js.map +1 -0
  265. package/dist/generated/abi/DLPRewardSwapImplementation.cjs +939 -0
  266. package/dist/generated/abi/DLPRewardSwapImplementation.cjs.map +1 -0
  267. package/dist/generated/abi/DLPRewardSwapImplementation.d.ts +705 -0
  268. package/dist/generated/abi/DLPRewardSwapImplementation.js +915 -0
  269. package/dist/generated/abi/DLPRewardSwapImplementation.js.map +1 -0
  270. package/dist/generated/abi/DLPRootImplementation.cjs +1644 -0
  271. package/dist/generated/abi/DLPRootImplementation.cjs.map +1 -0
  272. package/dist/generated/abi/DLPRootImplementation.d.ts +1246 -0
  273. package/dist/generated/abi/DLPRootImplementation.js +1620 -0
  274. package/dist/generated/abi/DLPRootImplementation.js.map +1 -0
  275. package/dist/generated/abi/DLPTreasuryImplementation.cjs +612 -0
  276. package/dist/generated/abi/DLPTreasuryImplementation.cjs.map +1 -0
  277. package/dist/generated/abi/DLPTreasuryImplementation.d.ts +451 -0
  278. package/dist/generated/abi/DLPTreasuryImplementation.js +588 -0
  279. package/dist/generated/abi/DLPTreasuryImplementation.js.map +1 -0
  280. package/dist/generated/abi/DataLiquidityPoolImplementation.cjs +985 -0
  281. package/dist/generated/abi/DataLiquidityPoolImplementation.cjs.map +1 -0
  282. package/dist/generated/abi/DataLiquidityPoolImplementation.d.ts +735 -0
  283. package/dist/generated/abi/DataLiquidityPoolImplementation.js +961 -0
  284. package/dist/generated/abi/DataLiquidityPoolImplementation.js.map +1 -0
  285. package/dist/generated/abi/DataPortabilityGranteesImplementation.cjs +1050 -0
  286. package/dist/generated/abi/DataPortabilityGranteesImplementation.cjs.map +1 -0
  287. package/dist/generated/abi/DataPortabilityGranteesImplementation.d.ts +783 -0
  288. package/dist/generated/abi/DataPortabilityGranteesImplementation.js +1026 -0
  289. package/dist/generated/abi/DataPortabilityGranteesImplementation.js.map +1 -0
  290. package/dist/generated/abi/DataPortabilityPermissionsImplementation.cjs +1317 -0
  291. package/dist/generated/abi/DataPortabilityPermissionsImplementation.cjs.map +1 -0
  292. package/dist/generated/abi/DataPortabilityPermissionsImplementation.d.ts +988 -0
  293. package/dist/generated/abi/DataPortabilityPermissionsImplementation.js +1293 -0
  294. package/dist/generated/abi/DataPortabilityPermissionsImplementation.js.map +1 -0
  295. package/dist/generated/abi/DataPortabilityServersImplementation.cjs +1438 -0
  296. package/dist/generated/abi/DataPortabilityServersImplementation.cjs.map +1 -0
  297. package/dist/generated/abi/DataPortabilityServersImplementation.d.ts +1085 -0
  298. package/dist/generated/abi/DataPortabilityServersImplementation.js +1414 -0
  299. package/dist/generated/abi/DataPortabilityServersImplementation.js.map +1 -0
  300. package/dist/generated/abi/DataRefinerRegistryImplementation.cjs +984 -0
  301. package/dist/generated/abi/DataRefinerRegistryImplementation.cjs.map +1 -0
  302. package/dist/generated/abi/DataRefinerRegistryImplementation.d.ts +736 -0
  303. package/dist/generated/abi/DataRefinerRegistryImplementation.js +960 -0
  304. package/dist/generated/abi/DataRefinerRegistryImplementation.js.map +1 -0
  305. package/dist/generated/abi/DataRegistryImplementation.cjs +1341 -0
  306. package/dist/generated/abi/DataRegistryImplementation.cjs.map +1 -0
  307. package/dist/generated/abi/DataRegistryImplementation.d.ts +1013 -0
  308. package/dist/generated/abi/DataRegistryImplementation.js +1317 -0
  309. package/dist/generated/abi/DataRegistryImplementation.js.map +1 -0
  310. package/dist/generated/abi/QueryEngineImplementation.cjs +1319 -0
  311. package/dist/generated/abi/QueryEngineImplementation.cjs.map +1 -0
  312. package/dist/generated/abi/QueryEngineImplementation.d.ts +1000 -0
  313. package/dist/generated/abi/QueryEngineImplementation.js +1295 -0
  314. package/dist/generated/abi/QueryEngineImplementation.js.map +1 -0
  315. package/dist/generated/abi/SwapHelperImplementation.cjs +1019 -0
  316. package/dist/generated/abi/SwapHelperImplementation.cjs.map +1 -0
  317. package/dist/generated/abi/SwapHelperImplementation.d.ts +763 -0
  318. package/dist/generated/abi/SwapHelperImplementation.js +995 -0
  319. package/dist/generated/abi/SwapHelperImplementation.js.map +1 -0
  320. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.cjs +936 -0
  321. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.cjs.map +1 -0
  322. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.d.ts +700 -0
  323. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.js +912 -0
  324. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.js.map +1 -0
  325. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.cjs +936 -0
  326. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.cjs.map +1 -0
  327. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.d.ts +700 -0
  328. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.js +912 -0
  329. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.js.map +1 -0
  330. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.cjs +936 -0
  331. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.cjs.map +1 -0
  332. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.d.ts +700 -0
  333. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.js +912 -0
  334. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.js.map +1 -0
  335. package/dist/generated/abi/TeePoolImplementation.cjs +1313 -0
  336. package/dist/generated/abi/TeePoolImplementation.cjs.map +1 -0
  337. package/dist/generated/abi/TeePoolImplementation.d.ts +992 -0
  338. package/dist/generated/abi/TeePoolImplementation.js +1289 -0
  339. package/dist/generated/abi/TeePoolImplementation.js.map +1 -0
  340. package/dist/generated/abi/TeePoolPersistentGpuImplementation.cjs +936 -0
  341. package/dist/generated/abi/TeePoolPersistentGpuImplementation.cjs.map +1 -0
  342. package/dist/generated/abi/TeePoolPersistentGpuImplementation.d.ts +700 -0
  343. package/dist/generated/abi/TeePoolPersistentGpuImplementation.js +912 -0
  344. package/dist/generated/abi/TeePoolPersistentGpuImplementation.js.map +1 -0
  345. package/dist/generated/abi/TeePoolPersistentStandardImplementation.cjs +936 -0
  346. package/dist/generated/abi/TeePoolPersistentStandardImplementation.cjs.map +1 -0
  347. package/dist/generated/abi/TeePoolPersistentStandardImplementation.d.ts +700 -0
  348. package/dist/generated/abi/TeePoolPersistentStandardImplementation.js +912 -0
  349. package/dist/generated/abi/TeePoolPersistentStandardImplementation.js.map +1 -0
  350. package/dist/generated/abi/TeePoolPhalaImplementation.cjs +1313 -0
  351. package/dist/generated/abi/TeePoolPhalaImplementation.cjs.map +1 -0
  352. package/dist/generated/abi/TeePoolPhalaImplementation.d.ts +992 -0
  353. package/dist/generated/abi/TeePoolPhalaImplementation.js +1289 -0
  354. package/dist/generated/abi/TeePoolPhalaImplementation.js.map +1 -0
  355. package/dist/generated/abi/VanaEpochImplementation.cjs +1188 -0
  356. package/dist/generated/abi/VanaEpochImplementation.cjs.map +1 -0
  357. package/dist/generated/abi/VanaEpochImplementation.d.ts +899 -0
  358. package/dist/generated/abi/VanaEpochImplementation.js +1164 -0
  359. package/dist/generated/abi/VanaEpochImplementation.js.map +1 -0
  360. package/dist/generated/abi/VanaPoolEntityImplementation.cjs +1234 -0
  361. package/dist/generated/abi/VanaPoolEntityImplementation.cjs.map +1 -0
  362. package/dist/generated/abi/VanaPoolEntityImplementation.d.ts +933 -0
  363. package/dist/generated/abi/VanaPoolEntityImplementation.js +1210 -0
  364. package/dist/generated/abi/VanaPoolEntityImplementation.js.map +1 -0
  365. package/dist/generated/abi/VanaPoolStakingImplementation.cjs +921 -0
  366. package/dist/generated/abi/VanaPoolStakingImplementation.cjs.map +1 -0
  367. package/dist/generated/abi/VanaPoolStakingImplementation.d.ts +692 -0
  368. package/dist/generated/abi/VanaPoolStakingImplementation.js +897 -0
  369. package/dist/generated/abi/VanaPoolStakingImplementation.js.map +1 -0
  370. package/dist/generated/abi/VanaPoolTreasuryImplementation.cjs +538 -0
  371. package/dist/generated/abi/VanaPoolTreasuryImplementation.cjs.map +1 -0
  372. package/dist/generated/abi/VanaPoolTreasuryImplementation.d.ts +393 -0
  373. package/dist/generated/abi/VanaPoolTreasuryImplementation.js +514 -0
  374. package/dist/generated/abi/VanaPoolTreasuryImplementation.js.map +1 -0
  375. package/dist/generated/abi/index.cjs +177 -0
  376. package/dist/generated/abi/index.cjs.map +1 -0
  377. package/dist/{index.node.d.cts → generated/abi/index.d.ts} +26664 -34464
  378. package/dist/generated/abi/index.js +120 -0
  379. package/dist/generated/abi/index.js.map +1 -0
  380. package/dist/generated/event-types.cjs +17 -0
  381. package/dist/generated/event-types.cjs.map +1 -0
  382. package/dist/generated/event-types.d.ts +854 -0
  383. package/dist/generated/event-types.js +1 -0
  384. package/dist/generated/event-types.js.map +1 -0
  385. package/dist/generated/eventRegistry.cjs +3351 -0
  386. package/dist/generated/eventRegistry.cjs.map +1 -0
  387. package/dist/generated/eventRegistry.d.ts +14 -0
  388. package/dist/generated/eventRegistry.js +3326 -0
  389. package/dist/generated/eventRegistry.js.map +1 -0
  390. package/dist/generated/server/server-exports.cjs +23 -0
  391. package/dist/generated/server/server-exports.cjs.map +1 -0
  392. package/dist/generated/server/server-exports.d.ts +19 -0
  393. package/dist/generated/server/server-exports.js +2 -0
  394. package/dist/generated/server/server-exports.js.map +1 -0
  395. package/dist/generated/server/server.cjs +17 -0
  396. package/dist/generated/server/server.cjs.map +1 -0
  397. package/dist/generated/server/server.d.ts +538 -0
  398. package/dist/generated/server/server.js +1 -0
  399. package/dist/generated/server/server.js.map +1 -0
  400. package/dist/generated/subgraph.cjs +1440 -0
  401. package/dist/generated/subgraph.cjs.map +1 -0
  402. package/dist/generated/subgraph.d.ts +6113 -0
  403. package/dist/generated/subgraph.js +1404 -0
  404. package/dist/generated/subgraph.js.map +1 -0
  405. package/dist/index.browser.d.ts +47 -34228
  406. package/dist/index.browser.js +78 -41645
  407. package/dist/index.browser.js.map +1 -1
  408. package/dist/index.cjs +5 -0
  409. package/dist/index.cjs.map +1 -0
  410. package/dist/index.d.ts +0 -0
  411. package/dist/index.js +4 -0
  412. package/dist/index.js.map +1 -0
  413. package/dist/index.node.cjs +116 -42122
  414. package/dist/index.node.cjs.map +1 -1
  415. package/dist/index.node.d.ts +91 -34336
  416. package/dist/index.node.js +95 -42010
  417. package/dist/index.node.js.map +1 -1
  418. package/dist/lib/__tests__/redisAtomicStore.test.d.ts +1 -0
  419. package/dist/lib/redisAtomicStore.cjs +201 -0
  420. package/dist/lib/redisAtomicStore.cjs.map +1 -0
  421. package/dist/lib/redisAtomicStore.d.ts +120 -0
  422. package/dist/lib/redisAtomicStore.js +177 -0
  423. package/dist/lib/redisAtomicStore.js.map +1 -0
  424. package/dist/node.cjs +29 -0
  425. package/dist/node.cjs.map +1 -0
  426. package/dist/node.d.ts +42 -0
  427. package/dist/node.js +5 -0
  428. package/dist/node.js.map +1 -0
  429. package/dist/platform/browser-only.cjs +37 -0
  430. package/dist/platform/browser-only.cjs.map +1 -0
  431. package/dist/platform/browser-only.d.ts +22 -0
  432. package/dist/platform/browser-only.js +12 -0
  433. package/dist/platform/browser-only.js.map +1 -0
  434. package/dist/platform/browser-only.test.d.ts +1 -0
  435. package/dist/platform/browser-safe.cjs +57 -0
  436. package/dist/platform/browser-safe.cjs.map +1 -0
  437. package/dist/platform/browser-safe.d.ts +29 -0
  438. package/dist/platform/browser-safe.js +31 -0
  439. package/dist/platform/browser-safe.js.map +1 -0
  440. package/dist/platform/browser-safe.test.d.ts +1 -0
  441. package/dist/platform/browser.cjs +488 -0
  442. package/dist/platform/browser.cjs.map +1 -0
  443. package/dist/platform/browser.d.ts +291 -0
  444. package/dist/platform/browser.js +454 -0
  445. package/dist/platform/browser.js.map +1 -0
  446. package/dist/platform/browser.test.d.ts +1 -0
  447. package/dist/platform/index.cjs +50 -0
  448. package/dist/platform/index.cjs.map +1 -0
  449. package/dist/platform/index.d.ts +11 -0
  450. package/dist/platform/index.js +27 -0
  451. package/dist/platform/index.js.map +1 -0
  452. package/dist/platform/interface.cjs +17 -0
  453. package/dist/platform/interface.cjs.map +1 -0
  454. package/dist/platform/interface.d.ts +409 -0
  455. package/dist/platform/interface.js +1 -0
  456. package/dist/platform/interface.js.map +1 -0
  457. package/dist/platform/node.cjs +512 -0
  458. package/dist/platform/node.cjs.map +1 -0
  459. package/dist/platform/node.d.ts +86 -0
  460. package/dist/platform/node.js +481 -0
  461. package/dist/platform/node.js.map +1 -0
  462. package/dist/platform/ports/openpgp-port.cjs +74 -0
  463. package/dist/platform/ports/openpgp-port.cjs.map +1 -0
  464. package/dist/platform/ports/openpgp-port.d.ts +13 -0
  465. package/dist/platform/ports/openpgp-port.js +59 -0
  466. package/dist/platform/ports/openpgp-port.js.map +1 -0
  467. package/dist/platform/ports/pgp-port.cjs +17 -0
  468. package/dist/platform/ports/pgp-port.cjs.map +1 -0
  469. package/dist/platform/ports/pgp-port.d.ts +35 -0
  470. package/dist/platform/ports/pgp-port.js +1 -0
  471. package/dist/platform/ports/pgp-port.js.map +1 -0
  472. package/dist/platform/shared/error-utils.cjs +43 -0
  473. package/dist/platform/shared/error-utils.cjs.map +1 -0
  474. package/dist/platform/shared/error-utils.d.ts +23 -0
  475. package/dist/platform/shared/error-utils.js +18 -0
  476. package/dist/platform/shared/error-utils.js.map +1 -0
  477. package/dist/platform/shared/pgp-utils.cjs +55 -0
  478. package/dist/platform/shared/pgp-utils.cjs.map +1 -0
  479. package/dist/platform/shared/pgp-utils.d.ts +59 -0
  480. package/dist/platform/shared/pgp-utils.js +29 -0
  481. package/dist/platform/shared/pgp-utils.js.map +1 -0
  482. package/dist/platform/shared/stream-utils.cjs +49 -0
  483. package/dist/platform/shared/stream-utils.cjs.map +1 -0
  484. package/dist/platform/shared/stream-utils.d.ts +14 -0
  485. package/dist/platform/shared/stream-utils.js +25 -0
  486. package/dist/platform/shared/stream-utils.js.map +1 -0
  487. package/dist/platform/utils.cjs +114 -0
  488. package/dist/platform/utils.cjs.map +1 -0
  489. package/dist/platform/utils.d.ts +49 -0
  490. package/dist/platform/utils.js +76 -0
  491. package/dist/platform/utils.js.map +1 -0
  492. package/dist/platform/utils.test.d.ts +1 -0
  493. package/dist/platform.browser.d.ts +6 -290
  494. package/dist/platform.browser.js +10 -356
  495. package/dist/platform.browser.js.map +1 -1
  496. package/dist/platform.cjs +14 -698
  497. package/dist/platform.cjs.map +1 -1
  498. package/dist/platform.d.ts +11 -1
  499. package/dist/platform.js +14 -684
  500. package/dist/platform.js.map +1 -1
  501. package/dist/platform.node.cjs +14 -698
  502. package/dist/platform.node.cjs.map +1 -1
  503. package/dist/platform.node.d.ts +7 -331
  504. package/dist/platform.node.js +14 -684
  505. package/dist/platform.node.js.map +1 -1
  506. package/dist/schemas/dataSchema.schema.json +53 -0
  507. package/dist/schemas/grantFile.schema.json +43 -0
  508. package/dist/server/relayerHandler.cjs +420 -0
  509. package/dist/server/relayerHandler.cjs.map +1 -0
  510. package/dist/server/relayerHandler.d.ts +69 -0
  511. package/dist/server/relayerHandler.js +396 -0
  512. package/dist/server/relayerHandler.js.map +1 -0
  513. package/dist/storage/index.cjs +44 -0
  514. package/dist/storage/index.cjs.map +1 -0
  515. package/dist/storage/index.d.ts +56 -0
  516. package/dist/storage/index.js +15 -0
  517. package/dist/storage/index.js.map +1 -0
  518. package/dist/storage/manager.cjs +272 -0
  519. package/dist/storage/manager.cjs.map +1 -0
  520. package/dist/storage/manager.d.ts +241 -0
  521. package/dist/storage/manager.js +248 -0
  522. package/dist/storage/manager.js.map +1 -0
  523. package/dist/storage/providers/callback-storage.cjs +248 -0
  524. package/dist/storage/providers/callback-storage.cjs.map +1 -0
  525. package/dist/storage/providers/callback-storage.d.ts +183 -0
  526. package/dist/storage/providers/callback-storage.js +226 -0
  527. package/dist/storage/providers/callback-storage.js.map +1 -0
  528. package/dist/storage/providers/google-drive.cjs +516 -0
  529. package/dist/storage/providers/google-drive.cjs.map +1 -0
  530. package/dist/storage/providers/google-drive.d.ts +152 -0
  531. package/dist/storage/providers/google-drive.js +494 -0
  532. package/dist/storage/providers/google-drive.js.map +1 -0
  533. package/dist/storage/providers/google-drive.test.d.ts +1 -0
  534. package/dist/storage/providers/ipfs.cjs +283 -0
  535. package/dist/storage/providers/ipfs.cjs.map +1 -0
  536. package/dist/storage/providers/ipfs.d.ts +160 -0
  537. package/dist/storage/providers/ipfs.js +261 -0
  538. package/dist/storage/providers/ipfs.js.map +1 -0
  539. package/dist/storage/providers/pinata.cjs +339 -0
  540. package/dist/storage/providers/pinata.cjs.map +1 -0
  541. package/dist/storage/providers/pinata.d.ts +168 -0
  542. package/dist/storage/providers/pinata.js +317 -0
  543. package/dist/storage/providers/pinata.js.map +1 -0
  544. package/dist/storage/tests/callbackStorage.test.d.ts +1 -0
  545. package/dist/storage/tests/googleDriveStorage.test.d.ts +1 -0
  546. package/dist/storage/tests/ipfsStorage.test.d.ts +1 -0
  547. package/dist/storage/tests/pinataStorage.test.d.ts +1 -0
  548. package/dist/storage/tests/storageManager.test.d.ts +1 -0
  549. package/dist/tests/abi.test.d.ts +1 -0
  550. package/dist/tests/chains-definitions.test.d.ts +1 -0
  551. package/dist/tests/core-encryption.test.d.ts +1 -0
  552. package/dist/tests/core-extended.test.d.ts +1 -0
  553. package/dist/tests/core-generics-coverage.test.d.ts +1 -0
  554. package/dist/tests/coverage-boost.test.d.ts +1 -0
  555. package/dist/tests/crypto-cross-platform-compatibility.test.d.ts +1 -0
  556. package/dist/tests/data-addfile-permissions-schema.test.d.ts +1 -0
  557. package/dist/tests/data-additional-methods.test.d.ts +1 -0
  558. package/dist/tests/data-controller-edge-cases.test.d.ts +1 -0
  559. package/dist/tests/data-ipfs-gateways.test.d.ts +1 -0
  560. package/dist/tests/data-relayer.test.d.ts +1 -0
  561. package/dist/tests/data-schema-validation.test.d.ts +1 -0
  562. package/dist/tests/data-simple-methods.test.d.ts +1 -0
  563. package/dist/tests/data.test.d.ts +1 -0
  564. package/dist/tests/demo-integration.test.d.ts +1 -0
  565. package/dist/tests/demo-trusted-server-integration.test.d.ts +1 -0
  566. package/dist/tests/download-relayer.test.d.ts +1 -0
  567. package/dist/tests/dual-mode-permissions.test.d.ts +1 -0
  568. package/dist/tests/dual-mode-trusted-servers.test.d.ts +1 -0
  569. package/dist/tests/encryption-correct-implementation.test.d.ts +1 -0
  570. package/dist/tests/encryption-coverage.test.d.ts +1 -0
  571. package/dist/tests/encryption-edge-cases.test.d.ts +1 -0
  572. package/dist/tests/encryption-utils-updated.test.d.ts +1 -0
  573. package/dist/tests/errors-coverage.test.d.ts +1 -0
  574. package/dist/tests/errors.test.d.ts +1 -0
  575. package/dist/tests/factories/mockFactory.d.ts +316 -0
  576. package/dist/tests/fakes/FakeStorageManager.d.ts +200 -0
  577. package/dist/tests/fakes/FakeStorageManager.test.d.ts +1 -0
  578. package/dist/tests/fakes/FakeWaitForTransactionEvents.d.ts +170 -0
  579. package/dist/tests/fakes/FakeWaitForTransactionEvents.test.d.ts +1 -0
  580. package/dist/tests/fakes/fake-pgp-port.d.ts +13 -0
  581. package/dist/tests/grantValidation-edge-cases.test.d.ts +1 -0
  582. package/dist/tests/grantValidation-unreachable-branch.test.d.ts +1 -0
  583. package/dist/tests/helper-methods.test.d.ts +1 -0
  584. package/dist/tests/helpers/platformTestHelpers.d.ts +106 -0
  585. package/dist/tests/helpers/typedMocks.d.ts +64 -0
  586. package/dist/tests/index-browser.test.d.ts +1 -0
  587. package/dist/tests/index-node.test.d.ts +1 -0
  588. package/dist/tests/index.test.d.ts +1 -0
  589. package/dist/tests/mocks/platformAdapter.d.ts +12 -0
  590. package/dist/tests/new-permissions-methods.test.d.ts +1 -0
  591. package/dist/tests/no-buffer-browser.test.d.ts +1 -0
  592. package/dist/tests/permissions-grantee.test.d.ts +1 -0
  593. package/dist/tests/permissions-revoke-relayer.test.d.ts +1 -0
  594. package/dist/tests/permissions-schema-validation.test.d.ts +1 -0
  595. package/dist/tests/permissions-server-files.test.d.ts +1 -0
  596. package/dist/tests/permissions-transaction-options.test.d.ts +1 -0
  597. package/dist/tests/permissions-trust-servers.test.d.ts +1 -0
  598. package/dist/tests/permissions.test.d.ts +1 -0
  599. package/dist/tests/personal.test.d.ts +1 -0
  600. package/dist/tests/platform-browser.test.d.ts +1 -0
  601. package/dist/tests/platform-crypto-expanded.test.d.ts +1 -0
  602. package/dist/tests/platform-crypto.test.d.ts +1 -0
  603. package/dist/tests/platform-index.test.d.ts +1 -0
  604. package/dist/tests/platform-node.test.d.ts +1 -0
  605. package/dist/tests/platform-shared-utils.test.d.ts +1 -0
  606. package/dist/tests/platform-updated.test.d.ts +1 -0
  607. package/dist/tests/protocol-additional-methods.test.d.ts +1 -0
  608. package/dist/tests/protocol.test.d.ts +1 -0
  609. package/dist/tests/read-only-mode.test.d.ts +1 -0
  610. package/dist/tests/relayer-integration.test.d.ts +1 -0
  611. package/dist/tests/relayer-unified.test.d.ts +1 -0
  612. package/dist/tests/schemas.test.d.ts +1 -0
  613. package/dist/tests/server-relayer-handler.test.d.ts +1 -0
  614. package/dist/tests/setup.d.ts +7 -0
  615. package/dist/tests/signatureFormatter.test.d.ts +1 -0
  616. package/dist/tests/trusted-server-queries.test.d.ts +1 -0
  617. package/dist/tests/typedDataConverter.test.d.ts +1 -0
  618. package/dist/tests/types-contracts.test.d.ts +1 -0
  619. package/dist/tests/types-data.test.d.ts +1 -0
  620. package/dist/tests/types-external-apis.test.d.ts +1 -0
  621. package/dist/tests/types-generics.test.d.ts +1 -0
  622. package/dist/tests/types-permissions.test.d.ts +1 -0
  623. package/dist/tests/types-upload-params.test.d.ts +1 -0
  624. package/dist/tests/types.test.d.ts +1 -0
  625. package/dist/tests/utils-formatters.test.d.ts +1 -0
  626. package/dist/tests/utils-grantFiles-edge-cases.test.d.ts +1 -0
  627. package/dist/tests/utils-grantFiles-validation.test.d.ts +1 -0
  628. package/dist/tests/utils-grantFiles.test.d.ts +1 -0
  629. package/dist/tests/utils-grantValidation-consolidated.test.d.ts +1 -0
  630. package/dist/tests/utils-grants.test.d.ts +1 -0
  631. package/dist/tests/utils-ipfs-additional.test.d.ts +1 -0
  632. package/dist/tests/utils-ipfs.test.d.ts +4 -0
  633. package/dist/tests/utils-schemaValidation.test.d.ts +1 -0
  634. package/dist/tests/vana.test.d.ts +1 -0
  635. package/dist/tests/wallet-crypto-compatibility.test.d.ts +1 -0
  636. package/dist/types/atomicStore.cjs +31 -0
  637. package/dist/types/atomicStore.cjs.map +1 -0
  638. package/dist/types/atomicStore.d.ts +236 -0
  639. package/dist/types/atomicStore.js +7 -0
  640. package/dist/types/atomicStore.js.map +1 -0
  641. package/dist/types/blockchain.cjs +17 -0
  642. package/dist/types/blockchain.cjs.map +1 -0
  643. package/dist/types/blockchain.d.ts +85 -0
  644. package/dist/types/blockchain.js +1 -0
  645. package/dist/types/blockchain.js.map +1 -0
  646. package/dist/types/chains-additional.test.d.ts +1 -0
  647. package/dist/types/chains.cjs +36 -0
  648. package/dist/types/chains.cjs.map +1 -0
  649. package/dist/types/chains.d.ts +98 -0
  650. package/dist/types/chains.js +11 -0
  651. package/dist/types/chains.js.map +1 -0
  652. package/dist/types/config.cjs +51 -0
  653. package/dist/types/config.cjs.map +1 -0
  654. package/dist/types/config.d.ts +720 -0
  655. package/dist/types/config.js +23 -0
  656. package/dist/types/config.js.map +1 -0
  657. package/dist/types/contracts.cjs +17 -0
  658. package/dist/types/contracts.cjs.map +1 -0
  659. package/dist/types/contracts.d.ts +129 -0
  660. package/dist/types/contracts.js +1 -0
  661. package/dist/types/contracts.js.map +1 -0
  662. package/dist/types/controller-context.cjs +17 -0
  663. package/dist/types/controller-context.cjs.map +1 -0
  664. package/dist/types/controller-context.d.ts +68 -0
  665. package/dist/types/controller-context.js +1 -0
  666. package/dist/types/controller-context.js.map +1 -0
  667. package/dist/types/data.cjs +17 -0
  668. package/dist/types/data.cjs.map +1 -0
  669. package/dist/types/data.d.ts +763 -0
  670. package/dist/types/data.js +1 -0
  671. package/dist/types/data.js.map +1 -0
  672. package/dist/types/eccrypto-js.d.cjs +2 -0
  673. package/dist/types/eccrypto-js.d.cjs.map +1 -0
  674. package/dist/types/eccrypto-js.d.js +1 -0
  675. package/dist/types/eccrypto-js.d.js.map +1 -0
  676. package/dist/types/external-apis.cjs +61 -0
  677. package/dist/types/external-apis.cjs.map +1 -0
  678. package/dist/types/external-apis.d.ts +184 -0
  679. package/dist/types/external-apis.js +34 -0
  680. package/dist/types/external-apis.js.map +1 -0
  681. package/dist/types/generics.cjs +17 -0
  682. package/dist/types/generics.cjs.map +1 -0
  683. package/dist/types/generics.d.ts +518 -0
  684. package/dist/types/generics.js +1 -0
  685. package/dist/types/generics.js.map +1 -0
  686. package/dist/types/index.cjs +65 -0
  687. package/dist/types/index.cjs.map +1 -0
  688. package/dist/types/index.d.ts +48 -0
  689. package/dist/types/index.js +42 -0
  690. package/dist/types/index.js.map +1 -0
  691. package/dist/types/operationStore.cjs +17 -0
  692. package/dist/types/operationStore.cjs.map +1 -0
  693. package/dist/types/operationStore.d.ts +171 -0
  694. package/dist/types/operationStore.js +1 -0
  695. package/dist/types/operationStore.js.map +1 -0
  696. package/dist/types/operations.cjs +65 -0
  697. package/dist/types/operations.cjs.map +1 -0
  698. package/dist/types/operations.d.ts +230 -0
  699. package/dist/types/operations.js +37 -0
  700. package/dist/types/operations.js.map +1 -0
  701. package/dist/types/options.cjs +17 -0
  702. package/dist/types/options.cjs.map +1 -0
  703. package/dist/types/options.d.ts +308 -0
  704. package/dist/types/options.js +1 -0
  705. package/dist/types/options.js.map +1 -0
  706. package/dist/types/permissions.cjs +17 -0
  707. package/dist/types/permissions.cjs.map +1 -0
  708. package/dist/types/permissions.d.ts +951 -0
  709. package/dist/types/permissions.js +1 -0
  710. package/dist/types/permissions.js.map +1 -0
  711. package/dist/types/personal.cjs +17 -0
  712. package/dist/types/personal.cjs.map +1 -0
  713. package/dist/types/personal.d.ts +155 -0
  714. package/dist/types/personal.js +1 -0
  715. package/dist/types/personal.js.map +1 -0
  716. package/dist/types/relayer.cjs +17 -0
  717. package/dist/types/relayer.cjs.map +1 -0
  718. package/dist/types/relayer.d.ts +527 -0
  719. package/dist/types/relayer.js +1 -0
  720. package/dist/types/relayer.js.map +1 -0
  721. package/dist/types/storage.cjs +39 -0
  722. package/dist/types/storage.cjs.map +1 -0
  723. package/dist/types/storage.d.ts +117 -0
  724. package/dist/types/storage.js +15 -0
  725. package/dist/types/storage.js.map +1 -0
  726. package/dist/types/transactionResults.cjs +17 -0
  727. package/dist/types/transactionResults.cjs.map +1 -0
  728. package/dist/types/transactionResults.d.ts +193 -0
  729. package/dist/types/transactionResults.js +1 -0
  730. package/dist/types/transactionResults.js.map +1 -0
  731. package/dist/types/utils.cjs +17 -0
  732. package/dist/types/utils.cjs.map +1 -0
  733. package/dist/types/utils.d.ts +771 -0
  734. package/dist/types/utils.js +1 -0
  735. package/dist/types/utils.js.map +1 -0
  736. package/dist/types.cjs +23 -0
  737. package/dist/types.cjs.map +1 -0
  738. package/dist/types.d.ts +30 -0
  739. package/dist/types.js +2 -0
  740. package/dist/types.js.map +1 -0
  741. package/dist/utils/__tests__/parseTransaction.test.d.ts +1 -0
  742. package/dist/utils/__tests__/pojo-serialization.test.d.ts +1 -0
  743. package/dist/utils/__tests__/signatureCache.test.d.ts +1 -0
  744. package/dist/utils/__tests__/subgraphConsistency.test.d.ts +4 -0
  745. package/dist/utils/__tests__/subgraphPagination.test.d.ts +4 -0
  746. package/dist/utils/__tests__/transaction-edge-cases.test.d.ts +1 -0
  747. package/dist/utils/__tests__/transactionHelpers.test.d.ts +1 -0
  748. package/dist/utils/__tests__/urlResolver.test.d.ts +4 -0
  749. package/dist/utils/blockchain/registry.cjs +81 -0
  750. package/dist/utils/blockchain/registry.cjs.map +1 -0
  751. package/dist/utils/blockchain/registry.d.ts +32 -0
  752. package/dist/utils/blockchain/registry.js +56 -0
  753. package/dist/utils/blockchain/registry.js.map +1 -0
  754. package/dist/utils/blockchain/registry.test.d.ts +1 -0
  755. package/dist/utils/chainQuery.cjs +107 -0
  756. package/dist/utils/chainQuery.cjs.map +1 -0
  757. package/dist/utils/chainQuery.d.ts +31 -0
  758. package/dist/utils/chainQuery.js +82 -0
  759. package/dist/utils/chainQuery.js.map +1 -0
  760. package/dist/utils/crypto-utils.cjs +108 -0
  761. package/dist/utils/crypto-utils.cjs.map +1 -0
  762. package/dist/utils/crypto-utils.d.ts +100 -0
  763. package/dist/utils/crypto-utils.js +76 -0
  764. package/dist/utils/crypto-utils.js.map +1 -0
  765. package/dist/utils/crypto-utils.test.d.ts +1 -0
  766. package/dist/utils/download.cjs +69 -0
  767. package/dist/utils/download.cjs.map +1 -0
  768. package/dist/utils/download.d.ts +40 -0
  769. package/dist/utils/download.js +45 -0
  770. package/dist/utils/download.js.map +1 -0
  771. package/dist/utils/encoding.cjs +66 -0
  772. package/dist/utils/encoding.cjs.map +1 -0
  773. package/dist/utils/encoding.d.ts +52 -0
  774. package/dist/utils/encoding.js +39 -0
  775. package/dist/utils/encoding.js.map +1 -0
  776. package/dist/utils/encoding.test.d.ts +1 -0
  777. package/dist/utils/encryption.cjs +176 -0
  778. package/dist/utils/encryption.cjs.map +1 -0
  779. package/dist/utils/encryption.d.ts +271 -0
  780. package/dist/utils/encryption.js +142 -0
  781. package/dist/utils/encryption.js.map +1 -0
  782. package/dist/utils/formatters.cjs +55 -0
  783. package/dist/utils/formatters.cjs.map +1 -0
  784. package/dist/utils/formatters.d.ts +118 -0
  785. package/dist/utils/formatters.js +28 -0
  786. package/dist/utils/formatters.js.map +1 -0
  787. package/dist/utils/grantFiles.cjs +178 -0
  788. package/dist/utils/grantFiles.cjs.map +1 -0
  789. package/dist/utils/grantFiles.d.ts +172 -0
  790. package/dist/utils/grantFiles.js +140 -0
  791. package/dist/utils/grantFiles.js.map +1 -0
  792. package/dist/utils/grantValidation.cjs +243 -0
  793. package/dist/utils/grantValidation.cjs.map +1 -0
  794. package/dist/utils/grantValidation.d.ts +226 -0
  795. package/dist/utils/grantValidation.js +201 -0
  796. package/dist/utils/grantValidation.js.map +1 -0
  797. package/dist/utils/grants.cjs +108 -0
  798. package/dist/utils/grants.cjs.map +1 -0
  799. package/dist/utils/grants.d.ts +148 -0
  800. package/dist/utils/grants.js +82 -0
  801. package/dist/utils/grants.js.map +1 -0
  802. package/dist/utils/ipfs.cjs +128 -0
  803. package/dist/utils/ipfs.cjs.map +1 -0
  804. package/dist/utils/ipfs.d.ts +88 -0
  805. package/dist/utils/ipfs.js +97 -0
  806. package/dist/utils/ipfs.js.map +1 -0
  807. package/dist/utils/lazy-import.cjs +38 -0
  808. package/dist/utils/lazy-import.cjs.map +1 -0
  809. package/dist/utils/lazy-import.d.ts +43 -0
  810. package/dist/utils/lazy-import.js +14 -0
  811. package/dist/utils/lazy-import.js.map +1 -0
  812. package/dist/utils/multicall.cjs +233 -0
  813. package/dist/utils/multicall.cjs.map +1 -0
  814. package/dist/utils/multicall.d.ts +126 -0
  815. package/dist/utils/multicall.js +208 -0
  816. package/dist/utils/multicall.js.map +1 -0
  817. package/dist/utils/parseTransactionPojo.cjs +87 -0
  818. package/dist/utils/parseTransactionPojo.cjs.map +1 -0
  819. package/dist/utils/parseTransactionPojo.d.ts +31 -0
  820. package/dist/utils/parseTransactionPojo.js +63 -0
  821. package/dist/utils/parseTransactionPojo.js.map +1 -0
  822. package/dist/utils/schemaValidation.cjs +258 -0
  823. package/dist/utils/schemaValidation.cjs.map +1 -0
  824. package/dist/utils/schemaValidation.d.ts +168 -0
  825. package/dist/utils/schemaValidation.js +219 -0
  826. package/dist/utils/schemaValidation.js.map +1 -0
  827. package/dist/utils/signatureCache.cjs +192 -0
  828. package/dist/utils/signatureCache.cjs.map +1 -0
  829. package/dist/utils/signatureCache.d.ts +172 -0
  830. package/dist/utils/signatureCache.js +167 -0
  831. package/dist/utils/signatureCache.js.map +1 -0
  832. package/dist/utils/signatureFormatter.cjs +42 -0
  833. package/dist/utils/signatureFormatter.cjs.map +1 -0
  834. package/dist/utils/signatureFormatter.d.ts +36 -0
  835. package/dist/utils/signatureFormatter.js +18 -0
  836. package/dist/utils/signatureFormatter.js.map +1 -0
  837. package/dist/utils/subgraphConsistency.cjs +184 -0
  838. package/dist/utils/subgraphConsistency.cjs.map +1 -0
  839. package/dist/utils/subgraphConsistency.d.ts +65 -0
  840. package/dist/utils/subgraphConsistency.js +155 -0
  841. package/dist/utils/subgraphConsistency.js.map +1 -0
  842. package/dist/utils/subgraphMetaCache.cjs +101 -0
  843. package/dist/utils/subgraphMetaCache.cjs.map +1 -0
  844. package/dist/utils/subgraphMetaCache.d.ts +56 -0
  845. package/dist/utils/subgraphMetaCache.js +76 -0
  846. package/dist/utils/subgraphMetaCache.js.map +1 -0
  847. package/dist/utils/subgraphPagination.cjs +104 -0
  848. package/dist/utils/subgraphPagination.cjs.map +1 -0
  849. package/dist/utils/subgraphPagination.d.ts +78 -0
  850. package/dist/utils/subgraphPagination.js +78 -0
  851. package/dist/utils/subgraphPagination.js.map +1 -0
  852. package/dist/utils/tests/multicall.test.d.ts +1 -0
  853. package/dist/utils/transactionHelpers.cjs +54 -0
  854. package/dist/utils/transactionHelpers.cjs.map +1 -0
  855. package/dist/utils/transactionHelpers.d.ts +80 -0
  856. package/dist/utils/transactionHelpers.js +29 -0
  857. package/dist/utils/transactionHelpers.js.map +1 -0
  858. package/dist/utils/typeGuards.cjs +109 -0
  859. package/dist/utils/typeGuards.cjs.map +1 -0
  860. package/dist/utils/typeGuards.d.ts +138 -0
  861. package/dist/utils/typeGuards.js +74 -0
  862. package/dist/utils/typeGuards.js.map +1 -0
  863. package/dist/utils/typedDataConverter.cjs +43 -0
  864. package/dist/utils/typedDataConverter.cjs.map +1 -0
  865. package/dist/utils/typedDataConverter.d.ts +46 -0
  866. package/dist/utils/typedDataConverter.js +19 -0
  867. package/dist/utils/typedDataConverter.js.map +1 -0
  868. package/dist/utils/urlResolver.cjs +62 -0
  869. package/dist/utils/urlResolver.cjs.map +1 -0
  870. package/dist/utils/urlResolver.d.ts +56 -0
  871. package/dist/utils/urlResolver.js +37 -0
  872. package/dist/utils/urlResolver.js.map +1 -0
  873. package/dist/utils/wallet.cjs +63 -0
  874. package/dist/utils/wallet.cjs.map +1 -0
  875. package/dist/utils/wallet.d.ts +94 -0
  876. package/dist/utils/wallet.js +37 -0
  877. package/dist/utils/wallet.js.map +1 -0
  878. package/dist/utils/withEvents.cjs +44 -0
  879. package/dist/utils/withEvents.cjs.map +1 -0
  880. package/dist/utils/withEvents.d.ts +56 -0
  881. package/dist/utils/withEvents.js +18 -0
  882. package/dist/utils/withEvents.js.map +1 -0
  883. package/package.json +76 -37
  884. package/dist/chains.browser.cjs.map +0 -1
  885. package/dist/chains.d.cts +0 -2
  886. package/dist/chains.node.d.cts +0 -2
  887. package/dist/index.d.cts +0 -2
  888. package/dist/platform.d.cts +0 -1
  889. package/dist/platform.node.d.cts +0 -334
@@ -0,0 +1,1060 @@
1
+ import type { Address } from "viem";
2
+ import type { TransactionOptions, TransactionResult } from "../types/operations";
3
+ import type { StorageUploadResult } from "../types/storage";
4
+ import type { UserFile, UploadParams, UploadResult, UploadEncryptedFileResult, Refiner, AddRefinerParams, AddRefinerResult, UpdateSchemaIdParams, UpdateSchemaIdResult, TrustedServer, GetUserTrustedServersParams, EncryptedUploadParams, UnencryptedUploadParams, EncryptFileOptions, EncryptFileResult, DecryptFileOptions, UploadFileWithPermissionsParams, AddFilePermissionParams, DecryptFileWithPermissionOptions } from "../types/index";
5
+ import type { ControllerContext } from "./permissions";
6
+ import { BaseController } from "./base";
7
+ import type { ConsistencyOptions, PaginationOptions } from "../types/options";
8
+ import { type DataSchema } from "../utils/schemaValidation";
9
+ /**
10
+ * Manages encrypted user data files and blockchain registration on the Vana network.
11
+ *
12
+ * @remarks
13
+ * The DataController provides comprehensive file lifecycle management from encrypted upload
14
+ * through blockchain registration to decryption. Client-side encryption ensures data privacy
15
+ * before transmission. The controller integrates with multiple storage providers (IPFS, Pinata,
16
+ * Google Drive) and supports both gasless transactions via relayers and direct blockchain interaction.
17
+ *
18
+ * **Architecture:**
19
+ * Files use dual storage: encrypted content on decentralized storage (IPFS/Pinata/Google Drive),
20
+ * metadata and permissions on blockchain. This design minimizes on-chain data while maintaining
21
+ * decentralization and access control.
22
+ *
23
+ * **Method Selection:**
24
+ * - `upload()` - Complete workflow: encryption, storage, blockchain registration
25
+ * - `getUserFiles()` - Query file metadata from blockchain/subgraph
26
+ * - `decryptFile()` - Decrypt files you have permission to access
27
+ * - `getFileById()` - Retrieve specific file metadata by ID
28
+ *
29
+ * **Storage Requirements:**
30
+ * - Methods requiring storage: `upload()`, `encryptFile()`
31
+ * - Methods working without storage: `getUserFiles()`, `decryptFile()`, `getFileById()`
32
+ *
33
+ * **Permission Model:**
34
+ * - File permissions (decryption access) are handled during upload
35
+ * - Operation permissions (what can be done with data) use `vana.permissions.grant()`
36
+ *
37
+ * @example
38
+ * ```typescript
39
+ * // Upload encrypted file with schema validation
40
+ * const result = await vana.data.upload({
41
+ * content: { name: "Alice", age: 30 },
42
+ * filename: "profile.json",
43
+ * schemaId: 1
44
+ * });
45
+ * console.log(`File uploaded: ID ${result.fileId}, URL ${result.url}`);
46
+ *
47
+ * // Query user's files
48
+ * const files = await vana.data.getUserFiles({
49
+ * owner: "0x742d35Cc6558Fd4D9e9E0E888F0462ef6919Bd36"
50
+ * });
51
+ * files.forEach(file => console.log(`File ${file.id}: ${file.url}`));
52
+ *
53
+ * // Decrypt accessible file
54
+ * const decryptedData = await vana.data.decryptFile(files[0]);
55
+ * console.log("Decrypted content:", decryptedData);
56
+ * ```
57
+ *
58
+ * @category Data Management
59
+ * @see For conceptual overview, visit {@link https://docs.vana.org/docs/data-registry}
60
+ */
61
+ export declare class DataController extends BaseController {
62
+ constructor(context: ControllerContext);
63
+ /**
64
+ * Uploads data with automatic encryption and blockchain registration.
65
+ *
66
+ * @remarks
67
+ * Primary method for uploading data to Vana. Handles complete workflow:
68
+ * content normalization, schema validation, encryption, storage upload,
69
+ * permission granting, and blockchain registration.
70
+ *
71
+ * **Automatic Processing:**
72
+ * - Normalizes content to Blob format
73
+ * - Validates against schema if provided
74
+ * - Generates encryption keys
75
+ * - Uploads to configured storage
76
+ * - Grants decryption permissions
77
+ * - Registers on blockchain
78
+ *
79
+ * **TypeScript Overloads:**
80
+ * - `EncryptedUploadParams`: When `encrypt: true` (default), permissions require `publicKey`
81
+ * - `UnencryptedUploadParams`: When `encrypt: false`, permissions optional
82
+ * - `UploadParams`: General signature for runtime determination
83
+ *
84
+ * **Permission Separation:**
85
+ * - File permissions (here): Decryption access only
86
+ * - Operation permissions: Use `vana.permissions.grant()` separately
87
+ *
88
+ * @param params - Upload configuration object
89
+ * @param params.content - Data to upload (string, object, or Blob)
90
+ * @param params.filename - Name for the uploaded file
91
+ * @param params.permissions - Decryption access grants.
92
+ * Each requires `account` and `publicKey` for encryption.
93
+ * @param params.schemaId - Schema for validation.
94
+ * Obtain via `vana.schemas.list()`.
95
+ * @param params.owner - Owner address for delegation scenarios.
96
+ * Defaults to connected wallet address.
97
+ * @param params.encrypt - Enable encryption (default: `true`)
98
+ * @param params.providerName - Storage provider override
99
+ *
100
+ * @returns Upload result with file ID, URL, and transaction hash
101
+ *
102
+ * @throws {Error} Storage not configured.
103
+ * Configure storage providers in `VanaConfig`.
104
+ * @throws {Error} No wallet addresses available.
105
+ * Ensure wallet is connected.
106
+ * @throws {SchemaValidationError} Data doesn't match schema.
107
+ * Verify data structure matches schema from `vana.schemas.get(schemaId)`.
108
+ * @throws {Error} Upload failed with specific error message.
109
+ *
110
+ * @example
111
+ * ```typescript
112
+ * // Basic file upload
113
+ * const result = await vana.data.upload({
114
+ * content: "My personal data",
115
+ * filename: "diary.txt"
116
+ * });
117
+ *
118
+ * // Upload with schema validation
119
+ * const result = await vana.data.upload({
120
+ * content: { name: "John", age: 30 },
121
+ * filename: "profile.json",
122
+ * schemaId: 1
123
+ * });
124
+ *
125
+ * // Upload with file permissions (for decryption access)
126
+ * const result = await vana.data.upload({
127
+ * content: "Data for AI analysis",
128
+ * filename: "analysis.txt",
129
+ * permissions: [{
130
+ * account: "0x1234...", // Server address that can decrypt
131
+ * publicKey: "0x04..." // Server's public key for encryption
132
+ * }]
133
+ * });
134
+ *
135
+ * // After upload, grant operation permissions separately:
136
+ * // await vana.permissions.grant({
137
+ * // grantee: "0x1234...",
138
+ * // fileIds: [result.fileId],
139
+ * // operation: "llm_inference",
140
+ * // parameters: { model: "gpt-4" }
141
+ * // });
142
+ *
143
+ * // Upload without encryption (public data)
144
+ * // Note: Cast to UnencryptedUploadParams for TypeScript
145
+ * const result = await vana.data.upload({
146
+ * content: "Public data",
147
+ * filename: "public.txt",
148
+ * encrypt: false
149
+ * } as const); // 'as const' ensures TypeScript infers encrypt: false literally
150
+ *
151
+ * // Upload on behalf of another user (delegation)
152
+ * const result = await vana.data.upload({
153
+ * content: "User's data",
154
+ * filename: "delegated.txt",
155
+ * owner: "0x5678...", // Different from connected wallet
156
+ * permissions: [{
157
+ * account: "0x1234...", // Address that can decrypt
158
+ * publicKey: "0x04..." // Their public key for encryption
159
+ * }]
160
+ * });
161
+ * ```
162
+ */
163
+ upload(params: EncryptedUploadParams): Promise<UploadResult>;
164
+ upload(params: UnencryptedUploadParams): Promise<UploadResult>;
165
+ upload(params: UploadParams): Promise<UploadResult>;
166
+ /**
167
+ * Encrypts data using wallet-derived encryption.
168
+ *
169
+ * @remarks
170
+ * This method provides secure, wallet-based encryption for data before uploading
171
+ * to the Vana network. It's the counterpart to decryptFile for preparing data
172
+ * for secure storage.
173
+ *
174
+ * The method automatically:
175
+ * - Generates an encryption key from the user's wallet signature
176
+ * - Converts the input data to a Blob if necessary
177
+ * - Encrypts the data using the generated key
178
+ * - Returns both the encrypted data and the encryption key
179
+ *
180
+ * The encryption key returned can be stored and later used for decryption,
181
+ * or shared with others to grant them decryption access.
182
+ *
183
+ * @param data - The data to encrypt (Blob, string, or object)
184
+ * @param options - Optional encryption configuration
185
+ * @returns Promise resolving to encrypted data and the encryption key used
186
+ * @throws {Error} When wallet is not connected or encryption fails
187
+ * @example
188
+ * ```typescript
189
+ * // Encrypt a string
190
+ * const { encryptedData, encryptionKey } = await vana.data.encryptFile(
191
+ * "My secret data"
192
+ * );
193
+ *
194
+ * // Encrypt JSON with custom MIME type
195
+ * const { encryptedData, encryptionKey } = await vana.data.encryptFile(
196
+ * { name: "Alice", age: 30 },
197
+ * { mimeType: "application/json" }
198
+ * );
199
+ *
200
+ * // With custom encryption seed
201
+ * const { encryptedData, encryptionKey } = await vana.data.encryptFile(
202
+ * "Secret message",
203
+ * { seed: "My custom encryption seed" }
204
+ * );
205
+ *
206
+ * // Upload the encrypted data
207
+ * const result = await vana.data.uploadToStorage(encryptedData);
208
+ * ```
209
+ */
210
+ encryptFile(data: Blob | string | object, options?: EncryptFileOptions): Promise<EncryptFileResult>;
211
+ /**
212
+ * Decrypts a file using wallet-derived decryption key.
213
+ *
214
+ * @remarks
215
+ * Counterpart to `upload()` for decrypting user files. Automatically
216
+ * generates decryption key from wallet, fetches encrypted content,
217
+ * and decrypts. Supports IPFS (with gateway fallback) and HTTP URLs.
218
+ *
219
+ * @param file - UserFile object from `getUserFiles()`
220
+ * @param options - Decryption options
221
+ * @param options.seed - Custom encryption seed.
222
+ * Defaults to standard Vana seed.
223
+ *
224
+ * @returns Decrypted content as Blob
225
+ *
226
+ * @throws {Error} No wallet connected.
227
+ * Connect wallet before decrypting.
228
+ * @throws {Error} Network error accessing file.
229
+ * Check CORS settings or server availability.
230
+ * @throws {Error} File not found (404).
231
+ * File no longer available at stored URL.
232
+ * @throws {Error} Access denied (403).
233
+ * No permission to access file.
234
+ * @throws {Error} Invalid file format.
235
+ * File not encrypted with Vana protocol.
236
+ * @throws {Error} Wrong encryption key.
237
+ * Verify seed matches upload or use default.
238
+ *
239
+ * @example
240
+ * ```typescript
241
+ * // Basic file decryption
242
+ * const files = await vana.data.getUserFiles({ owner: userAddress });
243
+ * const decryptedBlob = await vana.data.decryptFile(files[0]);
244
+ *
245
+ * // Convert to text
246
+ * const text = await decryptedBlob.text();
247
+ * console.log('Decrypted content:', text);
248
+ *
249
+ * // Convert to JSON
250
+ * const json = JSON.parse(await decryptedBlob.text());
251
+ * console.log('Decrypted data:', json);
252
+ *
253
+ * // With custom encryption seed
254
+ * const decryptedBlob = await vana.data.decryptFile(
255
+ * files[0],
256
+ * "My custom encryption seed"
257
+ * );
258
+ *
259
+ * // Save to file (in Node.js)
260
+ * const buffer = await decryptedBlob.arrayBuffer();
261
+ * fs.writeFileSync('decrypted-file.txt', Buffer.from(buffer));
262
+ * ```
263
+ */
264
+ decryptFile(file: UserFile, options?: DecryptFileOptions): Promise<Blob>;
265
+ /**
266
+ * Retrieves all files owned by a specific user address.
267
+ *
268
+ * @remarks
269
+ * Queries the Vana subgraph for files owned by the specified address.
270
+ * Automatically deduplicates by file ID, keeping the latest version
271
+ * when duplicates exist from re-indexing or chain reorganizations.
272
+ * Enriches results with DLP proof data when available.
273
+ *
274
+ * @param params - Query configuration
275
+ * @param params.owner - Wallet address of the file owner
276
+ * @param params.subgraphUrl - Subgraph endpoint override.
277
+ * Defaults to context configuration.
278
+ *
279
+ * @returns Array of UserFile objects sorted by timestamp (newest first)
280
+ *
281
+ * @throws {Error} Subgraph URL not configured.
282
+ * Provide `subgraphUrl` parameter or configure in Vana constructor.
283
+ * @throws {Error} Subgraph request failed.
284
+ * Check network connectivity and subgraph availability.
285
+ * @throws {Error} Subgraph returned errors.
286
+ * Review query parameters and subgraph logs.
287
+ *
288
+ * @example
289
+ * ```typescript
290
+ * const files = await vana.data.getUserFiles({
291
+ * owner: "0x742d35Cc6558Fd4D9e9E0E888F0462ef6919Bd36"
292
+ * });
293
+ *
294
+ * files.forEach(file => {
295
+ * console.log(`File ${file.id}: ${file.url}`);
296
+ * console.log(` Schema: ${file.schemaId}`);
297
+ * console.log(` DLPs: ${file.dlpIds?.join(", ") || "none"}`);
298
+ * });
299
+ * ```
300
+ */
301
+ getUserFiles(params: {
302
+ owner: Address;
303
+ subgraphUrl?: string;
304
+ }, options?: ConsistencyOptions & PaginationOptions): Promise<UserFile[]>;
305
+ /**
306
+ * Fetches proof data for multiple files from the subgraph.
307
+ *
308
+ * @private
309
+ * @param fileIds - Array of file IDs to fetch proofs for
310
+ * @param subgraphUrl - The subgraph endpoint URL
311
+ * @returns Map of file IDs to their associated DLP IDs
312
+ */
313
+ private _fetchProofsFromSubgraph;
314
+ /**
315
+ * Fetches proof data for multiple files from the blockchain.
316
+ * Falls back to this when subgraph is unavailable.
317
+ *
318
+ * @private
319
+ * @param fileIds - Array of file IDs to fetch proofs for
320
+ * @returns Map of file IDs to their associated DLP IDs
321
+ */
322
+ private _fetchProofsFromChain;
323
+ /**
324
+ * Retrieves information about a specific Data Liquidity Pool (DLP).
325
+ *
326
+ * @remarks
327
+ * DLPs are entities that process and verify data files in the Vana network.
328
+ * This method fetches DLP metadata including name, status, and performance rating.
329
+ * Uses subgraph first for efficiency, falls back to chain if unavailable.
330
+ *
331
+ * @param dlpId - The unique identifier of the DLP
332
+ * @param options - Optional parameters
333
+ * @param options.subgraphUrl - Custom subgraph URL to override default
334
+ * @returns Promise resolving to DLP information
335
+ * @throws {Error} When DLP cannot be found - "DLP not found: {dlpId}"
336
+ * @throws {Error} When query fails - "Failed to fetch DLP: {error}"
337
+ * @example
338
+ * ```typescript
339
+ * const dlp = await vana.data.getDLP(26);
340
+ * console.log(`DLP ${dlp.name}: ${dlp.status}`);
341
+ * ```
342
+ */
343
+ getDLP(dlpId: number, options?: {
344
+ subgraphUrl?: string;
345
+ minBlock?: number;
346
+ waitForSync?: number;
347
+ }): Promise<{
348
+ id: number;
349
+ name: string;
350
+ metadata?: string;
351
+ status?: number;
352
+ address?: Address;
353
+ owner?: Address;
354
+ }>;
355
+ /**
356
+ * Lists all Data Liquidity Pools (DLPs) with optional pagination.
357
+ *
358
+ * @remarks
359
+ * Fetches a paginated list of all DLPs registered in the network.
360
+ * Uses subgraph for efficient querying with fallback to chain multicall.
361
+ *
362
+ * @param options - Optional parameters for pagination and filtering
363
+ * @param options.limit - Maximum number of DLPs to return (default: 100)
364
+ * @param options.offset - Number of DLPs to skip (default: 0)
365
+ * @param options.subgraphUrl - Custom subgraph URL to override default
366
+ * @returns Promise resolving to array of DLP information
367
+ * @throws {Error} When query fails - "Failed to list DLPs: {error}"
368
+ * @example
369
+ * ```typescript
370
+ * // Get first 10 DLPs
371
+ * const dlps = await vana.data.listDLPs({ limit: 10 });
372
+ * dlps.forEach(dlp => console.log(`${dlp.id}: ${dlp.name}`));
373
+ *
374
+ * // Get next page
375
+ * const nextPage = await vana.data.listDLPs({ limit: 10, offset: 10 });
376
+ * ```
377
+ */
378
+ listDLPs(options?: {
379
+ limit?: number;
380
+ offset?: number;
381
+ subgraphUrl?: string;
382
+ }): Promise<Array<{
383
+ id: number;
384
+ name: string;
385
+ metadata?: string;
386
+ status?: number;
387
+ address?: Address;
388
+ owner?: Address;
389
+ }>>;
390
+ /**
391
+ * Retrieves a list of permissions granted by a user.
392
+ *
393
+ * This method supports automatic fallback between subgraph and RPC modes:
394
+ * - If subgraph URL is available, tries subgraph query first
395
+ * - Falls back to direct contract queries via RPC if subgraph fails
396
+ * - RPC mode uses gasAwareMulticall for efficient batch queries
397
+ *
398
+ * @param params - Object containing the user address and optional subgraph URL
399
+ * @param params.user - The wallet address of the user to query permissions for
400
+ * @param params.subgraphUrl - Optional subgraph URL to override the default
401
+ * @returns Promise resolving to an array of permission objects
402
+ * @throws Error if both subgraph and RPC queries fail
403
+ */
404
+ getUserPermissions(params: {
405
+ user: Address;
406
+ subgraphUrl?: string;
407
+ }, options?: ConsistencyOptions & PaginationOptions): Promise<Array<{
408
+ id: string;
409
+ grant: string;
410
+ nonce: bigint;
411
+ signature: string;
412
+ addedAtBlock: bigint;
413
+ addedAtTimestamp: bigint;
414
+ transactionHash: Address;
415
+ user: Address;
416
+ }>>;
417
+ /**
418
+ * Internal method: Query user permissions via subgraph
419
+ *
420
+ * @param params - Query parameters object
421
+ * @param params.user - The user address to query permissions for
422
+ * @param params.subgraphUrl - The subgraph URL endpoint to query
423
+ * @returns Promise resolving to an array of permission objects
424
+ */
425
+ private _getUserPermissionsViaSubgraph;
426
+ /**
427
+ * Internal method: Query user permissions via direct RPC
428
+ *
429
+ * @param params - Query parameters object
430
+ * @param params.user - The user address to query permissions for
431
+ * @returns Promise resolving to an array of permission objects
432
+ */
433
+ private _getUserPermissionsViaRpc;
434
+ /**
435
+ * Retrieves a list of trusted servers for a user.
436
+ *
437
+ * This method supports automatic fallback between subgraph and RPC modes:
438
+ * - If subgraph URL is available, tries subgraph query first for fast results
439
+ * - Falls back to direct contract queries via RPC if subgraph fails
440
+ * - RPC mode uses gasAwareMulticall for efficient batch queries
441
+ *
442
+ * @param params - Query parameters including user address and optional pagination
443
+ * @param params.user - The wallet address of the user to query trusted servers for
444
+ * @param params.subgraphUrl - Optional subgraph URL to override the default
445
+ * @param params.limit - Maximum number of results to return (default: 50)
446
+ * @param params.offset - Number of results to skip for pagination (default: 0)
447
+ * @returns Promise resolving to an array of trusted server objects
448
+ * @throws Error if both subgraph and RPC queries fail
449
+ * @example
450
+ * ```typescript
451
+ * // Basic usage with automatic fallback
452
+ * const servers = await vana.data.getUserTrustedServers({
453
+ * user: '0x...'
454
+ * });
455
+ *
456
+ * // With pagination
457
+ * const servers = await vana.data.getUserTrustedServers({
458
+ * user: '0x...',
459
+ * limit: 10,
460
+ * offset: 20
461
+ * });
462
+ *
463
+ * // With custom subgraph URL
464
+ * const servers = await vana.data.getUserTrustedServers({
465
+ * user: '0x...',
466
+ * subgraphUrl: 'https://custom-subgraph.com/graphql'
467
+ * });
468
+ * ```
469
+ */
470
+ getUserTrustedServers(params: GetUserTrustedServersParams, options?: ConsistencyOptions & PaginationOptions): Promise<TrustedServer[]>;
471
+ /**
472
+ * Internal method: Query trusted servers via subgraph
473
+ *
474
+ * @param params - Query parameters object
475
+ * @param params.user - The user address to query trusted servers for
476
+ * @param params.subgraphUrl - The subgraph URL endpoint to query
477
+ * @returns Promise resolving to an array of trusted server objects
478
+ */
479
+ private _getUserTrustedServersViaSubgraph;
480
+ /**
481
+ * Internal method: Query trusted servers via direct RPC
482
+ *
483
+ * @param params - Query parameters object
484
+ * @param params.user - The user address to query trusted servers for
485
+ * @param params.limit - Maximum number of results to return
486
+ * @param params.offset - Number of results to skip for pagination
487
+ * @returns Promise resolving to pagination result with servers, total count, and hasMore flag
488
+ */
489
+ private _getUserTrustedServersViaRpc;
490
+ /**
491
+ * Retrieves total file count from Data Registry.
492
+ *
493
+ * @remarks
494
+ * Queries blockchain for complete file count across all users.
495
+ * Useful for pagination and network statistics.
496
+ *
497
+ * @returns Total number of registered files
498
+ *
499
+ * @throws {Error} Chain ID not available.
500
+ * Ensure network connection.
501
+ * @throws {Error} Contract read failed.
502
+ * Check RPC availability.
503
+ *
504
+ * @example
505
+ * ```typescript
506
+ * const total = await vana.data.getTotalFilesCount();
507
+ * console.log(`Total files: ${total}`);
508
+ *
509
+ * // Calculate pagination
510
+ * const pages = Math.ceil(total / 20);
511
+ * ```
512
+ */
513
+ getTotalFilesCount(): Promise<number>;
514
+ /**
515
+ * Retrieves file metadata by ID from the blockchain.
516
+ *
517
+ * @remarks
518
+ * Queries DataRegistry contract directly for file details.
519
+ * Works for any file ID regardless of ownership, enabling
520
+ * cross-user file discovery and verification.
521
+ *
522
+ * @param fileId - Numeric file ID to retrieve
523
+ *
524
+ * @returns UserFile object with metadata
525
+ *
526
+ * @throws {Error} Chain ID not available.
527
+ * Ensure proper network connection.
528
+ * @throws {Error} File not found.
529
+ * Verify file ID exists on-chain.
530
+ * @throws {Error} Contract call failed.
531
+ * Check network and RPC availability.
532
+ *
533
+ * @example
534
+ * ```typescript
535
+ * const file = await vana.data.getFileById(123);
536
+ * console.log(`File ${file.id}:`);
537
+ * console.log(` URL: ${file.url}`);
538
+ * console.log(` Owner: ${file.ownerAddress}`);
539
+ * console.log(` Block: ${file.addedAtBlock}`);
540
+ * ```
541
+ */
542
+ getFileById(fileId: number): Promise<UserFile>;
543
+ /**
544
+ * Registers a file URL directly on the blockchain with a schema ID.
545
+ *
546
+ * @remarks
547
+ * This method registers an existing file URL on the DataRegistry contract
548
+ * with a schema ID, without uploading any data. Useful when you have already
549
+ * uploaded content to storage and just need to register it on-chain.
550
+ *
551
+ * @param url - The URL of the file to register (IPFS or HTTP/HTTPS)
552
+ * @param schemaId - The schema ID to associate with the file
553
+ * @returns Promise resolving to the file ID and transaction hash
554
+ * @throws {Error} When chain ID is not available - "Chain ID not available"
555
+ * @throws {Error} When wallet address is unavailable - "No addresses available"
556
+ * @throws {Error} When transaction fails - "Failed to register file with schema"
557
+ * @example
558
+ * ```typescript
559
+ * const { fileId, transactionHash } = await vana.data.registerFileWithSchema(
560
+ * "ipfs://QmXxx...",
561
+ * 1
562
+ * );
563
+ * console.log(`File ${fileId} registered with schema in tx ${transactionHash}`);
564
+ * ```
565
+ */
566
+ registerFileWithSchema(url: string, schemaId: number, options?: TransactionOptions): Promise<TransactionResult<"DataRegistry", "addFileWithSchema">>;
567
+ /**
568
+ * Gets the user's address from the wallet client.
569
+ *
570
+ * @returns Promise resolving to the user's wallet address
571
+ * @throws {Error} When no addresses are available in wallet client
572
+ */
573
+ /**
574
+ * Adds a file with permissions to the DataRegistry contract.
575
+ *
576
+ * @param url - The file URL to register
577
+ * @param ownerAddress - The address of the file owner
578
+ * @param permissions - Array of permissions to set for the file
579
+ * @returns Promise resolving to file ID and transaction hash
580
+ * @throws {Error} When chain ID is not available
581
+ * @throws {ContractError} When contract execution fails
582
+ * @throws {Error} When transaction receipt is not available
583
+ * @throws {Error} When FileAdded event cannot be parsed
584
+ *
585
+ * This method handles the core logic of registering a file
586
+ * with specific permissions on the DataRegistry contract. It can be used
587
+ * by both direct transactions and relayer services.
588
+ */
589
+ addFileWithPermissions(url: string, ownerAddress: Address, permissions?: Array<{
590
+ account: Address;
591
+ key: string;
592
+ }>, options?: TransactionOptions): Promise<TransactionResult<"DataRegistry", "addFileWithPermissions">>;
593
+ /**
594
+ * Adds a file to the registry with permissions and schema.
595
+ * This combines the functionality of addFileWithPermissions and schema validation.
596
+ *
597
+ * @remarks
598
+ * This method automatically encrypts permissions when a publicKey is provided.
599
+ * It generates the user's encryption key and encrypts it with each recipient's
600
+ * public key before registering on the blockchain.
601
+ *
602
+ * @param url - The URL of the file to register
603
+ * @param ownerAddress - The address of the file owner
604
+ * @param permissions - Array of permissions to grant, each with account and publicKey properties
605
+ * @param schemaId - The schema ID to associate with the file (0 for no schema)
606
+ * @returns Promise resolving to TransactionResult with fileId and transactionHash
607
+ * @throws {Error} "Chain ID not available" - When wallet chain is not configured
608
+ * @throws {Error} "Failed to generate encryption key" - When encryption key generation fails
609
+ * @throws {Error} "Permission for {account} must include 'publicKey'" - When publicKey is missing
610
+ * @throws {Error} "Failed to add file with permissions and schema: {error}" - When transaction fails
611
+ * @example
612
+ * ```typescript
613
+ * // Get server's public key
614
+ * const serverIdentity = await vana.server.getIdentity({
615
+ * userAddress: "0x..."
616
+ * });
617
+ *
618
+ * // Add file with permissions and schema
619
+ * const result = await vana.data.addFileWithPermissionsAndSchema(
620
+ * "ipfs://QmXxx...",
621
+ * ownerAddress,
622
+ * [{
623
+ * account: serverIdentity.address,
624
+ * publicKey: serverIdentity.publicKey
625
+ * }],
626
+ * schemaId
627
+ * );
628
+ *
629
+ * console.log(`File ${result.fileId} registered in tx ${result.hash}`);
630
+ * ```
631
+ */
632
+ addFileWithPermissionsAndSchema(url: string, ownerAddress: Address, permissions?: Array<{
633
+ account: Address;
634
+ publicKey: string;
635
+ }>, schemaId?: number, options?: TransactionOptions): Promise<TransactionResult<"DataRegistry", "addFileWithPermissionsAndSchema">>;
636
+ /**
637
+ * Adds a file with pre-encrypted permissions and schema to the DataRegistry.
638
+ *
639
+ * @remarks
640
+ * This method is designed for relay services and advanced use cases where permissions
641
+ * have already been encrypted client-side. Unlike `addFileWithPermissionsAndSchema()`,
642
+ * this method expects permissions in the encrypted format with a 'key' field instead
643
+ * of 'publicKey'.
644
+ *
645
+ * This is typically used by relay endpoints that receive pre-encrypted data from
646
+ * the client SDK's `upload()` method, avoiding double encryption.
647
+ *
648
+ * @param url - The storage URL of the file (e.g., IPFS URL)
649
+ * @param ownerAddress - The address that will own this file
650
+ * @param permissions - Array of pre-encrypted permissions with 'account' and 'key' fields
651
+ * @param schemaId - Optional schema ID for data validation (defaults to 0)
652
+ * @returns Promise resolving to transaction result with hash and contract details
653
+ * @throws {Error} When chain ID is not available
654
+ * @throws {Error} When wallet is not connected
655
+ * @throws {Error} When transaction fails
656
+ * @example
657
+ * ```typescript
658
+ * // In a relay endpoint that receives pre-encrypted permissions
659
+ * const result = await vana.data.addFileWithEncryptedPermissionsAndSchema(
660
+ * "ipfs://QmXxx...",
661
+ * ownerAddress,
662
+ * [
663
+ * {
664
+ * account: "0xServerAddress...",
665
+ * key: "encrypted_key_string" // Already encrypted by client
666
+ * }
667
+ * ],
668
+ * schemaId
669
+ * );
670
+ *
671
+ * console.log(`File registered in tx ${result.hash}`);
672
+ * ```
673
+ */
674
+ addFileWithEncryptedPermissionsAndSchema(url: string, ownerAddress: Address, permissions?: Array<{
675
+ account: Address;
676
+ key: string;
677
+ }>, schemaId?: number, options?: TransactionOptions): Promise<TransactionResult<"DataRegistry", "addFileWithPermissionsAndSchema">>;
678
+ /**
679
+ * Registers a data refiner for processing templates.
680
+ *
681
+ * @remarks
682
+ * Refiners define data transformation rules for DLPs.
683
+ * Associates schema, instructions, and processing logic.
684
+ *
685
+ * @param params - Refiner configuration
686
+ * @param params.dlpId - Data Liquidity Pool ID
687
+ * @param params.name - Refiner display name
688
+ * @param params.schemaId - Output schema ID.
689
+ * Obtain via `vana.schemas.list()`.
690
+ * @param params.refinementInstructionUrl - Processing instructions URL
691
+ *
692
+ * @returns Refiner ID and transaction hash
693
+ *
694
+ * @throws {Error} Chain ID not available.
695
+ * Ensure network connection.
696
+ * @throws {Error} Transaction failed.
697
+ * Check wallet balance and network status.
698
+ *
699
+ * @example
700
+ * ```typescript
701
+ * const result = await vana.data.addRefiner({
702
+ * dlpId: 1,
703
+ * name: "Sentiment Analyzer",
704
+ * schemaId: 42,
705
+ * refinementInstructionUrl: "ipfs://QmXxx..."
706
+ * });
707
+ * console.log(`Refiner ${result.refinerId} created`);
708
+ * ```
709
+ */
710
+ addRefiner(params: AddRefinerParams, options?: TransactionOptions): Promise<AddRefinerResult>;
711
+ /**
712
+ * Retrieves refiner configuration by ID.
713
+ *
714
+ * @remarks
715
+ * Queries DataRefinerRegistry for refiner details.
716
+ * Returns DLP association, schema, and processing instructions.
717
+ *
718
+ * @param refinerId - Numeric refiner ID
719
+ *
720
+ * @returns Refiner configuration object
721
+ *
722
+ * @throws {Error} Chain ID not available.
723
+ * Ensure network connection.
724
+ * @throws {Error} Refiner not found.
725
+ * Verify refiner ID exists.
726
+ * @throws {Error} Contract read failed.
727
+ * Check network and RPC status.
728
+ *
729
+ * @example
730
+ * ```typescript
731
+ * const refiner = await vana.data.getRefiner(1);
732
+ * console.log(`Refiner: ${refiner.name}`);
733
+ * console.log(`DLP: ${refiner.dlpId}`);
734
+ * console.log(`Schema: ${refiner.schemaId}`);
735
+ * ```
736
+ */
737
+ getRefiner(refinerId: number): Promise<Refiner>;
738
+ /**
739
+ * Validates schema ID existence.
740
+ *
741
+ * @remarks
742
+ * Verifies schema registration in DataRegistry.
743
+ * Check before using schemas for uploads.
744
+ *
745
+ * @param schemaId - Numeric schema ID to validate
746
+ *
747
+ * @returns True if schema exists, false otherwise
748
+ *
749
+ * @throws {Error} Chain ID not available.
750
+ * Ensure network connection.
751
+ * @throws {Error} Contract read failed.
752
+ * Check RPC availability.
753
+ *
754
+ * @example
755
+ * ```typescript
756
+ * const valid = await vana.data.isValidSchemaId(42);
757
+ * if (valid) {
758
+ * // Safe to use schema 42
759
+ * await vana.data.upload({ schemaId: 42, ... });
760
+ * }
761
+ * ```
762
+ */
763
+ isValidSchemaId(schemaId: number): Promise<boolean>;
764
+ /**
765
+ * Gets the total number of refiners in the registry.
766
+ *
767
+ * @remarks
768
+ * Queries the DataRefinerRegistry contract to get the total count of all
769
+ * registered refiners across all DLPs.
770
+ *
771
+ * @returns Promise resolving to the total refiner count
772
+ * @example
773
+ * ```typescript
774
+ * const count = await vana.data.getRefinersCount();
775
+ * console.log(`Total refiners registered: ${count}`);
776
+ * ```
777
+ */
778
+ getRefinersCount(): Promise<number>;
779
+ /**
780
+ * Updates the schema ID for an existing refiner.
781
+ *
782
+ * @remarks
783
+ * Allows the owner of a refiner to update its associated schema ID.
784
+ * This is useful when refiner output format needs to change.
785
+ *
786
+ * @param params - Update parameters
787
+ * @param params.refinerId - The refiner ID to update
788
+ * @param params.newSchemaId - The new schema ID to set
789
+ * @returns Promise resolving to the transaction hash
790
+ * @throws {Error} When chain ID is not available - "Chain ID not available"
791
+ * @throws {Error} When transaction fails - "Failed to update schema ID: {error}"
792
+ * @example
793
+ * ```typescript
794
+ * const result = await vana.data.updateSchemaId({
795
+ * refinerId: 1,
796
+ * newSchemaId: 55
797
+ * });
798
+ * console.log(`Schema updated in tx ${result.transactionHash}`);
799
+ * ```
800
+ */
801
+ updateSchemaId(params: UpdateSchemaIdParams, options?: TransactionOptions): Promise<UpdateSchemaIdResult>;
802
+ /**
803
+ * Uploads an encrypted file and grants permission to a party with a public key.
804
+ *
805
+ * This method handles the complete workflow:
806
+ * 1. Encrypts the file with the user's encryption key
807
+ * 2. Uploads the encrypted file to storage
808
+ * 3. Encrypts the user's encryption key with the provided public key
809
+ * 4. Registers the file with permissions
810
+ *
811
+ * @param params - Upload parameters including data, permissions, and options
812
+ * @returns Promise resolving to upload result with file ID and storage URL
813
+ */
814
+ uploadFileWithPermissions(params: UploadFileWithPermissionsParams): Promise<UploadEncryptedFileResult>;
815
+ /**
816
+ * Uploads content to storage without registering it on the blockchain.
817
+ * This method only handles the storage upload and returns the file URL.
818
+ *
819
+ * @param content - The content to upload (string, Blob, Buffer, or object - objects will be JSON stringified)
820
+ * @param filename - Optional filename for the uploaded file (defaults to timestamp-based name)
821
+ * @param encrypt - Optional flag to encrypt the content before upload
822
+ * @param providerName - Optional specific storage provider to use
823
+ * @returns Promise resolving to the storage upload result with url, size, and contentType
824
+ */
825
+ uploadToStorage(content: string | Blob | Buffer | object, filename?: string, encrypt?: boolean, providerName?: string): Promise<StorageUploadResult>;
826
+ /**
827
+ * Adds a permission for a party to access an existing file.
828
+ *
829
+ * This method handles the complete workflow:
830
+ * 1. Gets the user's encryption key
831
+ * 2. Encrypts the user's encryption key with the provided public key
832
+ * 3. Adds the permission to the file
833
+ * 4. Returns the permission data from the blockchain event
834
+ *
835
+ * For advanced users who need more control over transaction timing,
836
+ * use `submitFilePermission()` instead.
837
+ *
838
+ * @param params - Parameters for adding file permission
839
+ * @param params.fileId - The ID of the file to grant permission for
840
+ * @param params.account - The recipient's wallet address that will access the file
841
+ * @param params.publicKey - The recipient's public key for encryption.
842
+ * Obtain via `vana.server.getIdentity(account).publicKey`
843
+ * @returns Promise resolving to permission data from PermissionGranted event
844
+ * @throws {Error} "No addresses available in wallet client" - When wallet is not connected
845
+ * @throws {Error} "Chain ID not available" - When wallet chain is not configured
846
+ * @throws {Error} "Failed to add permission to file: {error}" - When transaction fails or user doesn't own file
847
+ * @example
848
+ * ```typescript
849
+ * const result = await vana.data.addPermissionToFile({
850
+ * fileId: 123,
851
+ * account: "0xRecipientAddress...",
852
+ * publicKey: "0xRecipientPublicKey..."
853
+ * });
854
+ * console.log(`Permission granted to ${result.account} for file ${result.fileId}`);
855
+ * console.log(`Transaction: ${result.transactionHash}`);
856
+ * ```
857
+ */
858
+ addPermissionToFile(params: AddFilePermissionParams, options?: TransactionOptions): Promise<TransactionResult<"DataRegistry", "addFilePermission">>;
859
+ /**
860
+ * Submits a file permission transaction to the blockchain.
861
+ *
862
+ * @remarks
863
+ * This method supports gasless transactions via relayer callbacks when configured.
864
+ * It encrypts the user's encryption key with the recipient's public key before submission.
865
+ * Use this when you want to handle transaction confirmation and event parsing separately.
866
+ *
867
+ * @param fileId - The ID of the file to grant permission for
868
+ * @param account - The recipient's wallet address that will access the file
869
+ * @param publicKey - The recipient's public key for encryption.
870
+ * Obtain via `vana.server.getIdentity(account).publicKey`
871
+ * @returns Promise resolving to TransactionResult for tracking the transaction
872
+ * @throws {Error} When chain ID is not available
873
+ * @throws {Error} When encryption key generation fails
874
+ * @throws {Error} When public key encryption fails
875
+ *
876
+ * @example
877
+ * ```typescript
878
+ * const tx = await vana.data.submitFilePermission(
879
+ * fileId,
880
+ * "0x742d35Cc6558Fd4D9e9E0E888F0462ef6919Bd36",
881
+ * recipientPublicKey
882
+ * );
883
+ * const result = await tx.waitForEvents();
884
+ * console.log(`Permission granted with ID: ${result.permissionId}`);
885
+ * ```
886
+ */
887
+ submitFilePermission(fileId: number, account: Address, publicKey: string, options?: TransactionOptions): Promise<TransactionResult<"DataRegistry", "addFilePermission">>;
888
+ /**
889
+ * Gets the encrypted key for a specific account's permission to access a file.
890
+ *
891
+ * @param fileId - The ID of the file
892
+ * @param account - The account address to get the permission for
893
+ * @returns Promise resolving to the encrypted key for that account
894
+ */
895
+ getFilePermission(fileId: number, account: Address): Promise<string>;
896
+ /**
897
+ * Decrypts a file that the user has permission to access using their private key.
898
+ *
899
+ * This method handles the complete workflow for servers or other permitted parties:
900
+ * 1. Gets the encrypted encryption key from file permissions
901
+ * 2. Decrypts the encryption key using the provided private key
902
+ * 3. Downloads and decrypts the file data
903
+ *
904
+ * @param file - The file to decrypt
905
+ * @param privateKey - The private key to decrypt the user's encryption key
906
+ * @param options - Optional decryption configuration
907
+ * @param options.account - The account address that has permission (defaults to current wallet account)
908
+ * @returns Promise resolving to the decrypted file data
909
+ */
910
+ decryptFileWithPermission(file: UserFile, privateKey: string, options?: DecryptFileWithPermissionOptions): Promise<Blob>;
911
+ /**
912
+ * Simple network-agnostic fetch utility for retrieving file content.
913
+ *
914
+ * @remarks
915
+ * This is a thin wrapper around the global fetch API that returns the response as a Blob.
916
+ * It provides a consistent interface for fetching encrypted content before decryption.
917
+ * For IPFS URLs, consider using fetchFromIPFS for better reliability.
918
+ *
919
+ * @param url - The URL to fetch content from
920
+ * @returns Promise resolving to the fetched content as a Blob
921
+ * @throws {Error} "HTTP error! status: {status} {statusText}" - When server returns error status
922
+ * @throws {Error} "Empty response" - When server returns no content
923
+ * @throws {Error} "Network error: Failed to fetch from {url}" - When network request fails
924
+ *
925
+ * @example
926
+ * ```typescript
927
+ * // Fetch and decrypt a file
928
+ * const encryptionKey = await generateEncryptionKey(walletClient);
929
+ * const encryptedBlob = await vana.data.fetch(file.url);
930
+ * const decryptedBlob = await decryptBlob(encryptedBlob, encryptionKey, platform);
931
+ *
932
+ * // With custom headers for authentication
933
+ * const response = await fetch(file.url, {
934
+ * headers: { 'Authorization': 'Bearer token' }
935
+ * });
936
+ * const encryptedBlob = await response.blob();
937
+ * ```
938
+ */
939
+ fetch(url: string): Promise<Blob>;
940
+ /**
941
+ * Specialized IPFS fetcher with gateway fallback mechanism.
942
+ *
943
+ * @remarks
944
+ * This method provides robust IPFS content fetching by trying multiple gateways
945
+ * in sequence until one succeeds. It supports both ipfs:// URLs and raw CIDs.
946
+ *
947
+ * The default gateway list includes public gateways, but you should provide
948
+ * your own gateways for production use to ensure reliability and privacy.
949
+ *
950
+ * @param url - The IPFS URL (ipfs://...) or CID to fetch
951
+ * @param options - Optional configuration
952
+ * @param options.gateways - Array of IPFS gateway URLs to try (must end with /)
953
+ * @returns Promise resolving to the fetched content as a Blob
954
+ * @throws {Error} "Invalid IPFS URL format" - When URL is not ipfs:// or valid CID
955
+ * @throws {Error} "Empty response" - When gateway returns no content
956
+ * @throws {Error} "HTTP error! status: {status}" - When gateway returns error status
957
+ * @throws {Error} "Failed to fetch IPFS content {cid} from all gateways" - When all gateways fail
958
+ *
959
+ * @example
960
+ * ```typescript
961
+ * // Fetch from IPFS with custom gateways
962
+ * const encryptedBlob = await vana.data.fetchFromIPFS(file.url, {
963
+ * gateways: [
964
+ * 'https://my-private-gateway.com/ipfs/',
965
+ * 'https://dweb.link/ipfs/',
966
+ * 'https://ipfs.io/ipfs/'
967
+ * ]
968
+ * });
969
+ *
970
+ * // Decrypt the fetched content
971
+ * const encryptionKey = await generateEncryptionKey(walletClient);
972
+ * const decryptedBlob = await decryptBlob(encryptedBlob, encryptionKey, platform);
973
+ *
974
+ * // With raw CID
975
+ * const blob = await vana.data.fetchFromIPFS('QmXxx...', {
976
+ * gateways: ['https://ipfs.io/ipfs/']
977
+ * });
978
+ * ```
979
+ */
980
+ fetchFromIPFS(url: string, options?: {
981
+ gateways?: string[];
982
+ }): Promise<Blob>;
983
+ /**
984
+ * Validates a data schema definition against the Vana meta-schema.
985
+ *
986
+ * @param schema - The data schema definition to validate
987
+ * @returns The validated DataSchema
988
+ * @throws SchemaValidationError if invalid
989
+ * @example
990
+ * ```typescript
991
+ * const schema = {
992
+ * name: "User Profile",
993
+ * version: "1.0.0",
994
+ * dialect: "json",
995
+ * schema: {
996
+ * type: "object",
997
+ * properties: {
998
+ * name: { type: "string" },
999
+ * age: { type: "number" }
1000
+ * }
1001
+ * }
1002
+ * };
1003
+ *
1004
+ * const validatedSchema = vana.data.validateDataSchemaAgainstMetaSchema(schema);
1005
+ * ```
1006
+ */
1007
+ validateDataSchemaAgainstMetaSchema(schema: unknown): DataSchema;
1008
+ /**
1009
+ * Validates data against a JSON Schema from a data schema.
1010
+ *
1011
+ * @param data - The data to validate
1012
+ * @param schema - The data schema containing the schema
1013
+ * @returns Void (throws if validation fails)
1014
+ * @throws SchemaValidationError if invalid
1015
+ * @example
1016
+ * ```typescript
1017
+ * const schema = {
1018
+ * name: "User Profile",
1019
+ * version: "1.0.0",
1020
+ * dialect: "json",
1021
+ * schema: {
1022
+ * type: "object",
1023
+ * properties: {
1024
+ * name: { type: "string" },
1025
+ * age: { type: "number" }
1026
+ * },
1027
+ * required: ["name"]
1028
+ * }
1029
+ * };
1030
+ *
1031
+ * const userData = { name: "Alice", age: 30 };
1032
+ * vana.data.validateDataAgainstSchema(userData, schema);
1033
+ * ```
1034
+ */
1035
+ validateDataAgainstSchema(data: unknown, schema: DataSchema): void;
1036
+ /**
1037
+ * Fetches and validates a data schema from a URL, then returns the parsed data schema.
1038
+ *
1039
+ * @param url - The URL to fetch the data schema from
1040
+ * @returns The validated data schema
1041
+ * @throws SchemaValidationError if invalid or fetch fails
1042
+ * @example
1043
+ * ```typescript
1044
+ * // Fetch and validate a schema from IPFS or HTTP
1045
+ * const schema = await vana.data.fetchAndValidateSchema("https://example.com/schema.json");
1046
+ * console.log(schema.name, schema.dialect);
1047
+ *
1048
+ * // Use the schema to validate user data
1049
+ * if (schema.dialect === "json") {
1050
+ * vana.data.validateDataAgainstSchema(userData, schema);
1051
+ * }
1052
+ * ```
1053
+ */
1054
+ fetchAndValidateSchema(url: string): Promise<DataSchema>;
1055
+ /**
1056
+ * Polls for confirmation of a relayer operation.
1057
+ * @internal
1058
+ */
1059
+ private pollRelayerForConfirmation;
1060
+ }