@opendatalabs/vana-sdk 0.1.0-alpha.7e4db82 → 0.1.0-alpha.7ee7635

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