@opendatalabs/vana-sdk 0.1.0-alpha.f9cc6ed → 0.1.0-alpha.fd33fc9

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