@opendatalabs/vana-sdk 0.1.0-alpha.f05a34e → 0.1.0-alpha.f2de4f7

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 (811) hide show
  1. package/README.md +98 -36
  2. package/dist/__tests__/waitForTransactionEvents.test.d.ts +1 -0
  3. package/dist/browser.cjs +29 -0
  4. package/dist/browser.cjs.map +1 -0
  5. package/dist/browser.d.ts +4 -0
  6. package/dist/browser.js +5 -0
  7. package/dist/browser.js.map +1 -0
  8. package/dist/{chains.browser.cjs → chains/definitions.cjs} +16 -17
  9. package/dist/chains/definitions.cjs.map +1 -0
  10. package/dist/{chains.browser.d.cts → chains/definitions.d.ts} +9 -11
  11. package/dist/chains/definitions.js +67 -0
  12. package/dist/chains/definitions.js.map +1 -0
  13. package/dist/chains/index.cjs +37 -0
  14. package/dist/chains/index.cjs.map +1 -0
  15. package/dist/chains/index.d.ts +5 -0
  16. package/dist/chains/index.js +15 -0
  17. package/dist/chains/index.js.map +1 -0
  18. package/dist/chains.browser.d.ts +5 -50
  19. package/dist/chains.browser.js +7 -57
  20. package/dist/chains.browser.js.map +1 -1
  21. package/dist/chains.cjs +6 -65
  22. package/dist/chains.cjs.map +1 -1
  23. package/dist/chains.d.ts +8 -2
  24. package/dist/chains.js +7 -57
  25. package/dist/chains.js.map +1 -1
  26. package/dist/chains.node.cjs +6 -65
  27. package/dist/chains.node.cjs.map +1 -1
  28. package/dist/chains.node.d.ts +8 -2
  29. package/dist/chains.node.js +7 -57
  30. package/dist/chains.node.js.map +1 -1
  31. package/dist/config/addresses.cjs +325 -0
  32. package/dist/config/addresses.cjs.map +1 -0
  33. package/dist/config/addresses.d.ts +364 -0
  34. package/dist/config/addresses.js +295 -0
  35. package/dist/config/addresses.js.map +1 -0
  36. package/dist/config/chains.cjs +93 -0
  37. package/dist/config/chains.cjs.map +1 -0
  38. package/dist/config/chains.d.ts +81 -0
  39. package/dist/config/chains.js +67 -0
  40. package/dist/config/chains.js.map +1 -0
  41. package/dist/config/default-services.cjs +60 -0
  42. package/dist/config/default-services.cjs.map +1 -0
  43. package/dist/config/default-services.d.ts +46 -0
  44. package/dist/config/default-services.js +33 -0
  45. package/dist/config/default-services.js.map +1 -0
  46. package/dist/config/default-services.test.d.ts +1 -0
  47. package/dist/config/features.cjs +52 -0
  48. package/dist/config/features.cjs.map +1 -0
  49. package/dist/config/features.d.ts +62 -0
  50. package/dist/config/features.js +28 -0
  51. package/dist/config/features.js.map +1 -0
  52. package/dist/config/tests/addresses.test.d.ts +1 -0
  53. package/dist/contracts/contractController.cjs +126 -0
  54. package/dist/contracts/contractController.cjs.map +1 -0
  55. package/dist/contracts/contractController.d.ts +79 -0
  56. package/dist/contracts/contractController.js +100 -0
  57. package/dist/contracts/contractController.js.map +1 -0
  58. package/dist/contracts/tests/contractController.test.d.ts +1 -0
  59. package/dist/controllers/__tests__/schemas-edge-cases.test.d.ts +1 -0
  60. package/dist/controllers/base.cjs +83 -0
  61. package/dist/controllers/base.cjs.map +1 -0
  62. package/dist/controllers/base.d.ts +84 -0
  63. package/dist/controllers/base.js +59 -0
  64. package/dist/controllers/base.js.map +1 -0
  65. package/dist/controllers/data-error-handling.test.d.ts +1 -0
  66. package/dist/controllers/data.cjs +2482 -0
  67. package/dist/controllers/data.cjs.map +1 -0
  68. package/dist/controllers/data.d.ts +1014 -0
  69. package/dist/controllers/data.js +2465 -0
  70. package/dist/controllers/data.js.map +1 -0
  71. package/dist/controllers/permissions.cjs +3977 -0
  72. package/dist/controllers/permissions.cjs.map +1 -0
  73. package/dist/controllers/permissions.d.ts +1348 -0
  74. package/dist/controllers/permissions.js +3953 -0
  75. package/dist/controllers/permissions.js.map +1 -0
  76. package/dist/controllers/protocol.cjs +183 -0
  77. package/dist/controllers/protocol.cjs.map +1 -0
  78. package/dist/controllers/protocol.d.ts +139 -0
  79. package/dist/controllers/protocol.js +163 -0
  80. package/dist/controllers/protocol.js.map +1 -0
  81. package/dist/controllers/schemas.cjs +599 -0
  82. package/dist/controllers/schemas.cjs.map +1 -0
  83. package/dist/controllers/schemas.d.ts +245 -0
  84. package/dist/controllers/schemas.js +575 -0
  85. package/dist/controllers/schemas.js.map +1 -0
  86. package/dist/controllers/server-additional.test.d.ts +1 -0
  87. package/dist/controllers/server.cjs +432 -0
  88. package/dist/controllers/server.cjs.map +1 -0
  89. package/dist/controllers/server.d.ts +217 -0
  90. package/dist/controllers/server.js +413 -0
  91. package/dist/controllers/server.js.map +1 -0
  92. package/dist/core/apiClient.cjs +328 -0
  93. package/dist/core/apiClient.cjs.map +1 -0
  94. package/dist/core/apiClient.d.ts +161 -0
  95. package/dist/core/apiClient.js +309 -0
  96. package/dist/core/apiClient.js.map +1 -0
  97. package/dist/core/client.cjs +70 -0
  98. package/dist/core/client.cjs.map +1 -0
  99. package/dist/core/client.d.ts +89 -0
  100. package/dist/core/client.js +47 -0
  101. package/dist/core/client.js.map +1 -0
  102. package/dist/core/core.test.d.ts +1 -0
  103. package/dist/core/generics.cjs +390 -0
  104. package/dist/core/generics.cjs.map +1 -0
  105. package/dist/core/generics.d.ts +116 -0
  106. package/dist/core/generics.js +359 -0
  107. package/dist/core/generics.js.map +1 -0
  108. package/dist/core/tests/apiClient.test.d.ts +1 -0
  109. package/dist/core/tests/client.test.d.ts +1 -0
  110. package/dist/core/tests/generics.test.d.ts +1 -0
  111. package/dist/core.cjs +706 -0
  112. package/dist/core.cjs.map +1 -0
  113. package/dist/core.d.ts +441 -0
  114. package/dist/core.js +681 -0
  115. package/dist/core.js.map +1 -0
  116. package/dist/crypto/ecies/__tests__/base.test.d.ts +4 -0
  117. package/dist/crypto/ecies/__tests__/compatibility.test.d.ts +8 -0
  118. package/dist/crypto/ecies/__tests__/constants.test.d.ts +4 -0
  119. package/dist/crypto/ecies/__tests__/native-parity.test.d.ts +7 -0
  120. package/dist/crypto/ecies/__tests__/normalization.test.d.ts +1 -0
  121. package/dist/crypto/ecies/__tests__/test-vectors.cjs +102 -0
  122. package/dist/crypto/ecies/__tests__/test-vectors.cjs.map +1 -0
  123. package/dist/crypto/ecies/__tests__/test-vectors.d.ts +38 -0
  124. package/dist/crypto/ecies/__tests__/test-vectors.js +77 -0
  125. package/dist/crypto/ecies/__tests__/test-vectors.js.map +1 -0
  126. package/dist/crypto/ecies/base.cjs +232 -0
  127. package/dist/crypto/ecies/base.cjs.map +1 -0
  128. package/dist/crypto/ecies/base.d.ts +140 -0
  129. package/dist/crypto/ecies/base.js +208 -0
  130. package/dist/crypto/ecies/base.js.map +1 -0
  131. package/dist/crypto/ecies/browser.cjs +165 -0
  132. package/dist/crypto/ecies/browser.cjs.map +1 -0
  133. package/dist/crypto/ecies/browser.d.ts +43 -0
  134. package/dist/crypto/ecies/browser.js +131 -0
  135. package/dist/crypto/ecies/browser.js.map +1 -0
  136. package/dist/crypto/ecies/constants.cjs +131 -0
  137. package/dist/crypto/ecies/constants.cjs.map +1 -0
  138. package/dist/crypto/ecies/constants.d.ts +120 -0
  139. package/dist/crypto/ecies/constants.js +101 -0
  140. package/dist/crypto/ecies/constants.js.map +1 -0
  141. package/dist/crypto/ecies/index.cjs +35 -0
  142. package/dist/crypto/ecies/index.cjs.map +1 -0
  143. package/dist/crypto/ecies/index.d.ts +8 -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 +87 -0
  147. package/dist/crypto/ecies/interface.cjs.map +1 -0
  148. package/dist/crypto/ecies/interface.d.ts +174 -0
  149. package/dist/crypto/ecies/interface.js +60 -0
  150. package/dist/crypto/ecies/interface.js.map +1 -0
  151. package/dist/crypto/ecies/node.cjs +167 -0
  152. package/dist/crypto/ecies/node.cjs.map +1 -0
  153. package/dist/crypto/ecies/node.d.ts +45 -0
  154. package/dist/crypto/ecies/node.js +139 -0
  155. package/dist/crypto/ecies/node.js.map +1 -0
  156. package/dist/crypto/ecies/test-vectors/eccrypto-vectors.json +72 -0
  157. package/dist/crypto/ecies/utils.cjs +52 -0
  158. package/dist/crypto/ecies/utils.cjs.map +1 -0
  159. package/dist/crypto/ecies/utils.d.ts +30 -0
  160. package/dist/crypto/ecies/utils.js +26 -0
  161. package/dist/crypto/ecies/utils.js.map +1 -0
  162. package/dist/crypto/services/WalletKeyEncryptionService.cjs +128 -0
  163. package/dist/crypto/services/WalletKeyEncryptionService.cjs.map +1 -0
  164. package/dist/crypto/services/WalletKeyEncryptionService.d.ts +88 -0
  165. package/dist/crypto/services/WalletKeyEncryptionService.js +108 -0
  166. package/dist/crypto/services/WalletKeyEncryptionService.js.map +1 -0
  167. package/dist/crypto/services/WalletKeyEncryptionService.test.d.ts +1 -0
  168. package/dist/diagnostics.cjs +37 -0
  169. package/dist/diagnostics.cjs.map +1 -0
  170. package/dist/diagnostics.d.ts +24 -0
  171. package/dist/diagnostics.js +13 -0
  172. package/dist/diagnostics.js.map +1 -0
  173. package/dist/diagnostics.test.d.ts +1 -0
  174. package/dist/errors.cjs +157 -0
  175. package/dist/errors.cjs.map +1 -0
  176. package/dist/errors.d.ts +388 -0
  177. package/dist/errors.js +120 -0
  178. package/dist/errors.js.map +1 -0
  179. package/dist/generated/abi/ComputeEngineImplementation.cjs +1313 -0
  180. package/dist/generated/abi/ComputeEngineImplementation.cjs.map +1 -0
  181. package/dist/generated/abi/ComputeEngineImplementation.d.ts +995 -0
  182. package/dist/generated/abi/ComputeEngineImplementation.js +1289 -0
  183. package/dist/generated/abi/ComputeEngineImplementation.js.map +1 -0
  184. package/dist/generated/abi/ComputeInstructionRegistryImplementation.cjs +734 -0
  185. package/dist/generated/abi/ComputeInstructionRegistryImplementation.cjs.map +1 -0
  186. package/dist/generated/abi/ComputeInstructionRegistryImplementation.d.ts +544 -0
  187. package/dist/generated/abi/ComputeInstructionRegistryImplementation.js +710 -0
  188. package/dist/generated/abi/ComputeInstructionRegistryImplementation.js.map +1 -0
  189. package/dist/generated/abi/DATFactoryImplementation.cjs +882 -0
  190. package/dist/generated/abi/DATFactoryImplementation.cjs.map +1 -0
  191. package/dist/generated/abi/DATFactoryImplementation.d.ts +660 -0
  192. package/dist/generated/abi/DATFactoryImplementation.js +858 -0
  193. package/dist/generated/abi/DATFactoryImplementation.js.map +1 -0
  194. package/dist/generated/abi/DATImplementation.cjs +934 -0
  195. package/dist/generated/abi/DATImplementation.cjs.map +1 -0
  196. package/dist/generated/abi/DATImplementation.d.ts +692 -0
  197. package/dist/generated/abi/DATImplementation.js +910 -0
  198. package/dist/generated/abi/DATImplementation.js.map +1 -0
  199. package/dist/generated/abi/DATPausableImplementation.cjs +1523 -0
  200. package/dist/generated/abi/DATPausableImplementation.cjs.map +1 -0
  201. package/dist/generated/abi/DATPausableImplementation.d.ts +1144 -0
  202. package/dist/generated/abi/DATPausableImplementation.js +1499 -0
  203. package/dist/generated/abi/DATPausableImplementation.js.map +1 -0
  204. package/dist/generated/abi/DATVotesImplementation.cjs +1460 -0
  205. package/dist/generated/abi/DATVotesImplementation.cjs.map +1 -0
  206. package/dist/generated/abi/DATVotesImplementation.d.ts +1094 -0
  207. package/dist/generated/abi/DATVotesImplementation.js +1436 -0
  208. package/dist/generated/abi/DATVotesImplementation.js.map +1 -0
  209. package/dist/generated/abi/DLPPerformanceImplementation.cjs +1160 -0
  210. package/dist/generated/abi/DLPPerformanceImplementation.cjs.map +1 -0
  211. package/dist/generated/abi/DLPPerformanceImplementation.d.ts +882 -0
  212. package/dist/generated/abi/DLPPerformanceImplementation.js +1136 -0
  213. package/dist/generated/abi/DLPPerformanceImplementation.js.map +1 -0
  214. package/dist/generated/abi/DLPRegistryImplementation.cjs +1469 -0
  215. package/dist/generated/abi/DLPRegistryImplementation.cjs.map +1 -0
  216. package/dist/generated/abi/DLPRegistryImplementation.d.ts +1122 -0
  217. package/dist/generated/abi/DLPRegistryImplementation.js +1445 -0
  218. package/dist/generated/abi/DLPRegistryImplementation.js.map +1 -0
  219. package/dist/generated/abi/DLPRegistryTreasuryImplementation.cjs +612 -0
  220. package/dist/generated/abi/DLPRegistryTreasuryImplementation.cjs.map +1 -0
  221. package/dist/generated/abi/DLPRegistryTreasuryImplementation.d.ts +451 -0
  222. package/dist/generated/abi/DLPRegistryTreasuryImplementation.js +588 -0
  223. package/dist/generated/abi/DLPRegistryTreasuryImplementation.js.map +1 -0
  224. package/dist/generated/abi/DLPRewardDeployerImplementation.cjs +948 -0
  225. package/dist/generated/abi/DLPRewardDeployerImplementation.cjs.map +1 -0
  226. package/dist/generated/abi/DLPRewardDeployerImplementation.d.ts +713 -0
  227. package/dist/generated/abi/DLPRewardDeployerImplementation.js +924 -0
  228. package/dist/generated/abi/DLPRewardDeployerImplementation.js.map +1 -0
  229. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.cjs +612 -0
  230. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.cjs.map +1 -0
  231. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.d.ts +451 -0
  232. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.js +588 -0
  233. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.js.map +1 -0
  234. package/dist/generated/abi/DLPRewardSwapImplementation.cjs +939 -0
  235. package/dist/generated/abi/DLPRewardSwapImplementation.cjs.map +1 -0
  236. package/dist/generated/abi/DLPRewardSwapImplementation.d.ts +705 -0
  237. package/dist/generated/abi/DLPRewardSwapImplementation.js +915 -0
  238. package/dist/generated/abi/DLPRewardSwapImplementation.js.map +1 -0
  239. package/dist/generated/abi/DLPRootImplementation.cjs +1644 -0
  240. package/dist/generated/abi/DLPRootImplementation.cjs.map +1 -0
  241. package/dist/generated/abi/DLPRootImplementation.d.ts +1246 -0
  242. package/dist/generated/abi/DLPRootImplementation.js +1620 -0
  243. package/dist/generated/abi/DLPRootImplementation.js.map +1 -0
  244. package/dist/generated/abi/DLPTreasuryImplementation.cjs +612 -0
  245. package/dist/generated/abi/DLPTreasuryImplementation.cjs.map +1 -0
  246. package/dist/generated/abi/DLPTreasuryImplementation.d.ts +451 -0
  247. package/dist/generated/abi/DLPTreasuryImplementation.js +588 -0
  248. package/dist/generated/abi/DLPTreasuryImplementation.js.map +1 -0
  249. package/dist/generated/abi/DataLiquidityPoolImplementation.cjs +985 -0
  250. package/dist/generated/abi/DataLiquidityPoolImplementation.cjs.map +1 -0
  251. package/dist/generated/abi/DataLiquidityPoolImplementation.d.ts +735 -0
  252. package/dist/generated/abi/DataLiquidityPoolImplementation.js +961 -0
  253. package/dist/generated/abi/DataLiquidityPoolImplementation.js.map +1 -0
  254. package/dist/generated/abi/DataPortabilityGranteesImplementation.cjs +888 -0
  255. package/dist/generated/abi/DataPortabilityGranteesImplementation.cjs.map +1 -0
  256. package/dist/generated/abi/DataPortabilityGranteesImplementation.d.ts +660 -0
  257. package/dist/generated/abi/DataPortabilityGranteesImplementation.js +864 -0
  258. package/dist/generated/abi/DataPortabilityGranteesImplementation.js.map +1 -0
  259. package/dist/generated/abi/DataPortabilityPermissionsImplementation.cjs +1317 -0
  260. package/dist/generated/abi/DataPortabilityPermissionsImplementation.cjs.map +1 -0
  261. package/dist/generated/abi/DataPortabilityPermissionsImplementation.d.ts +988 -0
  262. package/dist/generated/abi/DataPortabilityPermissionsImplementation.js +1293 -0
  263. package/dist/generated/abi/DataPortabilityPermissionsImplementation.js.map +1 -0
  264. package/dist/generated/abi/DataPortabilityServersImplementation.cjs +1438 -0
  265. package/dist/generated/abi/DataPortabilityServersImplementation.cjs.map +1 -0
  266. package/dist/generated/abi/DataPortabilityServersImplementation.d.ts +1085 -0
  267. package/dist/generated/abi/DataPortabilityServersImplementation.js +1414 -0
  268. package/dist/generated/abi/DataPortabilityServersImplementation.js.map +1 -0
  269. package/dist/generated/abi/DataRefinerRegistryImplementation.cjs +984 -0
  270. package/dist/generated/abi/DataRefinerRegistryImplementation.cjs.map +1 -0
  271. package/dist/generated/abi/DataRefinerRegistryImplementation.d.ts +736 -0
  272. package/dist/generated/abi/DataRefinerRegistryImplementation.js +960 -0
  273. package/dist/generated/abi/DataRefinerRegistryImplementation.js.map +1 -0
  274. package/dist/generated/abi/DataRegistryImplementation.cjs +1341 -0
  275. package/dist/generated/abi/DataRegistryImplementation.cjs.map +1 -0
  276. package/dist/generated/abi/DataRegistryImplementation.d.ts +1013 -0
  277. package/dist/generated/abi/DataRegistryImplementation.js +1317 -0
  278. package/dist/generated/abi/DataRegistryImplementation.js.map +1 -0
  279. package/dist/generated/abi/QueryEngineImplementation.cjs +1319 -0
  280. package/dist/generated/abi/QueryEngineImplementation.cjs.map +1 -0
  281. package/dist/generated/abi/QueryEngineImplementation.d.ts +1000 -0
  282. package/dist/generated/abi/QueryEngineImplementation.js +1295 -0
  283. package/dist/generated/abi/QueryEngineImplementation.js.map +1 -0
  284. package/dist/generated/abi/SwapHelperImplementation.cjs +1019 -0
  285. package/dist/generated/abi/SwapHelperImplementation.cjs.map +1 -0
  286. package/dist/generated/abi/SwapHelperImplementation.d.ts +763 -0
  287. package/dist/generated/abi/SwapHelperImplementation.js +995 -0
  288. package/dist/generated/abi/SwapHelperImplementation.js.map +1 -0
  289. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.cjs +936 -0
  290. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.cjs.map +1 -0
  291. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.d.ts +700 -0
  292. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.js +912 -0
  293. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.js.map +1 -0
  294. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.cjs +936 -0
  295. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.cjs.map +1 -0
  296. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.d.ts +700 -0
  297. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.js +912 -0
  298. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.js.map +1 -0
  299. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.cjs +936 -0
  300. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.cjs.map +1 -0
  301. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.d.ts +700 -0
  302. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.js +912 -0
  303. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.js.map +1 -0
  304. package/dist/generated/abi/TeePoolImplementation.cjs +1313 -0
  305. package/dist/generated/abi/TeePoolImplementation.cjs.map +1 -0
  306. package/dist/generated/abi/TeePoolImplementation.d.ts +992 -0
  307. package/dist/generated/abi/TeePoolImplementation.js +1289 -0
  308. package/dist/generated/abi/TeePoolImplementation.js.map +1 -0
  309. package/dist/generated/abi/TeePoolPersistentGpuImplementation.cjs +936 -0
  310. package/dist/generated/abi/TeePoolPersistentGpuImplementation.cjs.map +1 -0
  311. package/dist/generated/abi/TeePoolPersistentGpuImplementation.d.ts +700 -0
  312. package/dist/generated/abi/TeePoolPersistentGpuImplementation.js +912 -0
  313. package/dist/generated/abi/TeePoolPersistentGpuImplementation.js.map +1 -0
  314. package/dist/generated/abi/TeePoolPersistentStandardImplementation.cjs +936 -0
  315. package/dist/generated/abi/TeePoolPersistentStandardImplementation.cjs.map +1 -0
  316. package/dist/generated/abi/TeePoolPersistentStandardImplementation.d.ts +700 -0
  317. package/dist/generated/abi/TeePoolPersistentStandardImplementation.js +912 -0
  318. package/dist/generated/abi/TeePoolPersistentStandardImplementation.js.map +1 -0
  319. package/dist/generated/abi/TeePoolPhalaImplementation.cjs +1313 -0
  320. package/dist/generated/abi/TeePoolPhalaImplementation.cjs.map +1 -0
  321. package/dist/generated/abi/TeePoolPhalaImplementation.d.ts +992 -0
  322. package/dist/generated/abi/TeePoolPhalaImplementation.js +1289 -0
  323. package/dist/generated/abi/TeePoolPhalaImplementation.js.map +1 -0
  324. package/dist/generated/abi/VanaEpochImplementation.cjs +1188 -0
  325. package/dist/generated/abi/VanaEpochImplementation.cjs.map +1 -0
  326. package/dist/generated/abi/VanaEpochImplementation.d.ts +899 -0
  327. package/dist/generated/abi/VanaEpochImplementation.js +1164 -0
  328. package/dist/generated/abi/VanaEpochImplementation.js.map +1 -0
  329. package/dist/generated/abi/VanaPoolEntityImplementation.cjs +1234 -0
  330. package/dist/generated/abi/VanaPoolEntityImplementation.cjs.map +1 -0
  331. package/dist/generated/abi/VanaPoolEntityImplementation.d.ts +933 -0
  332. package/dist/generated/abi/VanaPoolEntityImplementation.js +1210 -0
  333. package/dist/generated/abi/VanaPoolEntityImplementation.js.map +1 -0
  334. package/dist/generated/abi/VanaPoolStakingImplementation.cjs +921 -0
  335. package/dist/generated/abi/VanaPoolStakingImplementation.cjs.map +1 -0
  336. package/dist/generated/abi/VanaPoolStakingImplementation.d.ts +692 -0
  337. package/dist/generated/abi/VanaPoolStakingImplementation.js +897 -0
  338. package/dist/generated/abi/VanaPoolStakingImplementation.js.map +1 -0
  339. package/dist/generated/abi/VanaPoolTreasuryImplementation.cjs +538 -0
  340. package/dist/generated/abi/VanaPoolTreasuryImplementation.cjs.map +1 -0
  341. package/dist/generated/abi/VanaPoolTreasuryImplementation.d.ts +393 -0
  342. package/dist/generated/abi/VanaPoolTreasuryImplementation.js +514 -0
  343. package/dist/generated/abi/VanaPoolTreasuryImplementation.js.map +1 -0
  344. package/dist/generated/abi/index.cjs +177 -0
  345. package/dist/generated/abi/index.cjs.map +1 -0
  346. package/dist/{index.node.d.cts → generated/abi/index.d.ts} +26541 -32582
  347. package/dist/generated/abi/index.js +120 -0
  348. package/dist/generated/abi/index.js.map +1 -0
  349. package/dist/generated/event-types.cjs +17 -0
  350. package/dist/generated/event-types.cjs.map +1 -0
  351. package/dist/generated/event-types.d.ts +854 -0
  352. package/dist/generated/event-types.js +1 -0
  353. package/dist/generated/event-types.js.map +1 -0
  354. package/dist/generated/eventRegistry.cjs +3351 -0
  355. package/dist/generated/eventRegistry.cjs.map +1 -0
  356. package/dist/generated/eventRegistry.d.ts +14 -0
  357. package/dist/generated/eventRegistry.js +3326 -0
  358. package/dist/generated/eventRegistry.js.map +1 -0
  359. package/dist/generated/server/server-exports.cjs +23 -0
  360. package/dist/generated/server/server-exports.cjs.map +1 -0
  361. package/dist/generated/server/server-exports.d.ts +19 -0
  362. package/dist/generated/server/server-exports.js +2 -0
  363. package/dist/generated/server/server-exports.js.map +1 -0
  364. package/dist/generated/server/server.cjs +17 -0
  365. package/dist/generated/server/server.cjs.map +1 -0
  366. package/dist/generated/server/server.d.ts +538 -0
  367. package/dist/generated/server/server.js +1 -0
  368. package/dist/generated/server/server.js.map +1 -0
  369. package/dist/generated/subgraph.cjs +675 -0
  370. package/dist/generated/subgraph.cjs.map +1 -0
  371. package/dist/generated/subgraph.d.ts +5978 -0
  372. package/dist/generated/subgraph.js +644 -0
  373. package/dist/generated/subgraph.js.map +1 -0
  374. package/dist/index.browser.d.ts +116 -32444
  375. package/dist/index.browser.js +76 -40974
  376. package/dist/index.browser.js.map +1 -1
  377. package/dist/index.cjs +5 -0
  378. package/dist/index.cjs.map +1 -0
  379. package/dist/index.d.ts +0 -0
  380. package/dist/index.js +4 -0
  381. package/dist/index.js.map +1 -0
  382. package/dist/index.node.cjs +96 -41420
  383. package/dist/index.node.cjs.map +1 -1
  384. package/dist/index.node.d.ts +141 -32546
  385. package/dist/index.node.js +78 -41310
  386. package/dist/index.node.js.map +1 -1
  387. package/dist/node.cjs +29 -0
  388. package/dist/node.cjs.map +1 -0
  389. package/dist/node.d.ts +4 -0
  390. package/dist/node.js +5 -0
  391. package/dist/node.js.map +1 -0
  392. package/dist/platform/browser-only.cjs +37 -0
  393. package/dist/platform/browser-only.cjs.map +1 -0
  394. package/dist/platform/browser-only.d.ts +22 -0
  395. package/dist/platform/browser-only.js +12 -0
  396. package/dist/platform/browser-only.js.map +1 -0
  397. package/dist/platform/browser-only.test.d.ts +1 -0
  398. package/dist/platform/browser-safe.cjs +57 -0
  399. package/dist/platform/browser-safe.cjs.map +1 -0
  400. package/dist/platform/browser-safe.d.ts +29 -0
  401. package/dist/platform/browser-safe.js +31 -0
  402. package/dist/platform/browser-safe.js.map +1 -0
  403. package/dist/platform/browser-safe.test.d.ts +1 -0
  404. package/dist/platform/browser.cjs +330 -0
  405. package/dist/platform/browser.cjs.map +1 -0
  406. package/dist/platform/browser.d.ts +71 -0
  407. package/dist/platform/browser.js +296 -0
  408. package/dist/platform/browser.js.map +1 -0
  409. package/dist/platform/browser.test.d.ts +1 -0
  410. package/dist/platform/index.cjs +50 -0
  411. package/dist/platform/index.cjs.map +1 -0
  412. package/dist/platform/index.d.ts +11 -0
  413. package/dist/platform/index.js +27 -0
  414. package/dist/platform/index.js.map +1 -0
  415. package/dist/platform/interface.cjs +17 -0
  416. package/dist/platform/interface.cjs.map +1 -0
  417. package/dist/{platform.node.d.cts → platform/interface.d.ts} +74 -122
  418. package/dist/platform/interface.js +1 -0
  419. package/dist/platform/interface.js.map +1 -0
  420. package/dist/platform/node.cjs +351 -0
  421. package/dist/platform/node.cjs.map +1 -0
  422. package/dist/platform/node.d.ts +23 -0
  423. package/dist/platform/node.js +320 -0
  424. package/dist/platform/node.js.map +1 -0
  425. package/dist/platform/ports/openpgp-port.cjs +74 -0
  426. package/dist/platform/ports/openpgp-port.cjs.map +1 -0
  427. package/dist/platform/ports/openpgp-port.d.ts +13 -0
  428. package/dist/platform/ports/openpgp-port.js +59 -0
  429. package/dist/platform/ports/openpgp-port.js.map +1 -0
  430. package/dist/platform/ports/pgp-port.cjs +17 -0
  431. package/dist/platform/ports/pgp-port.cjs.map +1 -0
  432. package/dist/platform/ports/pgp-port.d.ts +35 -0
  433. package/dist/platform/ports/pgp-port.js +1 -0
  434. package/dist/platform/ports/pgp-port.js.map +1 -0
  435. package/dist/platform/shared/error-utils.cjs +43 -0
  436. package/dist/platform/shared/error-utils.cjs.map +1 -0
  437. package/dist/platform/shared/error-utils.d.ts +23 -0
  438. package/dist/platform/shared/error-utils.js +18 -0
  439. package/dist/platform/shared/error-utils.js.map +1 -0
  440. package/dist/platform/shared/pgp-utils.cjs +55 -0
  441. package/dist/platform/shared/pgp-utils.cjs.map +1 -0
  442. package/dist/platform/shared/pgp-utils.d.ts +59 -0
  443. package/dist/platform/shared/pgp-utils.js +29 -0
  444. package/dist/platform/shared/pgp-utils.js.map +1 -0
  445. package/dist/platform/shared/stream-utils.cjs +49 -0
  446. package/dist/platform/shared/stream-utils.cjs.map +1 -0
  447. package/dist/platform/shared/stream-utils.d.ts +14 -0
  448. package/dist/platform/shared/stream-utils.js +25 -0
  449. package/dist/platform/shared/stream-utils.js.map +1 -0
  450. package/dist/platform/utils.cjs +114 -0
  451. package/dist/platform/utils.cjs.map +1 -0
  452. package/dist/platform/utils.d.ts +49 -0
  453. package/dist/platform/utils.js +76 -0
  454. package/dist/platform/utils.js.map +1 -0
  455. package/dist/platform/utils.test.d.ts +1 -0
  456. package/dist/platform.browser.d.ts +6 -221
  457. package/dist/platform.browser.js +10 -309
  458. package/dist/platform.browser.js.map +1 -1
  459. package/dist/platform.cjs +14 -623
  460. package/dist/platform.cjs.map +1 -1
  461. package/dist/platform.d.ts +11 -1
  462. package/dist/platform.js +14 -609
  463. package/dist/platform.js.map +1 -1
  464. package/dist/platform.node.cjs +14 -623
  465. package/dist/platform.node.cjs.map +1 -1
  466. package/dist/platform.node.d.ts +7 -261
  467. package/dist/platform.node.js +14 -609
  468. package/dist/platform.node.js.map +1 -1
  469. package/dist/schemas/dataSchema.schema.json +53 -0
  470. package/dist/schemas/grantFile.schema.json +43 -0
  471. package/dist/server/handler.cjs +101 -0
  472. package/dist/server/handler.cjs.map +1 -0
  473. package/dist/server/handler.d.ts +87 -0
  474. package/dist/server/handler.js +77 -0
  475. package/dist/server/handler.js.map +1 -0
  476. package/dist/storage/index.cjs +44 -0
  477. package/dist/storage/index.cjs.map +1 -0
  478. package/dist/storage/index.d.ts +56 -0
  479. package/dist/storage/index.js +15 -0
  480. package/dist/storage/index.js.map +1 -0
  481. package/dist/storage/manager.cjs +189 -0
  482. package/dist/storage/manager.cjs.map +1 -0
  483. package/dist/storage/manager.d.ts +147 -0
  484. package/dist/storage/manager.js +165 -0
  485. package/dist/storage/manager.js.map +1 -0
  486. package/dist/storage/providers/callback-storage.cjs +177 -0
  487. package/dist/storage/providers/callback-storage.cjs.map +1 -0
  488. package/dist/storage/providers/callback-storage.d.ts +94 -0
  489. package/dist/storage/providers/callback-storage.js +155 -0
  490. package/dist/storage/providers/callback-storage.js.map +1 -0
  491. package/dist/storage/providers/google-drive.cjs +516 -0
  492. package/dist/storage/providers/google-drive.cjs.map +1 -0
  493. package/dist/storage/providers/google-drive.d.ts +152 -0
  494. package/dist/storage/providers/google-drive.js +494 -0
  495. package/dist/storage/providers/google-drive.js.map +1 -0
  496. package/dist/storage/providers/google-drive.test.d.ts +1 -0
  497. package/dist/storage/providers/ipfs.cjs +283 -0
  498. package/dist/storage/providers/ipfs.cjs.map +1 -0
  499. package/dist/storage/providers/ipfs.d.ts +160 -0
  500. package/dist/storage/providers/ipfs.js +261 -0
  501. package/dist/storage/providers/ipfs.js.map +1 -0
  502. package/dist/storage/providers/pinata.cjs +339 -0
  503. package/dist/storage/providers/pinata.cjs.map +1 -0
  504. package/dist/storage/providers/pinata.d.ts +170 -0
  505. package/dist/storage/providers/pinata.js +317 -0
  506. package/dist/storage/providers/pinata.js.map +1 -0
  507. package/dist/storage/tests/callbackStorage.test.d.ts +1 -0
  508. package/dist/storage/tests/googleDriveStorage.test.d.ts +1 -0
  509. package/dist/storage/tests/ipfsStorage.test.d.ts +1 -0
  510. package/dist/storage/tests/pinataStorage.test.d.ts +1 -0
  511. package/dist/storage/tests/storageManager.test.d.ts +1 -0
  512. package/dist/tests/abi.test.d.ts +1 -0
  513. package/dist/tests/chains-definitions.test.d.ts +1 -0
  514. package/dist/tests/core-encryption.test.d.ts +1 -0
  515. package/dist/tests/core-extended.test.d.ts +1 -0
  516. package/dist/tests/core-generics-coverage.test.d.ts +1 -0
  517. package/dist/tests/coverage-boost.test.d.ts +1 -0
  518. package/dist/tests/crypto-cross-platform-compatibility.test.d.ts +1 -0
  519. package/dist/tests/data-addfile-permissions-schema.test.d.ts +1 -0
  520. package/dist/tests/data-additional-methods.test.d.ts +1 -0
  521. package/dist/tests/data-controller-edge-cases.test.d.ts +1 -0
  522. package/dist/tests/data-ipfs-gateways.test.d.ts +1 -0
  523. package/dist/tests/data-relayer.test.d.ts +1 -0
  524. package/dist/tests/data-schema-validation.test.d.ts +1 -0
  525. package/dist/tests/data-simple-methods.test.d.ts +1 -0
  526. package/dist/tests/data.test.d.ts +1 -0
  527. package/dist/tests/demo-integration.test.d.ts +1 -0
  528. package/dist/tests/demo-trusted-server-integration.test.d.ts +1 -0
  529. package/dist/tests/download-relayer.test.d.ts +1 -0
  530. package/dist/tests/dual-mode-permissions.test.d.ts +1 -0
  531. package/dist/tests/dual-mode-trusted-servers.test.d.ts +1 -0
  532. package/dist/tests/encryption-correct-implementation.test.d.ts +1 -0
  533. package/dist/tests/encryption-coverage.test.d.ts +1 -0
  534. package/dist/tests/encryption-edge-cases.test.d.ts +1 -0
  535. package/dist/tests/encryption-utils-updated.test.d.ts +1 -0
  536. package/dist/tests/errors-coverage.test.d.ts +1 -0
  537. package/dist/tests/errors.test.d.ts +1 -0
  538. package/dist/tests/factories/mockFactory.d.ts +316 -0
  539. package/dist/tests/fakes/FakeStorageManager.d.ts +200 -0
  540. package/dist/tests/fakes/FakeStorageManager.test.d.ts +1 -0
  541. package/dist/tests/fakes/FakeWaitForTransactionEvents.d.ts +170 -0
  542. package/dist/tests/fakes/FakeWaitForTransactionEvents.test.d.ts +1 -0
  543. package/dist/tests/fakes/fake-pgp-port.d.ts +13 -0
  544. package/dist/tests/grantValidation-edge-cases.test.d.ts +1 -0
  545. package/dist/tests/grantValidation-unreachable-branch.test.d.ts +1 -0
  546. package/dist/tests/helper-methods.test.d.ts +1 -0
  547. package/dist/tests/helpers/platformTestHelpers.d.ts +106 -0
  548. package/dist/tests/helpers/typedMocks.d.ts +64 -0
  549. package/dist/tests/index-browser.test.d.ts +1 -0
  550. package/dist/tests/index-node.test.d.ts +1 -0
  551. package/dist/tests/index.test.d.ts +1 -0
  552. package/dist/tests/mocks/platformAdapter.d.ts +12 -0
  553. package/dist/tests/new-permissions-methods.test.d.ts +1 -0
  554. package/dist/tests/no-buffer-browser.test.d.ts +1 -0
  555. package/dist/tests/permissions-grantee.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-transaction-options.test.d.ts +1 -0
  559. package/dist/tests/permissions-trust-servers.test.d.ts +1 -0
  560. package/dist/tests/permissions.test.d.ts +1 -0
  561. package/dist/tests/personal.test.d.ts +1 -0
  562. package/dist/tests/platform-browser.test.d.ts +1 -0
  563. package/dist/tests/platform-crypto-expanded.test.d.ts +1 -0
  564. package/dist/tests/platform-crypto.test.d.ts +1 -0
  565. package/dist/tests/platform-index.test.d.ts +1 -0
  566. package/dist/tests/platform-node.test.d.ts +1 -0
  567. package/dist/tests/platform-shared-utils.test.d.ts +1 -0
  568. package/dist/tests/platform-updated.test.d.ts +1 -0
  569. package/dist/tests/protocol-additional-methods.test.d.ts +1 -0
  570. package/dist/tests/protocol.test.d.ts +1 -0
  571. package/dist/tests/read-only-mode.test.d.ts +1 -0
  572. package/dist/tests/schemas.test.d.ts +1 -0
  573. package/dist/tests/server-handler.test.d.ts +1 -0
  574. package/dist/tests/setup.d.ts +7 -0
  575. package/dist/tests/signatureFormatter.test.d.ts +1 -0
  576. package/dist/tests/trusted-server-queries.test.d.ts +1 -0
  577. package/dist/tests/typedDataConverter.test.d.ts +1 -0
  578. package/dist/tests/types-contracts.test.d.ts +1 -0
  579. package/dist/tests/types-data.test.d.ts +1 -0
  580. package/dist/tests/types-external-apis.test.d.ts +1 -0
  581. package/dist/tests/types-generics.test.d.ts +1 -0
  582. package/dist/tests/types-permissions.test.d.ts +1 -0
  583. package/dist/tests/types-upload-params.test.d.ts +1 -0
  584. package/dist/tests/types.test.d.ts +1 -0
  585. package/dist/tests/utils-formatters.test.d.ts +1 -0
  586. package/dist/tests/utils-grantFiles-edge-cases.test.d.ts +1 -0
  587. package/dist/tests/utils-grantFiles-validation.test.d.ts +1 -0
  588. package/dist/tests/utils-grantFiles.test.d.ts +1 -0
  589. package/dist/tests/utils-grantValidation-consolidated.test.d.ts +1 -0
  590. package/dist/tests/utils-grants.test.d.ts +1 -0
  591. package/dist/tests/utils-ipfs-additional.test.d.ts +1 -0
  592. package/dist/tests/utils-ipfs.test.d.ts +4 -0
  593. package/dist/tests/utils-schemaValidation.test.d.ts +1 -0
  594. package/dist/tests/vana.test.d.ts +1 -0
  595. package/dist/tests/wallet-crypto-compatibility.test.d.ts +1 -0
  596. package/dist/types/blockchain.cjs +17 -0
  597. package/dist/types/blockchain.cjs.map +1 -0
  598. package/dist/types/blockchain.d.ts +57 -0
  599. package/dist/types/blockchain.js +1 -0
  600. package/dist/types/blockchain.js.map +1 -0
  601. package/dist/types/chains-additional.test.d.ts +1 -0
  602. package/dist/types/chains.cjs +36 -0
  603. package/dist/types/chains.cjs.map +1 -0
  604. package/dist/types/chains.d.ts +31 -0
  605. package/dist/types/chains.js +11 -0
  606. package/dist/types/chains.js.map +1 -0
  607. package/dist/types/config.cjs +51 -0
  608. package/dist/types/config.cjs.map +1 -0
  609. package/dist/types/config.d.ts +833 -0
  610. package/dist/types/config.js +23 -0
  611. package/dist/types/config.js.map +1 -0
  612. package/dist/types/contracts.cjs +17 -0
  613. package/dist/types/contracts.cjs.map +1 -0
  614. package/dist/types/contracts.d.ts +65 -0
  615. package/dist/types/contracts.js +1 -0
  616. package/dist/types/contracts.js.map +1 -0
  617. package/dist/types/controller-context.cjs +17 -0
  618. package/dist/types/controller-context.cjs.map +1 -0
  619. package/dist/types/controller-context.d.ts +64 -0
  620. package/dist/types/controller-context.js +1 -0
  621. package/dist/types/controller-context.js.map +1 -0
  622. package/dist/types/data.cjs +17 -0
  623. package/dist/types/data.cjs.map +1 -0
  624. package/dist/types/data.d.ts +762 -0
  625. package/dist/types/data.js +1 -0
  626. package/dist/types/data.js.map +1 -0
  627. package/dist/types/eccrypto-js.d.cjs +2 -0
  628. package/dist/types/eccrypto-js.d.cjs.map +1 -0
  629. package/dist/types/eccrypto-js.d.js +1 -0
  630. package/dist/types/eccrypto-js.d.js.map +1 -0
  631. package/dist/types/external-apis.cjs +61 -0
  632. package/dist/types/external-apis.cjs.map +1 -0
  633. package/dist/types/external-apis.d.ts +184 -0
  634. package/dist/types/external-apis.js +34 -0
  635. package/dist/types/external-apis.js.map +1 -0
  636. package/dist/types/generics.cjs +17 -0
  637. package/dist/types/generics.cjs.map +1 -0
  638. package/dist/types/generics.d.ts +447 -0
  639. package/dist/types/generics.js +1 -0
  640. package/dist/types/generics.js.map +1 -0
  641. package/dist/types/index.cjs +65 -0
  642. package/dist/types/index.cjs.map +1 -0
  643. package/dist/types/index.d.ts +20 -0
  644. package/dist/types/index.js +42 -0
  645. package/dist/types/index.js.map +1 -0
  646. package/dist/types/operations.cjs +65 -0
  647. package/dist/types/operations.cjs.map +1 -0
  648. package/dist/types/operations.d.ts +112 -0
  649. package/dist/types/operations.js +37 -0
  650. package/dist/types/operations.js.map +1 -0
  651. package/dist/types/permissions.cjs +17 -0
  652. package/dist/types/permissions.cjs.map +1 -0
  653. package/dist/types/permissions.d.ts +954 -0
  654. package/dist/types/permissions.js +1 -0
  655. package/dist/types/permissions.js.map +1 -0
  656. package/dist/types/personal.cjs +17 -0
  657. package/dist/types/personal.cjs.map +1 -0
  658. package/dist/types/personal.d.ts +38 -0
  659. package/dist/types/personal.js +1 -0
  660. package/dist/types/personal.js.map +1 -0
  661. package/dist/types/relayer.cjs +17 -0
  662. package/dist/types/relayer.cjs.map +1 -0
  663. package/dist/types/relayer.d.ts +281 -0
  664. package/dist/types/relayer.js +1 -0
  665. package/dist/types/relayer.js.map +1 -0
  666. package/dist/types/storage.cjs +39 -0
  667. package/dist/types/storage.cjs.map +1 -0
  668. package/dist/types/storage.d.ts +129 -0
  669. package/dist/types/storage.js +15 -0
  670. package/dist/types/storage.js.map +1 -0
  671. package/dist/types/transactionResults.cjs +17 -0
  672. package/dist/types/transactionResults.cjs.map +1 -0
  673. package/dist/types/transactionResults.d.ts +193 -0
  674. package/dist/types/transactionResults.js +1 -0
  675. package/dist/types/transactionResults.js.map +1 -0
  676. package/dist/types/utils.cjs +17 -0
  677. package/dist/types/utils.cjs.map +1 -0
  678. package/dist/types/utils.d.ts +820 -0
  679. package/dist/types/utils.js +1 -0
  680. package/dist/types/utils.js.map +1 -0
  681. package/dist/types.cjs +23 -0
  682. package/dist/types.cjs.map +1 -0
  683. package/dist/types.d.ts +30 -0
  684. package/dist/types.js +2 -0
  685. package/dist/types.js.map +1 -0
  686. package/dist/utils/__tests__/parseTransaction.test.d.ts +1 -0
  687. package/dist/utils/__tests__/pojo-serialization.test.d.ts +1 -0
  688. package/dist/utils/__tests__/signatureCache.test.d.ts +1 -0
  689. package/dist/utils/__tests__/transaction-edge-cases.test.d.ts +1 -0
  690. package/dist/utils/__tests__/transactionHelpers.test.d.ts +1 -0
  691. package/dist/utils/__tests__/urlResolver.test.d.ts +4 -0
  692. package/dist/utils/blockchain/registry.cjs +81 -0
  693. package/dist/utils/blockchain/registry.cjs.map +1 -0
  694. package/dist/utils/blockchain/registry.d.ts +32 -0
  695. package/dist/utils/blockchain/registry.js +56 -0
  696. package/dist/utils/blockchain/registry.js.map +1 -0
  697. package/dist/utils/blockchain/registry.test.d.ts +1 -0
  698. package/dist/utils/crypto-utils.cjs +108 -0
  699. package/dist/utils/crypto-utils.cjs.map +1 -0
  700. package/dist/utils/crypto-utils.d.ts +100 -0
  701. package/dist/utils/crypto-utils.js +76 -0
  702. package/dist/utils/crypto-utils.js.map +1 -0
  703. package/dist/utils/crypto-utils.test.d.ts +1 -0
  704. package/dist/utils/download.cjs +69 -0
  705. package/dist/utils/download.cjs.map +1 -0
  706. package/dist/utils/download.d.ts +40 -0
  707. package/dist/utils/download.js +45 -0
  708. package/dist/utils/download.js.map +1 -0
  709. package/dist/utils/encoding.cjs +66 -0
  710. package/dist/utils/encoding.cjs.map +1 -0
  711. package/dist/utils/encoding.d.ts +52 -0
  712. package/dist/utils/encoding.js +39 -0
  713. package/dist/utils/encoding.js.map +1 -0
  714. package/dist/utils/encoding.test.d.ts +1 -0
  715. package/dist/utils/encryption.cjs +176 -0
  716. package/dist/utils/encryption.cjs.map +1 -0
  717. package/dist/utils/encryption.d.ts +271 -0
  718. package/dist/utils/encryption.js +142 -0
  719. package/dist/utils/encryption.js.map +1 -0
  720. package/dist/utils/formatters.cjs +55 -0
  721. package/dist/utils/formatters.cjs.map +1 -0
  722. package/dist/utils/formatters.d.ts +118 -0
  723. package/dist/utils/formatters.js +28 -0
  724. package/dist/utils/formatters.js.map +1 -0
  725. package/dist/utils/grantFiles.cjs +178 -0
  726. package/dist/utils/grantFiles.cjs.map +1 -0
  727. package/dist/utils/grantFiles.d.ts +182 -0
  728. package/dist/utils/grantFiles.js +140 -0
  729. package/dist/utils/grantFiles.js.map +1 -0
  730. package/dist/utils/grantValidation.cjs +243 -0
  731. package/dist/utils/grantValidation.cjs.map +1 -0
  732. package/dist/utils/grantValidation.d.ts +147 -0
  733. package/dist/utils/grantValidation.js +201 -0
  734. package/dist/utils/grantValidation.js.map +1 -0
  735. package/dist/utils/grants.cjs +108 -0
  736. package/dist/utils/grants.cjs.map +1 -0
  737. package/dist/utils/grants.d.ts +67 -0
  738. package/dist/utils/grants.js +82 -0
  739. package/dist/utils/grants.js.map +1 -0
  740. package/dist/utils/ipfs.cjs +130 -0
  741. package/dist/utils/ipfs.cjs.map +1 -0
  742. package/dist/utils/ipfs.d.ts +88 -0
  743. package/dist/utils/ipfs.js +99 -0
  744. package/dist/utils/ipfs.js.map +1 -0
  745. package/dist/utils/lazy-import.cjs +38 -0
  746. package/dist/utils/lazy-import.cjs.map +1 -0
  747. package/dist/utils/lazy-import.d.ts +18 -0
  748. package/dist/utils/lazy-import.js +14 -0
  749. package/dist/utils/lazy-import.js.map +1 -0
  750. package/dist/utils/multicall.cjs +233 -0
  751. package/dist/utils/multicall.cjs.map +1 -0
  752. package/dist/utils/multicall.d.ts +126 -0
  753. package/dist/utils/multicall.js +208 -0
  754. package/dist/utils/multicall.js.map +1 -0
  755. package/dist/utils/parseTransactionPojo.cjs +87 -0
  756. package/dist/utils/parseTransactionPojo.cjs.map +1 -0
  757. package/dist/utils/parseTransactionPojo.d.ts +31 -0
  758. package/dist/utils/parseTransactionPojo.js +63 -0
  759. package/dist/utils/parseTransactionPojo.js.map +1 -0
  760. package/dist/utils/schemaValidation.cjs +258 -0
  761. package/dist/utils/schemaValidation.cjs.map +1 -0
  762. package/dist/utils/schemaValidation.d.ts +168 -0
  763. package/dist/utils/schemaValidation.js +219 -0
  764. package/dist/utils/schemaValidation.js.map +1 -0
  765. package/dist/utils/signatureCache.cjs +186 -0
  766. package/dist/utils/signatureCache.cjs.map +1 -0
  767. package/dist/utils/signatureCache.d.ts +131 -0
  768. package/dist/utils/signatureCache.js +161 -0
  769. package/dist/utils/signatureCache.js.map +1 -0
  770. package/dist/utils/signatureFormatter.cjs +42 -0
  771. package/dist/utils/signatureFormatter.cjs.map +1 -0
  772. package/dist/utils/signatureFormatter.d.ts +36 -0
  773. package/dist/utils/signatureFormatter.js +18 -0
  774. package/dist/utils/signatureFormatter.js.map +1 -0
  775. package/dist/utils/tests/multicall.test.d.ts +1 -0
  776. package/dist/utils/transactionHelpers.cjs +54 -0
  777. package/dist/utils/transactionHelpers.cjs.map +1 -0
  778. package/dist/utils/transactionHelpers.d.ts +80 -0
  779. package/dist/utils/transactionHelpers.js +29 -0
  780. package/dist/utils/transactionHelpers.js.map +1 -0
  781. package/dist/utils/typeGuards.cjs +109 -0
  782. package/dist/utils/typeGuards.cjs.map +1 -0
  783. package/dist/utils/typeGuards.d.ts +138 -0
  784. package/dist/utils/typeGuards.js +74 -0
  785. package/dist/utils/typeGuards.js.map +1 -0
  786. package/dist/utils/typedDataConverter.cjs +43 -0
  787. package/dist/utils/typedDataConverter.cjs.map +1 -0
  788. package/dist/utils/typedDataConverter.d.ts +10 -0
  789. package/dist/utils/typedDataConverter.js +19 -0
  790. package/dist/utils/typedDataConverter.js.map +1 -0
  791. package/dist/utils/urlResolver.cjs +55 -0
  792. package/dist/utils/urlResolver.cjs.map +1 -0
  793. package/dist/utils/urlResolver.d.ts +38 -0
  794. package/dist/utils/urlResolver.js +30 -0
  795. package/dist/utils/urlResolver.js.map +1 -0
  796. package/dist/utils/wallet.cjs +62 -0
  797. package/dist/utils/wallet.cjs.map +1 -0
  798. package/dist/utils/wallet.d.ts +32 -0
  799. package/dist/utils/wallet.js +36 -0
  800. package/dist/utils/wallet.js.map +1 -0
  801. package/dist/utils/withEvents.cjs +44 -0
  802. package/dist/utils/withEvents.cjs.map +1 -0
  803. package/dist/utils/withEvents.d.ts +56 -0
  804. package/dist/utils/withEvents.js +18 -0
  805. package/dist/utils/withEvents.js.map +1 -0
  806. package/package.json +74 -37
  807. package/dist/chains.browser.cjs.map +0 -1
  808. package/dist/chains.d.cts +0 -2
  809. package/dist/chains.node.d.cts +0 -2
  810. package/dist/index.d.cts +0 -2
  811. package/dist/platform.d.cts +0 -1
@@ -0,0 +1,101 @@
1
+ const CURVE = {
2
+ /** The elliptic curve used (secp256k1 - same as Bitcoin/Ethereum) */
3
+ name: "secp256k1",
4
+ /** Private key length in bytes */
5
+ PRIVATE_KEY_LENGTH: 32,
6
+ /** Compressed public key length in bytes (0x02 or 0x03 prefix + 32 bytes) */
7
+ COMPRESSED_PUBLIC_KEY_LENGTH: 33,
8
+ /** Uncompressed public key length in bytes (0x04 prefix + 64 bytes) */
9
+ UNCOMPRESSED_PUBLIC_KEY_LENGTH: 65,
10
+ /** ECDH shared secret X coordinate length */
11
+ SHARED_SECRET_LENGTH: 32,
12
+ /** Public key prefixes */
13
+ PREFIX: {
14
+ /** Uncompressed public key prefix */
15
+ UNCOMPRESSED: 4,
16
+ /** Compressed public key prefix for even Y */
17
+ COMPRESSED_EVEN: 2,
18
+ /** Compressed public key prefix for odd Y */
19
+ COMPRESSED_ODD: 3
20
+ },
21
+ /** X coordinate starts at byte 1 (after prefix) */
22
+ X_COORDINATE_OFFSET: 1,
23
+ /** X coordinate ends at byte 33 (1 + 32) */
24
+ X_COORDINATE_END: 33
25
+ };
26
+ const CIPHER = {
27
+ /** Cipher algorithm - must match eccrypto */
28
+ algorithm: "aes-256-cbc",
29
+ /** AES key length in bytes */
30
+ KEY_LENGTH: 32,
31
+ /** Initialization vector length in bytes */
32
+ IV_LENGTH: 16,
33
+ /** Block size for AES */
34
+ BLOCK_SIZE: 16
35
+ };
36
+ const KDF = {
37
+ /** Hash algorithm for key derivation - must match eccrypto */
38
+ algorithm: "sha512",
39
+ /** Output length of SHA-512 in bytes */
40
+ OUTPUT_LENGTH: 64,
41
+ /** Encryption key slice (first 32 bytes of KDF output) */
42
+ ENCRYPTION_KEY_OFFSET: 0,
43
+ ENCRYPTION_KEY_LENGTH: 32,
44
+ /** MAC key slice (last 32 bytes of KDF output) */
45
+ MAC_KEY_OFFSET: 32,
46
+ MAC_KEY_LENGTH: 32
47
+ };
48
+ const MAC = {
49
+ /** MAC algorithm - must match eccrypto */
50
+ algorithm: "sha256",
51
+ /** HMAC-SHA256 output length in bytes */
52
+ LENGTH: 32
53
+ };
54
+ const FORMAT = {
55
+ /** Offsets for each component in serialized format */
56
+ IV_OFFSET: 0,
57
+ IV_LENGTH: CIPHER.IV_LENGTH,
58
+ /** Ephemeral public key (always uncompressed in eccrypto format) */
59
+ EPHEMERAL_KEY_OFFSET: CIPHER.IV_LENGTH,
60
+ EPHEMERAL_KEY_LENGTH: CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH,
61
+ /** Ciphertext starts after IV and ephemeral key */
62
+ CIPHERTEXT_OFFSET: CIPHER.IV_LENGTH + CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH,
63
+ /** MAC is always the last 32 bytes */
64
+ MAC_LENGTH: MAC.LENGTH,
65
+ /** Minimum size of encrypted data (IV + ephemKey + MAC, no ciphertext) */
66
+ MIN_ENCRYPTED_LENGTH: CIPHER.IV_LENGTH + CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH + MAC.LENGTH,
67
+ /**
68
+ * Helper to calculate total length of encrypted data
69
+ *
70
+ * @param ciphertextLength - Length of the ciphertext portion
71
+ * @returns Total length including all components
72
+ */
73
+ getTotalLength: (ciphertextLength) => CIPHER.IV_LENGTH + CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH + ciphertextLength + MAC.LENGTH
74
+ };
75
+ const SECURITY = {
76
+ /** Overwrite patterns for secure data clearing */
77
+ CLEAR_PATTERNS: {
78
+ ZEROS: 0,
79
+ ONES: 255,
80
+ /** Pattern multiplier for third pass */
81
+ PATTERN_MULTIPLIER: 7,
82
+ /** Pattern offset for third pass */
83
+ PATTERN_OFFSET: 13
84
+ }
85
+ };
86
+ const VALIDATION = {
87
+ isValidPrivateKey: (key) => key.length === CURVE.PRIVATE_KEY_LENGTH,
88
+ isValidPublicKey: (key) => key.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH || key.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH,
89
+ isCompressedPublicKey: (key) => key.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH && (key[0] === CURVE.PREFIX.COMPRESSED_EVEN || key[0] === CURVE.PREFIX.COMPRESSED_ODD),
90
+ isUncompressedPublicKey: (key) => key.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH && key[0] === CURVE.PREFIX.UNCOMPRESSED
91
+ };
92
+ export {
93
+ CIPHER,
94
+ CURVE,
95
+ FORMAT,
96
+ KDF,
97
+ MAC,
98
+ SECURITY,
99
+ VALIDATION
100
+ };
101
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/constants.ts"],"sourcesContent":["/**\n * ECIES Constants and Format Specification\n *\n * These constants define the eccrypto-compatible ECIES format used throughout the SDK.\n * Maintaining these exact values ensures backward compatibility with data encrypted\n * using the original eccrypto library.\n */\n\n/**\n * Elliptic curve parameters\n */\nexport const CURVE = {\n /** The elliptic curve used (secp256k1 - same as Bitcoin/Ethereum) */\n name: \"secp256k1\",\n /** Private key length in bytes */\n PRIVATE_KEY_LENGTH: 32,\n /** Compressed public key length in bytes (0x02 or 0x03 prefix + 32 bytes) */\n COMPRESSED_PUBLIC_KEY_LENGTH: 33,\n /** Uncompressed public key length in bytes (0x04 prefix + 64 bytes) */\n UNCOMPRESSED_PUBLIC_KEY_LENGTH: 65,\n /** ECDH shared secret X coordinate length */\n SHARED_SECRET_LENGTH: 32,\n /** Public key prefixes */\n PREFIX: {\n /** Uncompressed public key prefix */\n UNCOMPRESSED: 0x04,\n /** Compressed public key prefix for even Y */\n COMPRESSED_EVEN: 0x02,\n /** Compressed public key prefix for odd Y */\n COMPRESSED_ODD: 0x03,\n },\n /** X coordinate starts at byte 1 (after prefix) */\n X_COORDINATE_OFFSET: 1,\n /** X coordinate ends at byte 33 (1 + 32) */\n X_COORDINATE_END: 33,\n} as const;\n\n/**\n * Symmetric encryption parameters (AES-256-CBC)\n */\nexport const CIPHER = {\n /** Cipher algorithm - must match eccrypto */\n algorithm: \"aes-256-cbc\",\n /** AES key length in bytes */\n KEY_LENGTH: 32,\n /** Initialization vector length in bytes */\n IV_LENGTH: 16,\n /** Block size for AES */\n BLOCK_SIZE: 16,\n} as const;\n\n/**\n * Key derivation function parameters\n */\nexport const KDF = {\n /** Hash algorithm for key derivation - must match eccrypto */\n algorithm: \"sha512\",\n /** Output length of SHA-512 in bytes */\n OUTPUT_LENGTH: 64,\n /** Encryption key slice (first 32 bytes of KDF output) */\n ENCRYPTION_KEY_OFFSET: 0,\n ENCRYPTION_KEY_LENGTH: 32,\n /** MAC key slice (last 32 bytes of KDF output) */\n MAC_KEY_OFFSET: 32,\n MAC_KEY_LENGTH: 32,\n} as const;\n\n/**\n * Message authentication code parameters\n */\nexport const MAC = {\n /** MAC algorithm - must match eccrypto */\n algorithm: \"sha256\",\n /** HMAC-SHA256 output length in bytes */\n LENGTH: 32,\n} as const;\n\n/**\n * ECIES encrypted data format offsets and lengths\n * Format: [iv(16)][ephemPublicKey(65)][ciphertext(variable)][mac(32)]\n */\nexport const FORMAT = {\n /** Offsets for each component in serialized format */\n IV_OFFSET: 0,\n IV_LENGTH: CIPHER.IV_LENGTH,\n\n /** Ephemeral public key (always uncompressed in eccrypto format) */\n EPHEMERAL_KEY_OFFSET: CIPHER.IV_LENGTH,\n EPHEMERAL_KEY_LENGTH: CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH,\n\n /** Ciphertext starts after IV and ephemeral key */\n CIPHERTEXT_OFFSET: CIPHER.IV_LENGTH + CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH,\n\n /** MAC is always the last 32 bytes */\n MAC_LENGTH: MAC.LENGTH,\n\n /** Minimum size of encrypted data (IV + ephemKey + MAC, no ciphertext) */\n MIN_ENCRYPTED_LENGTH:\n CIPHER.IV_LENGTH + CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH + MAC.LENGTH,\n\n /**\n * Helper to calculate total length of encrypted data\n *\n * @param ciphertextLength - Length of the ciphertext portion\n * @returns Total length including all components\n */\n getTotalLength: (ciphertextLength: number) =>\n CIPHER.IV_LENGTH +\n CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH +\n ciphertextLength +\n MAC.LENGTH,\n} as const;\n\n/**\n * Security constants for data clearing\n */\nexport const SECURITY = {\n /** Overwrite patterns for secure data clearing */\n CLEAR_PATTERNS: {\n ZEROS: 0x00,\n ONES: 0xff,\n /** Pattern multiplier for third pass */\n PATTERN_MULTIPLIER: 7,\n /** Pattern offset for third pass */\n PATTERN_OFFSET: 13,\n },\n} as const;\n\n/**\n * Validation helpers\n */\nexport const VALIDATION = {\n isValidPrivateKey: (key: Uint8Array): boolean =>\n key.length === CURVE.PRIVATE_KEY_LENGTH,\n\n isValidPublicKey: (key: Uint8Array): boolean =>\n key.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH ||\n key.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH,\n\n isCompressedPublicKey: (key: Uint8Array): boolean =>\n key.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH &&\n (key[0] === CURVE.PREFIX.COMPRESSED_EVEN ||\n key[0] === CURVE.PREFIX.COMPRESSED_ODD),\n\n isUncompressedPublicKey: (key: Uint8Array): boolean =>\n key.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH &&\n key[0] === CURVE.PREFIX.UNCOMPRESSED,\n} as const;\n"],"mappings":"AAWO,MAAM,QAAQ;AAAA;AAAA,EAEnB,MAAM;AAAA;AAAA,EAEN,oBAAoB;AAAA;AAAA,EAEpB,8BAA8B;AAAA;AAAA,EAE9B,gCAAgC;AAAA;AAAA,EAEhC,sBAAsB;AAAA;AAAA,EAEtB,QAAQ;AAAA;AAAA,IAEN,cAAc;AAAA;AAAA,IAEd,iBAAiB;AAAA;AAAA,IAEjB,gBAAgB;AAAA,EAClB;AAAA;AAAA,EAEA,qBAAqB;AAAA;AAAA,EAErB,kBAAkB;AACpB;AAKO,MAAM,SAAS;AAAA;AAAA,EAEpB,WAAW;AAAA;AAAA,EAEX,YAAY;AAAA;AAAA,EAEZ,WAAW;AAAA;AAAA,EAEX,YAAY;AACd;AAKO,MAAM,MAAM;AAAA;AAAA,EAEjB,WAAW;AAAA;AAAA,EAEX,eAAe;AAAA;AAAA,EAEf,uBAAuB;AAAA,EACvB,uBAAuB;AAAA;AAAA,EAEvB,gBAAgB;AAAA,EAChB,gBAAgB;AAClB;AAKO,MAAM,MAAM;AAAA;AAAA,EAEjB,WAAW;AAAA;AAAA,EAEX,QAAQ;AACV;AAMO,MAAM,SAAS;AAAA;AAAA,EAEpB,WAAW;AAAA,EACX,WAAW,OAAO;AAAA;AAAA,EAGlB,sBAAsB,OAAO;AAAA,EAC7B,sBAAsB,MAAM;AAAA;AAAA,EAG5B,mBAAmB,OAAO,YAAY,MAAM;AAAA;AAAA,EAG5C,YAAY,IAAI;AAAA;AAAA,EAGhB,sBACE,OAAO,YAAY,MAAM,iCAAiC,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQhE,gBAAgB,CAAC,qBACf,OAAO,YACP,MAAM,iCACN,mBACA,IAAI;AACR;AAKO,MAAM,WAAW;AAAA;AAAA,EAEtB,gBAAgB;AAAA,IACd,OAAO;AAAA,IACP,MAAM;AAAA;AAAA,IAEN,oBAAoB;AAAA;AAAA,IAEpB,gBAAgB;AAAA,EAClB;AACF;AAKO,MAAM,aAAa;AAAA,EACxB,mBAAmB,CAAC,QAClB,IAAI,WAAW,MAAM;AAAA,EAEvB,kBAAkB,CAAC,QACjB,IAAI,WAAW,MAAM,gCACrB,IAAI,WAAW,MAAM;AAAA,EAEvB,uBAAuB,CAAC,QACtB,IAAI,WAAW,MAAM,iCACpB,IAAI,CAAC,MAAM,MAAM,OAAO,mBACvB,IAAI,CAAC,MAAM,MAAM,OAAO;AAAA,EAE5B,yBAAyB,CAAC,QACxB,IAAI,WAAW,MAAM,kCACrB,IAAI,CAAC,MAAM,MAAM,OAAO;AAC5B;","names":[]}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var ecies_exports = {};
20
+ __export(ecies_exports, {
21
+ ECIESError: () => import_interface.ECIESError,
22
+ deserializeECIES: () => import_interface.deserializeECIES,
23
+ isECIESEncrypted: () => import_interface.isECIESEncrypted,
24
+ serializeECIES: () => import_interface.serializeECIES
25
+ });
26
+ module.exports = __toCommonJS(ecies_exports);
27
+ var import_interface = require("./interface");
28
+ // Annotate the CommonJS export names for ESM import in node:
29
+ 0 && (module.exports = {
30
+ ECIESError,
31
+ deserializeECIES,
32
+ isECIESEncrypted,
33
+ serializeECIES
34
+ });
35
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/index.ts"],"sourcesContent":["/**\n * ECIES Module Entry Point\n *\n * Exports interface and utilities for ECIES encryption/decryption\n * Platform-specific implementations are imported separately\n */\n\nexport type { ECIESProvider, ECIESEncrypted, ECIESOptions } from \"./interface\";\n\nexport {\n ECIESError,\n isECIESEncrypted,\n serializeECIES,\n deserializeECIES,\n} from \"./interface\";\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,uBAKO;","names":[]}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * ECIES Module Entry Point
3
+ *
4
+ * Exports interface and utilities for ECIES encryption/decryption
5
+ * Platform-specific implementations are imported separately
6
+ */
7
+ export type { ECIESProvider, ECIESEncrypted, ECIESOptions } from "./interface";
8
+ export { ECIESError, isECIESEncrypted, serializeECIES, deserializeECIES, } from "./interface";
@@ -0,0 +1,13 @@
1
+ import {
2
+ ECIESError,
3
+ isECIESEncrypted,
4
+ serializeECIES,
5
+ deserializeECIES
6
+ } from "./interface";
7
+ export {
8
+ ECIESError,
9
+ deserializeECIES,
10
+ isECIESEncrypted,
11
+ serializeECIES
12
+ };
13
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/index.ts"],"sourcesContent":["/**\n * ECIES Module Entry Point\n *\n * Exports interface and utilities for ECIES encryption/decryption\n * Platform-specific implementations are imported separately\n */\n\nexport type { ECIESProvider, ECIESEncrypted, ECIESOptions } from \"./interface\";\n\nexport {\n ECIESError,\n isECIESEncrypted,\n serializeECIES,\n deserializeECIES,\n} from \"./interface\";\n"],"mappings":"AASA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;","names":[]}
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var interface_exports = {};
20
+ __export(interface_exports, {
21
+ ECIESError: () => ECIESError,
22
+ deserializeECIES: () => deserializeECIES,
23
+ isECIESEncrypted: () => isECIESEncrypted,
24
+ serializeECIES: () => serializeECIES
25
+ });
26
+ module.exports = __toCommonJS(interface_exports);
27
+ var import_constants = require("./constants");
28
+ var import_viem = require("viem");
29
+ class ECIESError extends Error {
30
+ constructor(message, code, cause) {
31
+ super(message);
32
+ this.code = code;
33
+ this.cause = cause;
34
+ this.name = "ECIESError";
35
+ }
36
+ }
37
+ function isECIESEncrypted(obj) {
38
+ if (!obj || typeof obj !== "object") return false;
39
+ const enc = obj;
40
+ const isUint8Array = (value) => {
41
+ return value instanceof Uint8Array || typeof Buffer !== "undefined" && Buffer.isBuffer(value);
42
+ };
43
+ return isUint8Array(enc.iv) && enc.iv.length === import_constants.CIPHER.IV_LENGTH && isUint8Array(enc.ephemPublicKey) && (enc.ephemPublicKey.length === import_constants.CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH || enc.ephemPublicKey.length === import_constants.CURVE.COMPRESSED_PUBLIC_KEY_LENGTH) && isUint8Array(enc.ciphertext) && enc.ciphertext.length > 0 && isUint8Array(enc.mac) && enc.mac.length === import_constants.MAC.LENGTH;
44
+ }
45
+ function serializeECIES(encrypted) {
46
+ const combined = new Uint8Array(
47
+ encrypted.iv.length + encrypted.ephemPublicKey.length + encrypted.ciphertext.length + encrypted.mac.length
48
+ );
49
+ let offset = 0;
50
+ combined.set(encrypted.iv, offset);
51
+ offset += encrypted.iv.length;
52
+ combined.set(encrypted.ephemPublicKey, offset);
53
+ offset += encrypted.ephemPublicKey.length;
54
+ combined.set(encrypted.ciphertext, offset);
55
+ offset += encrypted.ciphertext.length;
56
+ combined.set(encrypted.mac, offset);
57
+ return (0, import_viem.toHex)(combined).slice(2);
58
+ }
59
+ function deserializeECIES(hex) {
60
+ const hexWithPrefix = hex.startsWith("0x") ? hex : `0x${hex}`;
61
+ const bytes = (0, import_viem.fromHex)(hexWithPrefix, "bytes");
62
+ const ephemKeySize = bytes[import_constants.FORMAT.EPHEMERAL_KEY_OFFSET] === import_constants.CURVE.PREFIX.UNCOMPRESSED ? import_constants.CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH : import_constants.CURVE.COMPRESSED_PUBLIC_KEY_LENGTH;
63
+ const minLength = import_constants.FORMAT.IV_LENGTH + ephemKeySize + import_constants.MAC.LENGTH + 1;
64
+ if (bytes.length < minLength) {
65
+ throw new ECIESError("Invalid ECIES data: too short", "DECRYPTION_FAILED");
66
+ }
67
+ return {
68
+ iv: bytes.subarray(import_constants.FORMAT.IV_OFFSET, import_constants.FORMAT.IV_OFFSET + import_constants.FORMAT.IV_LENGTH),
69
+ ephemPublicKey: bytes.subarray(
70
+ import_constants.FORMAT.EPHEMERAL_KEY_OFFSET,
71
+ import_constants.FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize
72
+ ),
73
+ ciphertext: bytes.subarray(
74
+ import_constants.FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize,
75
+ bytes.length - import_constants.MAC.LENGTH
76
+ ),
77
+ mac: bytes.subarray(bytes.length - import_constants.MAC.LENGTH)
78
+ };
79
+ }
80
+ // Annotate the CommonJS export names for ESM import in node:
81
+ 0 && (module.exports = {
82
+ ECIESError,
83
+ deserializeECIES,
84
+ isECIESEncrypted,
85
+ serializeECIES
86
+ });
87
+ //# sourceMappingURL=interface.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/interface.ts"],"sourcesContent":["/**\n * ECIES (Elliptic Curve Integrated Encryption Scheme) Interface\n *\n * @remarks\n * Defines the contract for platform-specific ECIES implementations.\n * All implementations maintain compatibility with the eccrypto format to ensure\n * backward compatibility with existing encrypted data.\n *\n * **Format specification:**\n * `[iv (16 bytes)][ephemPublicKey (65 bytes)][ciphertext (variable)][mac (32 bytes)]`\n *\n * @category Cryptography\n */\n\nimport { CIPHER, CURVE, MAC, FORMAT } from \"./constants\";\nimport { fromHex, toHex } from \"viem\";\n\n/**\n * Represents ECIES encrypted data in eccrypto-compatible format.\n *\n * @remarks\n * This structure maintains backward compatibility with data encrypted using\n * the legacy eccrypto library.\n */\nexport interface ECIESEncrypted {\n /** Initialization vector (16 bytes) */\n iv: Uint8Array;\n /** Ephemeral public key (65 bytes uncompressed) */\n ephemPublicKey: Uint8Array;\n /** Encrypted data */\n ciphertext: Uint8Array;\n /** Message authentication code (32 bytes) */\n mac: Uint8Array;\n}\n\n/**\n * Provides ECIES encryption and decryption operations.\n *\n * @remarks\n * Platform-specific implementations handle the underlying cryptographic primitives\n * while maintaining consistent data format across environments.\n *\n * @category Cryptography\n */\nexport interface ECIESProvider {\n /**\n * Encrypts data using ECIES with secp256k1.\n *\n * @param publicKey - Recipient's public key (65 bytes uncompressed or 33 bytes compressed).\n * Obtain via `vana.server.getIdentity(userAddress).public_key`.\n * @param message - Data to encrypt.\n * @returns Encrypted data structure compatible with eccrypto format.\n * @throws {ECIESError} When public key is invalid.\n * Verify key format matches secp256k1 requirements.\n *\n * @example\n * ```typescript\n * const encrypted = await provider.encrypt(\n * fromHex(publicKey, 'bytes'),\n * new TextEncoder().encode('sensitive data')\n * );\n * ```\n */\n encrypt(publicKey: Uint8Array, message: Uint8Array): Promise<ECIESEncrypted>;\n\n /**\n * Decrypts ECIES encrypted data.\n *\n * @param privateKey - Recipient's private key (32 bytes).\n * @param encrypted - Encrypted data structure from `encrypt()` or legacy eccrypto.\n * @returns Decrypted message as Uint8Array.\n * @throws {ECIESError} When MAC verification fails.\n * Ensure the private key matches the public key used for encryption.\n *\n * @example\n * ```typescript\n * const decrypted = await provider.decrypt(\n * fromHex(privateKey, 'bytes'),\n * encrypted\n * );\n * const message = new TextDecoder().decode(decrypted);\n * ```\n */\n decrypt(\n privateKey: Uint8Array,\n encrypted: ECIESEncrypted,\n ): Promise<Uint8Array>;\n\n /**\n * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).\n *\n * @remarks\n * Strict policy: Only accepts properly formatted compressed (33 bytes) or\n * uncompressed (65 bytes) public keys. Does not accept 64-byte raw coordinates\n * to ensure data integrity and prevent masking of malformed inputs.\n *\n * @param publicKey - Public key in compressed or uncompressed format\n * @returns Normalized uncompressed public key (65 bytes with 0x04 prefix)\n * @throws {Error} When public key format is invalid, including raw coordinates (64 bytes)\n * @throws {Error} When decompression of compressed key fails\n *\n * @example\n * ```typescript\n * // Compressed key (33 bytes)\n * const compressed = new Uint8Array(33);\n * compressed[0] = 0x02;\n * const uncompressed = provider.normalizeToUncompressed(compressed);\n * console.log(uncompressed.length); // 65\n * console.log(uncompressed[0]); // 0x04\n *\n * // Already uncompressed (65 bytes)\n * const already = provider.normalizeToUncompressed(uncompressedKey);\n * console.log(already === uncompressedKey); // true (returns same reference)\n *\n * // Raw coordinates rejected (64 bytes)\n * const raw = new Uint8Array(64);\n * provider.normalizeToUncompressed(raw); // Throws error\n * ```\n */\n normalizeToUncompressed(publicKey: Uint8Array): Uint8Array;\n}\n\n/**\n * Configures ECIES operation behavior.\n */\nexport interface ECIESOptions {\n /** Use compressed public keys (33 bytes) instead of uncompressed (65 bytes) */\n useCompressed?: boolean;\n}\n\n/**\n * Represents failures in ECIES cryptographic operations.\n *\n * @remarks\n * Provides specific error codes to help identify and recover from\n * different failure scenarios.\n *\n * @category Errors\n */\nexport class ECIESError extends Error {\n constructor(\n message: string,\n public readonly code:\n | \"INVALID_KEY\"\n | \"ENCRYPTION_FAILED\"\n | \"DECRYPTION_FAILED\"\n | \"MAC_MISMATCH\"\n | \"ECDH_FAILED\",\n public override readonly cause?: Error,\n ) {\n super(message);\n this.name = \"ECIESError\";\n }\n}\n\n/**\n * Validates if an object conforms to the ECIESEncrypted structure.\n *\n * @param obj - Object to validate.\n * @returns `true` if object is a valid ECIESEncrypted structure.\n *\n * @example\n * ```typescript\n * if (isECIESEncrypted(data)) {\n * const decrypted = await provider.decrypt(privateKey, data);\n * }\n * ```\n */\nexport function isECIESEncrypted(obj: unknown): obj is ECIESEncrypted {\n if (!obj || typeof obj !== \"object\") return false;\n const enc = obj as Record<string, unknown>;\n\n const isUint8Array = (value: unknown): value is Uint8Array => {\n return (\n value instanceof Uint8Array ||\n (typeof Buffer !== \"undefined\" && Buffer.isBuffer(value))\n );\n };\n\n return (\n isUint8Array(enc.iv) &&\n enc.iv.length === CIPHER.IV_LENGTH &&\n isUint8Array(enc.ephemPublicKey) &&\n (enc.ephemPublicKey.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH ||\n enc.ephemPublicKey.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH) &&\n isUint8Array(enc.ciphertext) &&\n enc.ciphertext.length > 0 &&\n isUint8Array(enc.mac) &&\n enc.mac.length === MAC.LENGTH\n );\n}\n\n/**\n * Serializes ECIESEncrypted to hex string for storage or transmission.\n *\n * @param encrypted - Encrypted data structure from `encrypt()`.\n * @returns Hex string representation.\n *\n * @example\n * ```typescript\n * const hexString = serializeECIES(encrypted);\n * // Store hexString in database or send over network\n * ```\n */\nexport function serializeECIES(encrypted: ECIESEncrypted): string {\n const combined = new Uint8Array(\n encrypted.iv.length +\n encrypted.ephemPublicKey.length +\n encrypted.ciphertext.length +\n encrypted.mac.length,\n );\n\n let offset = 0;\n combined.set(encrypted.iv, offset);\n offset += encrypted.iv.length;\n combined.set(encrypted.ephemPublicKey, offset);\n offset += encrypted.ephemPublicKey.length;\n combined.set(encrypted.ciphertext, offset);\n offset += encrypted.ciphertext.length;\n combined.set(encrypted.mac, offset);\n\n return toHex(combined).slice(2);\n}\n\n/**\n * Deserializes hex string to ECIESEncrypted structure.\n *\n * @param hex - Hex string from `serializeECIES()` or storage.\n * @returns ECIESEncrypted structure ready for decryption.\n * @throws {ECIESError} When hex string format is invalid.\n * Verify the hex string is complete and uncorrupted.\n *\n * @example\n * ```typescript\n * const encrypted = deserializeECIES(hexString);\n * const decrypted = await provider.decrypt(privateKey, encrypted);\n * ```\n */\nexport function deserializeECIES(hex: string): ECIESEncrypted {\n const hexWithPrefix = hex.startsWith(\"0x\") ? hex : `0x${hex}`;\n const bytes = fromHex(hexWithPrefix as `0x${string}`, \"bytes\");\n\n // Determine ephemPublicKey size based on prefix\n const ephemKeySize =\n bytes[FORMAT.EPHEMERAL_KEY_OFFSET] === CURVE.PREFIX.UNCOMPRESSED\n ? CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH\n : CURVE.COMPRESSED_PUBLIC_KEY_LENGTH;\n\n const minLength = FORMAT.IV_LENGTH + ephemKeySize + MAC.LENGTH + 1; // +1 for at least 1 byte of ciphertext\n if (bytes.length < minLength) {\n throw new ECIESError(\"Invalid ECIES data: too short\", \"DECRYPTION_FAILED\");\n }\n\n return {\n iv: bytes.subarray(FORMAT.IV_OFFSET, FORMAT.IV_OFFSET + FORMAT.IV_LENGTH),\n ephemPublicKey: bytes.subarray(\n FORMAT.EPHEMERAL_KEY_OFFSET,\n FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize,\n ),\n ciphertext: bytes.subarray(\n FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize,\n bytes.length - MAC.LENGTH,\n ),\n mac: bytes.subarray(bytes.length - MAC.LENGTH),\n };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAcA,uBAA2C;AAC3C,kBAA+B;AA4HxB,MAAM,mBAAmB,MAAM;AAAA,EACpC,YACE,SACgB,MAMS,OACzB;AACA,UAAM,OAAO;AARG;AAMS;AAGzB,SAAK,OAAO;AAAA,EACd;AACF;AAeO,SAAS,iBAAiB,KAAqC;AACpE,MAAI,CAAC,OAAO,OAAO,QAAQ,SAAU,QAAO;AAC5C,QAAM,MAAM;AAEZ,QAAM,eAAe,CAAC,UAAwC;AAC5D,WACE,iBAAiB,cAChB,OAAO,WAAW,eAAe,OAAO,SAAS,KAAK;AAAA,EAE3D;AAEA,SACE,aAAa,IAAI,EAAE,KACnB,IAAI,GAAG,WAAW,wBAAO,aACzB,aAAa,IAAI,cAAc,MAC9B,IAAI,eAAe,WAAW,uBAAM,kCACnC,IAAI,eAAe,WAAW,uBAAM,iCACtC,aAAa,IAAI,UAAU,KAC3B,IAAI,WAAW,SAAS,KACxB,aAAa,IAAI,GAAG,KACpB,IAAI,IAAI,WAAW,qBAAI;AAE3B;AAcO,SAAS,eAAe,WAAmC;AAChE,QAAM,WAAW,IAAI;AAAA,IACnB,UAAU,GAAG,SACX,UAAU,eAAe,SACzB,UAAU,WAAW,SACrB,UAAU,IAAI;AAAA,EAClB;AAEA,MAAI,SAAS;AACb,WAAS,IAAI,UAAU,IAAI,MAAM;AACjC,YAAU,UAAU,GAAG;AACvB,WAAS,IAAI,UAAU,gBAAgB,MAAM;AAC7C,YAAU,UAAU,eAAe;AACnC,WAAS,IAAI,UAAU,YAAY,MAAM;AACzC,YAAU,UAAU,WAAW;AAC/B,WAAS,IAAI,UAAU,KAAK,MAAM;AAElC,aAAO,mBAAM,QAAQ,EAAE,MAAM,CAAC;AAChC;AAgBO,SAAS,iBAAiB,KAA6B;AAC5D,QAAM,gBAAgB,IAAI,WAAW,IAAI,IAAI,MAAM,KAAK,GAAG;AAC3D,QAAM,YAAQ,qBAAQ,eAAgC,OAAO;AAG7D,QAAM,eACJ,MAAM,wBAAO,oBAAoB,MAAM,uBAAM,OAAO,eAChD,uBAAM,iCACN,uBAAM;AAEZ,QAAM,YAAY,wBAAO,YAAY,eAAe,qBAAI,SAAS;AACjE,MAAI,MAAM,SAAS,WAAW;AAC5B,UAAM,IAAI,WAAW,iCAAiC,mBAAmB;AAAA,EAC3E;AAEA,SAAO;AAAA,IACL,IAAI,MAAM,SAAS,wBAAO,WAAW,wBAAO,YAAY,wBAAO,SAAS;AAAA,IACxE,gBAAgB,MAAM;AAAA,MACpB,wBAAO;AAAA,MACP,wBAAO,uBAAuB;AAAA,IAChC;AAAA,IACA,YAAY,MAAM;AAAA,MAChB,wBAAO,uBAAuB;AAAA,MAC9B,MAAM,SAAS,qBAAI;AAAA,IACrB;AAAA,IACA,KAAK,MAAM,SAAS,MAAM,SAAS,qBAAI,MAAM;AAAA,EAC/C;AACF;","names":[]}
@@ -0,0 +1,174 @@
1
+ /**
2
+ * ECIES (Elliptic Curve Integrated Encryption Scheme) Interface
3
+ *
4
+ * @remarks
5
+ * Defines the contract for platform-specific ECIES implementations.
6
+ * All implementations maintain compatibility with the eccrypto format to ensure
7
+ * backward compatibility with existing encrypted data.
8
+ *
9
+ * **Format specification:**
10
+ * `[iv (16 bytes)][ephemPublicKey (65 bytes)][ciphertext (variable)][mac (32 bytes)]`
11
+ *
12
+ * @category Cryptography
13
+ */
14
+ /**
15
+ * Represents ECIES encrypted data in eccrypto-compatible format.
16
+ *
17
+ * @remarks
18
+ * This structure maintains backward compatibility with data encrypted using
19
+ * the legacy eccrypto library.
20
+ */
21
+ export interface ECIESEncrypted {
22
+ /** Initialization vector (16 bytes) */
23
+ iv: Uint8Array;
24
+ /** Ephemeral public key (65 bytes uncompressed) */
25
+ ephemPublicKey: Uint8Array;
26
+ /** Encrypted data */
27
+ ciphertext: Uint8Array;
28
+ /** Message authentication code (32 bytes) */
29
+ mac: Uint8Array;
30
+ }
31
+ /**
32
+ * Provides ECIES encryption and decryption operations.
33
+ *
34
+ * @remarks
35
+ * Platform-specific implementations handle the underlying cryptographic primitives
36
+ * while maintaining consistent data format across environments.
37
+ *
38
+ * @category Cryptography
39
+ */
40
+ export interface ECIESProvider {
41
+ /**
42
+ * Encrypts data using ECIES with secp256k1.
43
+ *
44
+ * @param publicKey - Recipient's public key (65 bytes uncompressed or 33 bytes compressed).
45
+ * Obtain via `vana.server.getIdentity(userAddress).public_key`.
46
+ * @param message - Data to encrypt.
47
+ * @returns Encrypted data structure compatible with eccrypto format.
48
+ * @throws {ECIESError} When public key is invalid.
49
+ * Verify key format matches secp256k1 requirements.
50
+ *
51
+ * @example
52
+ * ```typescript
53
+ * const encrypted = await provider.encrypt(
54
+ * fromHex(publicKey, 'bytes'),
55
+ * new TextEncoder().encode('sensitive data')
56
+ * );
57
+ * ```
58
+ */
59
+ encrypt(publicKey: Uint8Array, message: Uint8Array): Promise<ECIESEncrypted>;
60
+ /**
61
+ * Decrypts ECIES encrypted data.
62
+ *
63
+ * @param privateKey - Recipient's private key (32 bytes).
64
+ * @param encrypted - Encrypted data structure from `encrypt()` or legacy eccrypto.
65
+ * @returns Decrypted message as Uint8Array.
66
+ * @throws {ECIESError} When MAC verification fails.
67
+ * Ensure the private key matches the public key used for encryption.
68
+ *
69
+ * @example
70
+ * ```typescript
71
+ * const decrypted = await provider.decrypt(
72
+ * fromHex(privateKey, 'bytes'),
73
+ * encrypted
74
+ * );
75
+ * const message = new TextDecoder().decode(decrypted);
76
+ * ```
77
+ */
78
+ decrypt(privateKey: Uint8Array, encrypted: ECIESEncrypted): Promise<Uint8Array>;
79
+ /**
80
+ * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).
81
+ *
82
+ * @remarks
83
+ * Strict policy: Only accepts properly formatted compressed (33 bytes) or
84
+ * uncompressed (65 bytes) public keys. Does not accept 64-byte raw coordinates
85
+ * to ensure data integrity and prevent masking of malformed inputs.
86
+ *
87
+ * @param publicKey - Public key in compressed or uncompressed format
88
+ * @returns Normalized uncompressed public key (65 bytes with 0x04 prefix)
89
+ * @throws {Error} When public key format is invalid, including raw coordinates (64 bytes)
90
+ * @throws {Error} When decompression of compressed key fails
91
+ *
92
+ * @example
93
+ * ```typescript
94
+ * // Compressed key (33 bytes)
95
+ * const compressed = new Uint8Array(33);
96
+ * compressed[0] = 0x02;
97
+ * const uncompressed = provider.normalizeToUncompressed(compressed);
98
+ * console.log(uncompressed.length); // 65
99
+ * console.log(uncompressed[0]); // 0x04
100
+ *
101
+ * // Already uncompressed (65 bytes)
102
+ * const already = provider.normalizeToUncompressed(uncompressedKey);
103
+ * console.log(already === uncompressedKey); // true (returns same reference)
104
+ *
105
+ * // Raw coordinates rejected (64 bytes)
106
+ * const raw = new Uint8Array(64);
107
+ * provider.normalizeToUncompressed(raw); // Throws error
108
+ * ```
109
+ */
110
+ normalizeToUncompressed(publicKey: Uint8Array): Uint8Array;
111
+ }
112
+ /**
113
+ * Configures ECIES operation behavior.
114
+ */
115
+ export interface ECIESOptions {
116
+ /** Use compressed public keys (33 bytes) instead of uncompressed (65 bytes) */
117
+ useCompressed?: boolean;
118
+ }
119
+ /**
120
+ * Represents failures in ECIES cryptographic operations.
121
+ *
122
+ * @remarks
123
+ * Provides specific error codes to help identify and recover from
124
+ * different failure scenarios.
125
+ *
126
+ * @category Errors
127
+ */
128
+ export declare class ECIESError extends Error {
129
+ readonly code: "INVALID_KEY" | "ENCRYPTION_FAILED" | "DECRYPTION_FAILED" | "MAC_MISMATCH" | "ECDH_FAILED";
130
+ readonly cause?: Error | undefined;
131
+ constructor(message: string, code: "INVALID_KEY" | "ENCRYPTION_FAILED" | "DECRYPTION_FAILED" | "MAC_MISMATCH" | "ECDH_FAILED", cause?: Error | undefined);
132
+ }
133
+ /**
134
+ * Validates if an object conforms to the ECIESEncrypted structure.
135
+ *
136
+ * @param obj - Object to validate.
137
+ * @returns `true` if object is a valid ECIESEncrypted structure.
138
+ *
139
+ * @example
140
+ * ```typescript
141
+ * if (isECIESEncrypted(data)) {
142
+ * const decrypted = await provider.decrypt(privateKey, data);
143
+ * }
144
+ * ```
145
+ */
146
+ export declare function isECIESEncrypted(obj: unknown): obj is ECIESEncrypted;
147
+ /**
148
+ * Serializes ECIESEncrypted to hex string for storage or transmission.
149
+ *
150
+ * @param encrypted - Encrypted data structure from `encrypt()`.
151
+ * @returns Hex string representation.
152
+ *
153
+ * @example
154
+ * ```typescript
155
+ * const hexString = serializeECIES(encrypted);
156
+ * // Store hexString in database or send over network
157
+ * ```
158
+ */
159
+ export declare function serializeECIES(encrypted: ECIESEncrypted): string;
160
+ /**
161
+ * Deserializes hex string to ECIESEncrypted structure.
162
+ *
163
+ * @param hex - Hex string from `serializeECIES()` or storage.
164
+ * @returns ECIESEncrypted structure ready for decryption.
165
+ * @throws {ECIESError} When hex string format is invalid.
166
+ * Verify the hex string is complete and uncorrupted.
167
+ *
168
+ * @example
169
+ * ```typescript
170
+ * const encrypted = deserializeECIES(hexString);
171
+ * const decrypted = await provider.decrypt(privateKey, encrypted);
172
+ * ```
173
+ */
174
+ export declare function deserializeECIES(hex: string): ECIESEncrypted;
@@ -0,0 +1,60 @@
1
+ import { CIPHER, CURVE, MAC, FORMAT } from "./constants";
2
+ import { fromHex, toHex } from "viem";
3
+ class ECIESError extends Error {
4
+ constructor(message, code, cause) {
5
+ super(message);
6
+ this.code = code;
7
+ this.cause = cause;
8
+ this.name = "ECIESError";
9
+ }
10
+ }
11
+ function isECIESEncrypted(obj) {
12
+ if (!obj || typeof obj !== "object") return false;
13
+ const enc = obj;
14
+ const isUint8Array = (value) => {
15
+ return value instanceof Uint8Array || typeof Buffer !== "undefined" && Buffer.isBuffer(value);
16
+ };
17
+ return isUint8Array(enc.iv) && enc.iv.length === CIPHER.IV_LENGTH && isUint8Array(enc.ephemPublicKey) && (enc.ephemPublicKey.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH || enc.ephemPublicKey.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH) && isUint8Array(enc.ciphertext) && enc.ciphertext.length > 0 && isUint8Array(enc.mac) && enc.mac.length === MAC.LENGTH;
18
+ }
19
+ function serializeECIES(encrypted) {
20
+ const combined = new Uint8Array(
21
+ encrypted.iv.length + encrypted.ephemPublicKey.length + encrypted.ciphertext.length + encrypted.mac.length
22
+ );
23
+ let offset = 0;
24
+ combined.set(encrypted.iv, offset);
25
+ offset += encrypted.iv.length;
26
+ combined.set(encrypted.ephemPublicKey, offset);
27
+ offset += encrypted.ephemPublicKey.length;
28
+ combined.set(encrypted.ciphertext, offset);
29
+ offset += encrypted.ciphertext.length;
30
+ combined.set(encrypted.mac, offset);
31
+ return toHex(combined).slice(2);
32
+ }
33
+ function deserializeECIES(hex) {
34
+ const hexWithPrefix = hex.startsWith("0x") ? hex : `0x${hex}`;
35
+ const bytes = fromHex(hexWithPrefix, "bytes");
36
+ const ephemKeySize = bytes[FORMAT.EPHEMERAL_KEY_OFFSET] === CURVE.PREFIX.UNCOMPRESSED ? CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH : CURVE.COMPRESSED_PUBLIC_KEY_LENGTH;
37
+ const minLength = FORMAT.IV_LENGTH + ephemKeySize + MAC.LENGTH + 1;
38
+ if (bytes.length < minLength) {
39
+ throw new ECIESError("Invalid ECIES data: too short", "DECRYPTION_FAILED");
40
+ }
41
+ return {
42
+ iv: bytes.subarray(FORMAT.IV_OFFSET, FORMAT.IV_OFFSET + FORMAT.IV_LENGTH),
43
+ ephemPublicKey: bytes.subarray(
44
+ FORMAT.EPHEMERAL_KEY_OFFSET,
45
+ FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize
46
+ ),
47
+ ciphertext: bytes.subarray(
48
+ FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize,
49
+ bytes.length - MAC.LENGTH
50
+ ),
51
+ mac: bytes.subarray(bytes.length - MAC.LENGTH)
52
+ };
53
+ }
54
+ export {
55
+ ECIESError,
56
+ deserializeECIES,
57
+ isECIESEncrypted,
58
+ serializeECIES
59
+ };
60
+ //# sourceMappingURL=interface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/interface.ts"],"sourcesContent":["/**\n * ECIES (Elliptic Curve Integrated Encryption Scheme) Interface\n *\n * @remarks\n * Defines the contract for platform-specific ECIES implementations.\n * All implementations maintain compatibility with the eccrypto format to ensure\n * backward compatibility with existing encrypted data.\n *\n * **Format specification:**\n * `[iv (16 bytes)][ephemPublicKey (65 bytes)][ciphertext (variable)][mac (32 bytes)]`\n *\n * @category Cryptography\n */\n\nimport { CIPHER, CURVE, MAC, FORMAT } from \"./constants\";\nimport { fromHex, toHex } from \"viem\";\n\n/**\n * Represents ECIES encrypted data in eccrypto-compatible format.\n *\n * @remarks\n * This structure maintains backward compatibility with data encrypted using\n * the legacy eccrypto library.\n */\nexport interface ECIESEncrypted {\n /** Initialization vector (16 bytes) */\n iv: Uint8Array;\n /** Ephemeral public key (65 bytes uncompressed) */\n ephemPublicKey: Uint8Array;\n /** Encrypted data */\n ciphertext: Uint8Array;\n /** Message authentication code (32 bytes) */\n mac: Uint8Array;\n}\n\n/**\n * Provides ECIES encryption and decryption operations.\n *\n * @remarks\n * Platform-specific implementations handle the underlying cryptographic primitives\n * while maintaining consistent data format across environments.\n *\n * @category Cryptography\n */\nexport interface ECIESProvider {\n /**\n * Encrypts data using ECIES with secp256k1.\n *\n * @param publicKey - Recipient's public key (65 bytes uncompressed or 33 bytes compressed).\n * Obtain via `vana.server.getIdentity(userAddress).public_key`.\n * @param message - Data to encrypt.\n * @returns Encrypted data structure compatible with eccrypto format.\n * @throws {ECIESError} When public key is invalid.\n * Verify key format matches secp256k1 requirements.\n *\n * @example\n * ```typescript\n * const encrypted = await provider.encrypt(\n * fromHex(publicKey, 'bytes'),\n * new TextEncoder().encode('sensitive data')\n * );\n * ```\n */\n encrypt(publicKey: Uint8Array, message: Uint8Array): Promise<ECIESEncrypted>;\n\n /**\n * Decrypts ECIES encrypted data.\n *\n * @param privateKey - Recipient's private key (32 bytes).\n * @param encrypted - Encrypted data structure from `encrypt()` or legacy eccrypto.\n * @returns Decrypted message as Uint8Array.\n * @throws {ECIESError} When MAC verification fails.\n * Ensure the private key matches the public key used for encryption.\n *\n * @example\n * ```typescript\n * const decrypted = await provider.decrypt(\n * fromHex(privateKey, 'bytes'),\n * encrypted\n * );\n * const message = new TextDecoder().decode(decrypted);\n * ```\n */\n decrypt(\n privateKey: Uint8Array,\n encrypted: ECIESEncrypted,\n ): Promise<Uint8Array>;\n\n /**\n * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).\n *\n * @remarks\n * Strict policy: Only accepts properly formatted compressed (33 bytes) or\n * uncompressed (65 bytes) public keys. Does not accept 64-byte raw coordinates\n * to ensure data integrity and prevent masking of malformed inputs.\n *\n * @param publicKey - Public key in compressed or uncompressed format\n * @returns Normalized uncompressed public key (65 bytes with 0x04 prefix)\n * @throws {Error} When public key format is invalid, including raw coordinates (64 bytes)\n * @throws {Error} When decompression of compressed key fails\n *\n * @example\n * ```typescript\n * // Compressed key (33 bytes)\n * const compressed = new Uint8Array(33);\n * compressed[0] = 0x02;\n * const uncompressed = provider.normalizeToUncompressed(compressed);\n * console.log(uncompressed.length); // 65\n * console.log(uncompressed[0]); // 0x04\n *\n * // Already uncompressed (65 bytes)\n * const already = provider.normalizeToUncompressed(uncompressedKey);\n * console.log(already === uncompressedKey); // true (returns same reference)\n *\n * // Raw coordinates rejected (64 bytes)\n * const raw = new Uint8Array(64);\n * provider.normalizeToUncompressed(raw); // Throws error\n * ```\n */\n normalizeToUncompressed(publicKey: Uint8Array): Uint8Array;\n}\n\n/**\n * Configures ECIES operation behavior.\n */\nexport interface ECIESOptions {\n /** Use compressed public keys (33 bytes) instead of uncompressed (65 bytes) */\n useCompressed?: boolean;\n}\n\n/**\n * Represents failures in ECIES cryptographic operations.\n *\n * @remarks\n * Provides specific error codes to help identify and recover from\n * different failure scenarios.\n *\n * @category Errors\n */\nexport class ECIESError extends Error {\n constructor(\n message: string,\n public readonly code:\n | \"INVALID_KEY\"\n | \"ENCRYPTION_FAILED\"\n | \"DECRYPTION_FAILED\"\n | \"MAC_MISMATCH\"\n | \"ECDH_FAILED\",\n public override readonly cause?: Error,\n ) {\n super(message);\n this.name = \"ECIESError\";\n }\n}\n\n/**\n * Validates if an object conforms to the ECIESEncrypted structure.\n *\n * @param obj - Object to validate.\n * @returns `true` if object is a valid ECIESEncrypted structure.\n *\n * @example\n * ```typescript\n * if (isECIESEncrypted(data)) {\n * const decrypted = await provider.decrypt(privateKey, data);\n * }\n * ```\n */\nexport function isECIESEncrypted(obj: unknown): obj is ECIESEncrypted {\n if (!obj || typeof obj !== \"object\") return false;\n const enc = obj as Record<string, unknown>;\n\n const isUint8Array = (value: unknown): value is Uint8Array => {\n return (\n value instanceof Uint8Array ||\n (typeof Buffer !== \"undefined\" && Buffer.isBuffer(value))\n );\n };\n\n return (\n isUint8Array(enc.iv) &&\n enc.iv.length === CIPHER.IV_LENGTH &&\n isUint8Array(enc.ephemPublicKey) &&\n (enc.ephemPublicKey.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH ||\n enc.ephemPublicKey.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH) &&\n isUint8Array(enc.ciphertext) &&\n enc.ciphertext.length > 0 &&\n isUint8Array(enc.mac) &&\n enc.mac.length === MAC.LENGTH\n );\n}\n\n/**\n * Serializes ECIESEncrypted to hex string for storage or transmission.\n *\n * @param encrypted - Encrypted data structure from `encrypt()`.\n * @returns Hex string representation.\n *\n * @example\n * ```typescript\n * const hexString = serializeECIES(encrypted);\n * // Store hexString in database or send over network\n * ```\n */\nexport function serializeECIES(encrypted: ECIESEncrypted): string {\n const combined = new Uint8Array(\n encrypted.iv.length +\n encrypted.ephemPublicKey.length +\n encrypted.ciphertext.length +\n encrypted.mac.length,\n );\n\n let offset = 0;\n combined.set(encrypted.iv, offset);\n offset += encrypted.iv.length;\n combined.set(encrypted.ephemPublicKey, offset);\n offset += encrypted.ephemPublicKey.length;\n combined.set(encrypted.ciphertext, offset);\n offset += encrypted.ciphertext.length;\n combined.set(encrypted.mac, offset);\n\n return toHex(combined).slice(2);\n}\n\n/**\n * Deserializes hex string to ECIESEncrypted structure.\n *\n * @param hex - Hex string from `serializeECIES()` or storage.\n * @returns ECIESEncrypted structure ready for decryption.\n * @throws {ECIESError} When hex string format is invalid.\n * Verify the hex string is complete and uncorrupted.\n *\n * @example\n * ```typescript\n * const encrypted = deserializeECIES(hexString);\n * const decrypted = await provider.decrypt(privateKey, encrypted);\n * ```\n */\nexport function deserializeECIES(hex: string): ECIESEncrypted {\n const hexWithPrefix = hex.startsWith(\"0x\") ? hex : `0x${hex}`;\n const bytes = fromHex(hexWithPrefix as `0x${string}`, \"bytes\");\n\n // Determine ephemPublicKey size based on prefix\n const ephemKeySize =\n bytes[FORMAT.EPHEMERAL_KEY_OFFSET] === CURVE.PREFIX.UNCOMPRESSED\n ? CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH\n : CURVE.COMPRESSED_PUBLIC_KEY_LENGTH;\n\n const minLength = FORMAT.IV_LENGTH + ephemKeySize + MAC.LENGTH + 1; // +1 for at least 1 byte of ciphertext\n if (bytes.length < minLength) {\n throw new ECIESError(\"Invalid ECIES data: too short\", \"DECRYPTION_FAILED\");\n }\n\n return {\n iv: bytes.subarray(FORMAT.IV_OFFSET, FORMAT.IV_OFFSET + FORMAT.IV_LENGTH),\n ephemPublicKey: bytes.subarray(\n FORMAT.EPHEMERAL_KEY_OFFSET,\n FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize,\n ),\n ciphertext: bytes.subarray(\n FORMAT.EPHEMERAL_KEY_OFFSET + ephemKeySize,\n bytes.length - MAC.LENGTH,\n ),\n mac: bytes.subarray(bytes.length - MAC.LENGTH),\n };\n}\n"],"mappings":"AAcA,SAAS,QAAQ,OAAO,KAAK,cAAc;AAC3C,SAAS,SAAS,aAAa;AA4HxB,MAAM,mBAAmB,MAAM;AAAA,EACpC,YACE,SACgB,MAMS,OACzB;AACA,UAAM,OAAO;AARG;AAMS;AAGzB,SAAK,OAAO;AAAA,EACd;AACF;AAeO,SAAS,iBAAiB,KAAqC;AACpE,MAAI,CAAC,OAAO,OAAO,QAAQ,SAAU,QAAO;AAC5C,QAAM,MAAM;AAEZ,QAAM,eAAe,CAAC,UAAwC;AAC5D,WACE,iBAAiB,cAChB,OAAO,WAAW,eAAe,OAAO,SAAS,KAAK;AAAA,EAE3D;AAEA,SACE,aAAa,IAAI,EAAE,KACnB,IAAI,GAAG,WAAW,OAAO,aACzB,aAAa,IAAI,cAAc,MAC9B,IAAI,eAAe,WAAW,MAAM,kCACnC,IAAI,eAAe,WAAW,MAAM,iCACtC,aAAa,IAAI,UAAU,KAC3B,IAAI,WAAW,SAAS,KACxB,aAAa,IAAI,GAAG,KACpB,IAAI,IAAI,WAAW,IAAI;AAE3B;AAcO,SAAS,eAAe,WAAmC;AAChE,QAAM,WAAW,IAAI;AAAA,IACnB,UAAU,GAAG,SACX,UAAU,eAAe,SACzB,UAAU,WAAW,SACrB,UAAU,IAAI;AAAA,EAClB;AAEA,MAAI,SAAS;AACb,WAAS,IAAI,UAAU,IAAI,MAAM;AACjC,YAAU,UAAU,GAAG;AACvB,WAAS,IAAI,UAAU,gBAAgB,MAAM;AAC7C,YAAU,UAAU,eAAe;AACnC,WAAS,IAAI,UAAU,YAAY,MAAM;AACzC,YAAU,UAAU,WAAW;AAC/B,WAAS,IAAI,UAAU,KAAK,MAAM;AAElC,SAAO,MAAM,QAAQ,EAAE,MAAM,CAAC;AAChC;AAgBO,SAAS,iBAAiB,KAA6B;AAC5D,QAAM,gBAAgB,IAAI,WAAW,IAAI,IAAI,MAAM,KAAK,GAAG;AAC3D,QAAM,QAAQ,QAAQ,eAAgC,OAAO;AAG7D,QAAM,eACJ,MAAM,OAAO,oBAAoB,MAAM,MAAM,OAAO,eAChD,MAAM,iCACN,MAAM;AAEZ,QAAM,YAAY,OAAO,YAAY,eAAe,IAAI,SAAS;AACjE,MAAI,MAAM,SAAS,WAAW;AAC5B,UAAM,IAAI,WAAW,iCAAiC,mBAAmB;AAAA,EAC3E;AAEA,SAAO;AAAA,IACL,IAAI,MAAM,SAAS,OAAO,WAAW,OAAO,YAAY,OAAO,SAAS;AAAA,IACxE,gBAAgB,MAAM;AAAA,MACpB,OAAO;AAAA,MACP,OAAO,uBAAuB;AAAA,IAChC;AAAA,IACA,YAAY,MAAM;AAAA,MAChB,OAAO,uBAAuB;AAAA,MAC9B,MAAM,SAAS,IAAI;AAAA,IACrB;AAAA,IACA,KAAK,MAAM,SAAS,MAAM,SAAS,IAAI,MAAM;AAAA,EAC/C;AACF;","names":[]}