@opendatalabs/vana-sdk 0.1.0-alpha.e2e45dd → 0.1.0-alpha.e2f8234

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 (992) hide show
  1. package/README.md +67 -300
  2. package/dist/__tests__/waitForTransactionEvents.test.d.ts +1 -0
  3. package/dist/browser.cjs +29 -0
  4. package/dist/browser.cjs.map +1 -0
  5. package/dist/browser.d.ts +36 -1
  6. package/dist/browser.js +1 -290
  7. package/dist/browser.js.map +1 -1
  8. package/dist/{chains.browser.cjs → chains/definitions.cjs} +16 -17
  9. package/dist/chains/definitions.cjs.map +1 -0
  10. package/dist/{chains.browser.d.cts → chains/definitions.d.ts} +9 -11
  11. package/dist/chains/definitions.js +67 -0
  12. package/dist/chains/definitions.js.map +1 -0
  13. package/dist/chains/index.cjs +37 -0
  14. package/dist/chains/index.cjs.map +1 -0
  15. package/dist/chains/index.d.ts +34 -0
  16. package/dist/chains/index.js +15 -0
  17. package/dist/chains/index.js.map +1 -0
  18. package/dist/chains.browser.d.ts +5 -50
  19. package/dist/chains.browser.js +7 -57
  20. package/dist/chains.browser.js.map +1 -1
  21. package/dist/chains.cjs +6 -65
  22. package/dist/chains.cjs.map +1 -1
  23. package/dist/chains.d.ts +8 -2
  24. package/dist/chains.js +7 -57
  25. package/dist/chains.js.map +1 -1
  26. package/dist/chains.node.cjs +6 -65
  27. package/dist/chains.node.cjs.map +1 -1
  28. package/dist/chains.node.d.ts +8 -2
  29. package/dist/chains.node.js +7 -57
  30. package/dist/chains.node.js.map +1 -1
  31. package/dist/client/__tests__/enhancedResponse.test.d.ts +1 -0
  32. package/dist/client/enhancedResponse.cjs +164 -0
  33. package/dist/client/enhancedResponse.cjs.map +1 -0
  34. package/dist/client/enhancedResponse.d.ts +120 -0
  35. package/dist/client/enhancedResponse.js +138 -0
  36. package/dist/client/enhancedResponse.js.map +1 -0
  37. package/dist/config/chains.cjs +93 -0
  38. package/dist/config/chains.cjs.map +1 -0
  39. package/dist/config/chains.d.ts +180 -0
  40. package/dist/config/chains.js +67 -0
  41. package/dist/config/chains.js.map +1 -0
  42. package/dist/config/contracts.config.cjs +400 -0
  43. package/dist/config/contracts.config.cjs.map +1 -0
  44. package/dist/config/contracts.config.d.ts +84 -0
  45. package/dist/config/contracts.config.js +375 -0
  46. package/dist/config/contracts.config.js.map +1 -0
  47. package/dist/config/default-services.cjs +60 -0
  48. package/dist/config/default-services.cjs.map +1 -0
  49. package/dist/config/default-services.d.ts +46 -0
  50. package/dist/config/default-services.js +33 -0
  51. package/dist/config/default-services.js.map +1 -0
  52. package/dist/config/default-services.test.d.ts +1 -0
  53. package/dist/config/features.cjs +52 -0
  54. package/dist/config/features.cjs.map +1 -0
  55. package/dist/config/features.d.ts +62 -0
  56. package/dist/config/features.js +28 -0
  57. package/dist/config/features.js.map +1 -0
  58. package/dist/config/tests/addresses.test.d.ts +1 -0
  59. package/dist/contracts/contractController.cjs +126 -0
  60. package/dist/contracts/contractController.cjs.map +1 -0
  61. package/dist/contracts/contractController.d.ts +135 -0
  62. package/dist/contracts/contractController.js +100 -0
  63. package/dist/contracts/contractController.js.map +1 -0
  64. package/dist/contracts/tests/contractController.test.d.ts +1 -0
  65. package/dist/controllers/__tests__/data-consistency-integration.test.d.ts +7 -0
  66. package/dist/controllers/__tests__/operations.processQueue.test.d.ts +1 -0
  67. package/dist/controllers/__tests__/schemas-edge-cases.test.d.ts +1 -0
  68. package/dist/controllers/accessSettlement.cjs +289 -0
  69. package/dist/controllers/accessSettlement.cjs.map +1 -0
  70. package/dist/controllers/accessSettlement.d.ts +157 -0
  71. package/dist/controllers/accessSettlement.js +265 -0
  72. package/dist/controllers/accessSettlement.js.map +1 -0
  73. package/dist/controllers/accessSettlement.test.d.ts +1 -0
  74. package/dist/controllers/base.cjs +116 -0
  75. package/dist/controllers/base.cjs.map +1 -0
  76. package/dist/controllers/base.d.ts +94 -0
  77. package/dist/controllers/base.js +92 -0
  78. package/dist/controllers/base.js.map +1 -0
  79. package/dist/controllers/data-error-handling.test.d.ts +1 -0
  80. package/dist/controllers/data.cjs +2633 -0
  81. package/dist/controllers/data.cjs.map +1 -0
  82. package/dist/controllers/data.d.ts +1067 -0
  83. package/dist/controllers/data.js +2626 -0
  84. package/dist/controllers/data.js.map +1 -0
  85. package/dist/controllers/operations.cjs +430 -0
  86. package/dist/controllers/operations.cjs.map +1 -0
  87. package/dist/controllers/operations.d.ts +229 -0
  88. package/dist/controllers/operations.js +406 -0
  89. package/dist/controllers/operations.js.map +1 -0
  90. package/dist/controllers/permissions.cjs +4363 -0
  91. package/dist/controllers/permissions.cjs.map +1 -0
  92. package/dist/controllers/permissions.d.ts +1411 -0
  93. package/dist/controllers/permissions.js +4339 -0
  94. package/dist/controllers/permissions.js.map +1 -0
  95. package/dist/controllers/protocol.cjs +183 -0
  96. package/dist/controllers/protocol.cjs.map +1 -0
  97. package/dist/controllers/protocol.d.ts +138 -0
  98. package/dist/controllers/protocol.js +163 -0
  99. package/dist/controllers/protocol.js.map +1 -0
  100. package/dist/controllers/runtimePermissions.cjs +285 -0
  101. package/dist/controllers/runtimePermissions.cjs.map +1 -0
  102. package/dist/controllers/runtimePermissions.d.ts +152 -0
  103. package/dist/controllers/runtimePermissions.js +264 -0
  104. package/dist/controllers/runtimePermissions.js.map +1 -0
  105. package/dist/controllers/runtimePermissions.test.d.ts +1 -0
  106. package/dist/controllers/schemas.cjs +678 -0
  107. package/dist/controllers/schemas.cjs.map +1 -0
  108. package/dist/controllers/schemas.d.ts +293 -0
  109. package/dist/controllers/schemas.js +654 -0
  110. package/dist/controllers/schemas.js.map +1 -0
  111. package/dist/controllers/server-additional.test.d.ts +1 -0
  112. package/dist/controllers/server.cjs +643 -0
  113. package/dist/controllers/server.cjs.map +1 -0
  114. package/dist/controllers/server.d.ts +322 -0
  115. package/dist/controllers/server.js +624 -0
  116. package/dist/controllers/server.js.map +1 -0
  117. package/dist/core/__tests__/health.test.d.ts +1 -0
  118. package/dist/core/__tests__/inMemoryNonceManager.test.d.ts +1 -0
  119. package/dist/core/__tests__/nonceManager.test.d.ts +1 -0
  120. package/dist/core/__tests__/pollingManager.test.d.ts +4 -0
  121. package/dist/core/apiClient.cjs +378 -0
  122. package/dist/core/apiClient.cjs.map +1 -0
  123. package/dist/core/apiClient.d.ts +286 -0
  124. package/dist/core/apiClient.js +359 -0
  125. package/dist/core/apiClient.js.map +1 -0
  126. package/dist/core/client.cjs +70 -0
  127. package/dist/core/client.cjs.map +1 -0
  128. package/dist/core/client.d.ts +89 -0
  129. package/dist/core/client.js +47 -0
  130. package/dist/core/client.js.map +1 -0
  131. package/dist/core/core.test.d.ts +1 -0
  132. package/dist/core/generics.cjs +417 -0
  133. package/dist/core/generics.cjs.map +1 -0
  134. package/dist/core/generics.d.ts +205 -0
  135. package/dist/core/generics.js +386 -0
  136. package/dist/core/generics.js.map +1 -0
  137. package/dist/core/health.cjs +289 -0
  138. package/dist/core/health.cjs.map +1 -0
  139. package/dist/core/health.d.ts +143 -0
  140. package/dist/core/health.js +265 -0
  141. package/dist/core/health.js.map +1 -0
  142. package/dist/core/inMemoryNonceManager.cjs +138 -0
  143. package/dist/core/inMemoryNonceManager.cjs.map +1 -0
  144. package/dist/core/inMemoryNonceManager.d.ts +69 -0
  145. package/dist/core/inMemoryNonceManager.js +114 -0
  146. package/dist/core/inMemoryNonceManager.js.map +1 -0
  147. package/dist/core/nonceManager.cjs +304 -0
  148. package/dist/core/nonceManager.cjs.map +1 -0
  149. package/dist/core/nonceManager.d.ts +116 -0
  150. package/dist/core/nonceManager.js +280 -0
  151. package/dist/core/nonceManager.js.map +1 -0
  152. package/dist/core/pollingManager.cjs +292 -0
  153. package/dist/core/pollingManager.cjs.map +1 -0
  154. package/dist/core/pollingManager.d.ts +120 -0
  155. package/dist/core/pollingManager.js +268 -0
  156. package/dist/core/pollingManager.js.map +1 -0
  157. package/dist/core/tests/apiClient.test.d.ts +1 -0
  158. package/dist/core/tests/client.test.d.ts +1 -0
  159. package/dist/core/tests/generics.test.d.ts +1 -0
  160. package/dist/core.cjs +785 -0
  161. package/dist/core.cjs.map +1 -0
  162. package/dist/core.d.ts +499 -0
  163. package/dist/core.js +760 -0
  164. package/dist/core.js.map +1 -0
  165. package/dist/crypto/ecies/__tests__/base.test.d.ts +4 -0
  166. package/dist/crypto/ecies/__tests__/compatibility.test.d.ts +8 -0
  167. package/dist/crypto/ecies/__tests__/constants.test.d.ts +4 -0
  168. package/dist/crypto/ecies/__tests__/interface.test.d.ts +1 -0
  169. package/dist/crypto/ecies/__tests__/native-parity.test.d.ts +7 -0
  170. package/dist/crypto/ecies/__tests__/normalization.test.d.ts +1 -0
  171. package/dist/crypto/ecies/__tests__/serialization.test.d.ts +8 -0
  172. package/dist/crypto/ecies/__tests__/test-vectors.cjs +102 -0
  173. package/dist/crypto/ecies/__tests__/test-vectors.cjs.map +1 -0
  174. package/dist/crypto/ecies/__tests__/test-vectors.d.ts +38 -0
  175. package/dist/crypto/ecies/__tests__/test-vectors.js +77 -0
  176. package/dist/crypto/ecies/__tests__/test-vectors.js.map +1 -0
  177. package/dist/crypto/ecies/__tests__/utils.test.d.ts +1 -0
  178. package/dist/crypto/ecies/base.cjs +268 -0
  179. package/dist/crypto/ecies/base.cjs.map +1 -0
  180. package/dist/crypto/ecies/base.d.ts +140 -0
  181. package/dist/crypto/ecies/base.js +244 -0
  182. package/dist/crypto/ecies/base.js.map +1 -0
  183. package/dist/crypto/ecies/browser.cjs +165 -0
  184. package/dist/crypto/ecies/browser.cjs.map +1 -0
  185. package/dist/crypto/ecies/browser.d.ts +43 -0
  186. package/dist/crypto/ecies/browser.js +131 -0
  187. package/dist/crypto/ecies/browser.js.map +1 -0
  188. package/dist/crypto/ecies/constants.cjs +123 -0
  189. package/dist/crypto/ecies/constants.cjs.map +1 -0
  190. package/dist/crypto/ecies/constants.d.ts +111 -0
  191. package/dist/crypto/ecies/constants.js +94 -0
  192. package/dist/crypto/ecies/constants.js.map +1 -0
  193. package/dist/crypto/ecies/index.cjs +35 -0
  194. package/dist/crypto/ecies/index.cjs.map +1 -0
  195. package/dist/crypto/ecies/index.d.ts +8 -0
  196. package/dist/crypto/ecies/index.js +13 -0
  197. package/dist/crypto/ecies/index.js.map +1 -0
  198. package/dist/crypto/ecies/interface.cjs +104 -0
  199. package/dist/crypto/ecies/interface.cjs.map +1 -0
  200. package/dist/crypto/ecies/interface.d.ts +174 -0
  201. package/dist/crypto/ecies/interface.js +77 -0
  202. package/dist/crypto/ecies/interface.js.map +1 -0
  203. package/dist/crypto/ecies/node.cjs +167 -0
  204. package/dist/crypto/ecies/node.cjs.map +1 -0
  205. package/dist/crypto/ecies/node.d.ts +45 -0
  206. package/dist/crypto/ecies/node.js +139 -0
  207. package/dist/crypto/ecies/node.js.map +1 -0
  208. package/dist/crypto/ecies/test-vectors/eccrypto-vectors.json +72 -0
  209. package/dist/crypto/ecies/utils.cjs +52 -0
  210. package/dist/crypto/ecies/utils.cjs.map +1 -0
  211. package/dist/crypto/ecies/utils.d.ts +30 -0
  212. package/dist/crypto/ecies/utils.js +26 -0
  213. package/dist/crypto/ecies/utils.js.map +1 -0
  214. package/dist/crypto/services/WalletKeyEncryptionService.cjs +128 -0
  215. package/dist/crypto/services/WalletKeyEncryptionService.cjs.map +1 -0
  216. package/dist/crypto/services/WalletKeyEncryptionService.d.ts +88 -0
  217. package/dist/crypto/services/WalletKeyEncryptionService.js +108 -0
  218. package/dist/crypto/services/WalletKeyEncryptionService.js.map +1 -0
  219. package/dist/crypto/services/WalletKeyEncryptionService.test.d.ts +1 -0
  220. package/dist/diagnostics.cjs +37 -0
  221. package/dist/diagnostics.cjs.map +1 -0
  222. package/dist/diagnostics.d.ts +24 -0
  223. package/dist/diagnostics.js +13 -0
  224. package/dist/diagnostics.js.map +1 -0
  225. package/dist/diagnostics.test.d.ts +1 -0
  226. package/dist/errors.cjs +186 -0
  227. package/dist/errors.cjs.map +1 -0
  228. package/dist/errors.d.ts +452 -0
  229. package/dist/errors.js +148 -0
  230. package/dist/errors.js.map +1 -0
  231. package/dist/generated/abi/AccessSettlementImplementation.cjs +635 -0
  232. package/dist/generated/abi/AccessSettlementImplementation.cjs.map +1 -0
  233. package/dist/generated/abi/AccessSettlementImplementation.d.ts +468 -0
  234. package/dist/generated/abi/AccessSettlementImplementation.js +611 -0
  235. package/dist/generated/abi/AccessSettlementImplementation.js.map +1 -0
  236. package/dist/generated/abi/AttestationPolicyImplementation.cjs +614 -0
  237. package/dist/generated/abi/AttestationPolicyImplementation.cjs.map +1 -0
  238. package/dist/generated/abi/AttestationPolicyImplementation.d.ts +449 -0
  239. package/dist/generated/abi/AttestationPolicyImplementation.js +590 -0
  240. package/dist/generated/abi/AttestationPolicyImplementation.js.map +1 -0
  241. package/dist/generated/abi/ComputeEngineImplementation.cjs +1313 -0
  242. package/dist/generated/abi/ComputeEngineImplementation.cjs.map +1 -0
  243. package/dist/generated/abi/ComputeEngineImplementation.d.ts +995 -0
  244. package/dist/generated/abi/ComputeEngineImplementation.js +1289 -0
  245. package/dist/generated/abi/ComputeEngineImplementation.js.map +1 -0
  246. package/dist/generated/abi/ComputeEngineTreasuryImplementation.cjs +536 -0
  247. package/dist/generated/abi/ComputeEngineTreasuryImplementation.cjs.map +1 -0
  248. package/dist/generated/abi/ComputeEngineTreasuryImplementation.d.ts +393 -0
  249. package/dist/generated/abi/ComputeEngineTreasuryImplementation.js +512 -0
  250. package/dist/generated/abi/ComputeEngineTreasuryImplementation.js.map +1 -0
  251. package/dist/generated/abi/ComputeInstructionRegistryImplementation.cjs +734 -0
  252. package/dist/generated/abi/ComputeInstructionRegistryImplementation.cjs.map +1 -0
  253. package/dist/generated/abi/ComputeInstructionRegistryImplementation.d.ts +544 -0
  254. package/dist/generated/abi/ComputeInstructionRegistryImplementation.js +710 -0
  255. package/dist/generated/abi/ComputeInstructionRegistryImplementation.js.map +1 -0
  256. package/dist/generated/abi/DATFactoryImplementation.cjs +882 -0
  257. package/dist/generated/abi/DATFactoryImplementation.cjs.map +1 -0
  258. package/dist/generated/abi/DATFactoryImplementation.d.ts +660 -0
  259. package/dist/generated/abi/DATFactoryImplementation.js +858 -0
  260. package/dist/generated/abi/DATFactoryImplementation.js.map +1 -0
  261. package/dist/generated/abi/DATImplementation.cjs +934 -0
  262. package/dist/generated/abi/DATImplementation.cjs.map +1 -0
  263. package/dist/generated/abi/DATImplementation.d.ts +692 -0
  264. package/dist/generated/abi/DATImplementation.js +910 -0
  265. package/dist/generated/abi/DATImplementation.js.map +1 -0
  266. package/dist/generated/abi/DATPausableImplementation.cjs +1523 -0
  267. package/dist/generated/abi/DATPausableImplementation.cjs.map +1 -0
  268. package/dist/generated/abi/DATPausableImplementation.d.ts +1144 -0
  269. package/dist/generated/abi/DATPausableImplementation.js +1499 -0
  270. package/dist/generated/abi/DATPausableImplementation.js.map +1 -0
  271. package/dist/generated/abi/DATVotesImplementation.cjs +1460 -0
  272. package/dist/generated/abi/DATVotesImplementation.cjs.map +1 -0
  273. package/dist/generated/abi/DATVotesImplementation.d.ts +1094 -0
  274. package/dist/generated/abi/DATVotesImplementation.js +1436 -0
  275. package/dist/generated/abi/DATVotesImplementation.js.map +1 -0
  276. package/dist/generated/abi/DLPPerformanceImplementation.cjs +1202 -0
  277. package/dist/generated/abi/DLPPerformanceImplementation.cjs.map +1 -0
  278. package/dist/generated/abi/DLPPerformanceImplementation.d.ts +914 -0
  279. package/dist/generated/abi/DLPPerformanceImplementation.js +1178 -0
  280. package/dist/generated/abi/DLPPerformanceImplementation.js.map +1 -0
  281. package/dist/generated/abi/DLPRegistryImplementation.cjs +1469 -0
  282. package/dist/generated/abi/DLPRegistryImplementation.cjs.map +1 -0
  283. package/dist/generated/abi/DLPRegistryImplementation.d.ts +1122 -0
  284. package/dist/generated/abi/DLPRegistryImplementation.js +1445 -0
  285. package/dist/generated/abi/DLPRegistryImplementation.js.map +1 -0
  286. package/dist/generated/abi/DLPRegistryTreasuryImplementation.cjs +612 -0
  287. package/dist/generated/abi/DLPRegistryTreasuryImplementation.cjs.map +1 -0
  288. package/dist/generated/abi/DLPRegistryTreasuryImplementation.d.ts +451 -0
  289. package/dist/generated/abi/DLPRegistryTreasuryImplementation.js +588 -0
  290. package/dist/generated/abi/DLPRegistryTreasuryImplementation.js.map +1 -0
  291. package/dist/generated/abi/DLPRewardDeployerImplementation.cjs +1112 -0
  292. package/dist/generated/abi/DLPRewardDeployerImplementation.cjs.map +1 -0
  293. package/dist/generated/abi/DLPRewardDeployerImplementation.d.ts +840 -0
  294. package/dist/generated/abi/DLPRewardDeployerImplementation.js +1088 -0
  295. package/dist/generated/abi/DLPRewardDeployerImplementation.js.map +1 -0
  296. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.cjs +612 -0
  297. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.cjs.map +1 -0
  298. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.d.ts +451 -0
  299. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.js +588 -0
  300. package/dist/generated/abi/DLPRewardDeployerTreasuryImplementation.js.map +1 -0
  301. package/dist/generated/abi/DLPRewardSwapImplementation.cjs +939 -0
  302. package/dist/generated/abi/DLPRewardSwapImplementation.cjs.map +1 -0
  303. package/dist/generated/abi/DLPRewardSwapImplementation.d.ts +705 -0
  304. package/dist/generated/abi/DLPRewardSwapImplementation.js +915 -0
  305. package/dist/generated/abi/DLPRewardSwapImplementation.js.map +1 -0
  306. package/dist/generated/abi/DLPRootImplementation.cjs +1644 -0
  307. package/dist/generated/abi/DLPRootImplementation.cjs.map +1 -0
  308. package/dist/generated/abi/DLPRootImplementation.d.ts +1246 -0
  309. package/dist/generated/abi/DLPRootImplementation.js +1620 -0
  310. package/dist/generated/abi/DLPRootImplementation.js.map +1 -0
  311. package/dist/generated/abi/DataLiquidityPoolImplementation.cjs +1167 -0
  312. package/dist/generated/abi/DataLiquidityPoolImplementation.cjs.map +1 -0
  313. package/dist/generated/abi/DataLiquidityPoolImplementation.d.ts +874 -0
  314. package/dist/generated/abi/DataLiquidityPoolImplementation.js +1143 -0
  315. package/dist/generated/abi/DataLiquidityPoolImplementation.js.map +1 -0
  316. package/dist/generated/abi/DataPortabilityGranteesImplementation.cjs +1036 -0
  317. package/dist/generated/abi/DataPortabilityGranteesImplementation.cjs.map +1 -0
  318. package/dist/generated/abi/DataPortabilityGranteesImplementation.d.ts +773 -0
  319. package/dist/generated/abi/DataPortabilityGranteesImplementation.js +1012 -0
  320. package/dist/generated/abi/DataPortabilityGranteesImplementation.js.map +1 -0
  321. package/dist/generated/abi/DataPortabilityPermissionsImplementation.cjs +1298 -0
  322. package/dist/generated/abi/DataPortabilityPermissionsImplementation.cjs.map +1 -0
  323. package/dist/generated/abi/DataPortabilityPermissionsImplementation.d.ts +974 -0
  324. package/dist/generated/abi/DataPortabilityPermissionsImplementation.js +1274 -0
  325. package/dist/generated/abi/DataPortabilityPermissionsImplementation.js.map +1 -0
  326. package/dist/generated/abi/DataPortabilityServersImplementation.cjs +1419 -0
  327. package/dist/generated/abi/DataPortabilityServersImplementation.cjs.map +1 -0
  328. package/dist/generated/abi/DataPortabilityServersImplementation.d.ts +1071 -0
  329. package/dist/generated/abi/DataPortabilityServersImplementation.js +1395 -0
  330. package/dist/generated/abi/DataPortabilityServersImplementation.js.map +1 -0
  331. package/dist/generated/abi/DataRefinerRegistryImplementation.cjs +984 -0
  332. package/dist/generated/abi/DataRefinerRegistryImplementation.cjs.map +1 -0
  333. package/dist/generated/abi/DataRefinerRegistryImplementation.d.ts +736 -0
  334. package/dist/generated/abi/DataRefinerRegistryImplementation.js +960 -0
  335. package/dist/generated/abi/DataRefinerRegistryImplementation.js.map +1 -0
  336. package/dist/generated/abi/DataRegistryImplementation.cjs +1328 -0
  337. package/dist/generated/abi/DataRegistryImplementation.cjs.map +1 -0
  338. package/dist/generated/abi/DataRegistryImplementation.d.ts +1003 -0
  339. package/dist/generated/abi/DataRegistryImplementation.js +1304 -0
  340. package/dist/generated/abi/DataRegistryImplementation.js.map +1 -0
  341. package/dist/generated/abi/DatasetRegistryImplementation.cjs +751 -0
  342. package/dist/generated/abi/DatasetRegistryImplementation.cjs.map +1 -0
  343. package/dist/generated/abi/DatasetRegistryImplementation.d.ts +557 -0
  344. package/dist/generated/abi/DatasetRegistryImplementation.js +727 -0
  345. package/dist/generated/abi/DatasetRegistryImplementation.js.map +1 -0
  346. package/dist/generated/abi/ProtocolConfigImplementation.cjs +578 -0
  347. package/dist/generated/abi/ProtocolConfigImplementation.cjs.map +1 -0
  348. package/dist/generated/abi/ProtocolConfigImplementation.d.ts +423 -0
  349. package/dist/generated/abi/ProtocolConfigImplementation.js +554 -0
  350. package/dist/generated/abi/ProtocolConfigImplementation.js.map +1 -0
  351. package/dist/generated/abi/QueryEngineImplementation.cjs +1319 -0
  352. package/dist/generated/abi/QueryEngineImplementation.cjs.map +1 -0
  353. package/dist/generated/abi/QueryEngineImplementation.d.ts +1000 -0
  354. package/dist/generated/abi/QueryEngineImplementation.js +1295 -0
  355. package/dist/generated/abi/QueryEngineImplementation.js.map +1 -0
  356. package/dist/generated/abi/SwapHelperImplementation.cjs +976 -0
  357. package/dist/generated/abi/SwapHelperImplementation.cjs.map +1 -0
  358. package/dist/generated/abi/SwapHelperImplementation.d.ts +728 -0
  359. package/dist/generated/abi/SwapHelperImplementation.js +952 -0
  360. package/dist/generated/abi/SwapHelperImplementation.js.map +1 -0
  361. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.cjs +936 -0
  362. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.cjs.map +1 -0
  363. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.d.ts +700 -0
  364. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.js +912 -0
  365. package/dist/generated/abi/TeePoolDedicatedGpuImplementation.js.map +1 -0
  366. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.cjs +936 -0
  367. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.cjs.map +1 -0
  368. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.d.ts +700 -0
  369. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.js +912 -0
  370. package/dist/generated/abi/TeePoolDedicatedStandardImplementation.js.map +1 -0
  371. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.cjs +936 -0
  372. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.cjs.map +1 -0
  373. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.d.ts +700 -0
  374. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.js +912 -0
  375. package/dist/generated/abi/TeePoolEphemeralStandardImplementation.js.map +1 -0
  376. package/dist/generated/abi/TeePoolImplementation.cjs +1313 -0
  377. package/dist/generated/abi/TeePoolImplementation.cjs.map +1 -0
  378. package/dist/generated/abi/TeePoolImplementation.d.ts +992 -0
  379. package/dist/generated/abi/TeePoolImplementation.js +1289 -0
  380. package/dist/generated/abi/TeePoolImplementation.js.map +1 -0
  381. package/dist/generated/abi/TeePoolPersistentGpuImplementation.cjs +936 -0
  382. package/dist/generated/abi/TeePoolPersistentGpuImplementation.cjs.map +1 -0
  383. package/dist/generated/abi/TeePoolPersistentGpuImplementation.d.ts +700 -0
  384. package/dist/generated/abi/TeePoolPersistentGpuImplementation.js +912 -0
  385. package/dist/generated/abi/TeePoolPersistentGpuImplementation.js.map +1 -0
  386. package/dist/generated/abi/TeePoolPersistentStandardImplementation.cjs +936 -0
  387. package/dist/generated/abi/TeePoolPersistentStandardImplementation.cjs.map +1 -0
  388. package/dist/generated/abi/TeePoolPersistentStandardImplementation.d.ts +700 -0
  389. package/dist/generated/abi/TeePoolPersistentStandardImplementation.js +912 -0
  390. package/dist/generated/abi/TeePoolPersistentStandardImplementation.js.map +1 -0
  391. package/dist/generated/abi/TeePoolPhalaImplementation.cjs +1313 -0
  392. package/dist/generated/abi/TeePoolPhalaImplementation.cjs.map +1 -0
  393. package/dist/generated/abi/TeePoolPhalaImplementation.d.ts +992 -0
  394. package/dist/generated/abi/TeePoolPhalaImplementation.js +1289 -0
  395. package/dist/generated/abi/TeePoolPhalaImplementation.js.map +1 -0
  396. package/dist/generated/abi/UniswapV3NonfungiblePositionManagerImplementation.cjs +1251 -0
  397. package/dist/generated/abi/UniswapV3NonfungiblePositionManagerImplementation.cjs.map +1 -0
  398. package/dist/generated/abi/UniswapV3NonfungiblePositionManagerImplementation.d.ts +948 -0
  399. package/dist/generated/abi/UniswapV3NonfungiblePositionManagerImplementation.js +1227 -0
  400. package/dist/generated/abi/UniswapV3NonfungiblePositionManagerImplementation.js.map +1 -0
  401. package/dist/generated/abi/UniswapV3QuoterV2Implementation.cjs +297 -0
  402. package/dist/generated/abi/UniswapV3QuoterV2Implementation.cjs.map +1 -0
  403. package/dist/generated/abi/UniswapV3QuoterV2Implementation.d.ts +206 -0
  404. package/dist/generated/abi/UniswapV3QuoterV2Implementation.js +273 -0
  405. package/dist/generated/abi/UniswapV3QuoterV2Implementation.js.map +1 -0
  406. package/dist/generated/abi/VanaEpochImplementation.cjs +1383 -0
  407. package/dist/generated/abi/VanaEpochImplementation.cjs.map +1 -0
  408. package/dist/generated/abi/VanaEpochImplementation.d.ts +1050 -0
  409. package/dist/generated/abi/VanaEpochImplementation.js +1359 -0
  410. package/dist/generated/abi/VanaEpochImplementation.js.map +1 -0
  411. package/dist/generated/abi/VanaPoolEntityImplementation.cjs +1191 -0
  412. package/dist/generated/abi/VanaPoolEntityImplementation.cjs.map +1 -0
  413. package/dist/generated/abi/VanaPoolEntityImplementation.d.ts +899 -0
  414. package/dist/generated/abi/VanaPoolEntityImplementation.js +1167 -0
  415. package/dist/generated/abi/VanaPoolEntityImplementation.js.map +1 -0
  416. package/dist/generated/abi/VanaPoolStakingImplementation.cjs +1033 -0
  417. package/dist/generated/abi/VanaPoolStakingImplementation.cjs.map +1 -0
  418. package/dist/generated/abi/VanaPoolStakingImplementation.d.ts +776 -0
  419. package/dist/generated/abi/VanaPoolStakingImplementation.js +1009 -0
  420. package/dist/generated/abi/VanaPoolStakingImplementation.js.map +1 -0
  421. package/dist/generated/abi/VanaPoolTreasuryImplementation.cjs +538 -0
  422. package/dist/generated/abi/VanaPoolTreasuryImplementation.cjs.map +1 -0
  423. package/dist/generated/abi/VanaPoolTreasuryImplementation.d.ts +393 -0
  424. package/dist/generated/abi/VanaPoolTreasuryImplementation.js +514 -0
  425. package/dist/generated/abi/VanaPoolTreasuryImplementation.js.map +1 -0
  426. package/dist/generated/abi/VanaRuntimePermissionsImplementation.cjs +759 -0
  427. package/dist/generated/abi/VanaRuntimePermissionsImplementation.cjs.map +1 -0
  428. package/dist/generated/abi/VanaRuntimePermissionsImplementation.d.ts +563 -0
  429. package/dist/generated/abi/VanaRuntimePermissionsImplementation.js +735 -0
  430. package/dist/generated/abi/VanaRuntimePermissionsImplementation.js.map +1 -0
  431. package/dist/generated/abi/VanaRuntimeServersImplementation.cjs +820 -0
  432. package/dist/generated/abi/VanaRuntimeServersImplementation.cjs.map +1 -0
  433. package/dist/generated/abi/VanaRuntimeServersImplementation.d.ts +609 -0
  434. package/dist/generated/abi/VanaRuntimeServersImplementation.js +796 -0
  435. package/dist/generated/abi/VanaRuntimeServersImplementation.js.map +1 -0
  436. package/dist/generated/abi/VanaTreasuryImplementation.cjs +536 -0
  437. package/dist/generated/abi/VanaTreasuryImplementation.cjs.map +1 -0
  438. package/dist/generated/abi/VanaTreasuryImplementation.d.ts +393 -0
  439. package/dist/generated/abi/VanaTreasuryImplementation.js +512 -0
  440. package/dist/generated/abi/VanaTreasuryImplementation.js.map +1 -0
  441. package/dist/generated/abi/WVANAImplementation.cjs +339 -0
  442. package/dist/generated/abi/WVANAImplementation.cjs.map +1 -0
  443. package/dist/generated/abi/WVANAImplementation.d.ts +244 -0
  444. package/dist/generated/abi/WVANAImplementation.js +315 -0
  445. package/dist/generated/abi/WVANAImplementation.js.map +1 -0
  446. package/dist/generated/abi/index.cjs +209 -0
  447. package/dist/generated/abi/index.cjs.map +1 -0
  448. package/dist/{index.node.d.cts → generated/abi/index.d.ts} +16715 -21763
  449. package/dist/generated/abi/index.js +142 -0
  450. package/dist/generated/abi/index.js.map +1 -0
  451. package/dist/generated/addresses.cjs +424 -0
  452. package/dist/generated/addresses.cjs.map +1 -0
  453. package/dist/generated/addresses.d.ts +373 -0
  454. package/dist/generated/addresses.js +394 -0
  455. package/dist/generated/addresses.js.map +1 -0
  456. package/dist/generated/event-types.cjs +17 -0
  457. package/dist/generated/event-types.cjs.map +1 -0
  458. package/dist/generated/event-types.d.ts +937 -0
  459. package/dist/generated/event-types.js +1 -0
  460. package/dist/generated/event-types.js.map +1 -0
  461. package/dist/generated/eventRegistry.cjs +5228 -0
  462. package/dist/generated/eventRegistry.cjs.map +1 -0
  463. package/dist/generated/eventRegistry.d.ts +14 -0
  464. package/dist/generated/eventRegistry.js +5203 -0
  465. package/dist/generated/eventRegistry.js.map +1 -0
  466. package/dist/generated/server/server-exports.cjs +45 -0
  467. package/dist/generated/server/server-exports.cjs.map +1 -0
  468. package/dist/generated/server/server-exports.d.ts +39 -0
  469. package/dist/generated/server/server-exports.js +19 -0
  470. package/dist/generated/server/server-exports.js.map +1 -0
  471. package/dist/generated/server/server.cjs +17 -0
  472. package/dist/generated/server/server.cjs.map +1 -0
  473. package/dist/generated/server/server.d.ts +907 -0
  474. package/dist/generated/server/server.js +1 -0
  475. package/dist/generated/server/server.js.map +1 -0
  476. package/dist/generated/subgraph.cjs +1440 -0
  477. package/dist/generated/subgraph.cjs.map +1 -0
  478. package/dist/generated/subgraph.d.ts +6113 -0
  479. package/dist/generated/subgraph.js +1404 -0
  480. package/dist/generated/subgraph.js.map +1 -0
  481. package/dist/index.browser.d.ts +50 -36684
  482. package/dist/index.browser.js +91 -45518
  483. package/dist/index.browser.js.map +1 -1
  484. package/dist/index.cjs +5 -0
  485. package/dist/index.cjs.map +1 -0
  486. package/dist/index.d.ts +0 -0
  487. package/dist/index.js +4 -0
  488. package/dist/index.js.map +1 -0
  489. package/dist/index.node.cjs +131 -46017
  490. package/dist/index.node.cjs.map +1 -1
  491. package/dist/index.node.d.ts +94 -36795
  492. package/dist/index.node.js +108 -45905
  493. package/dist/index.node.js.map +1 -1
  494. package/dist/lib/__tests__/redisAtomicStore.test.d.ts +1 -0
  495. package/dist/lib/redisAtomicStore.cjs +201 -0
  496. package/dist/lib/redisAtomicStore.cjs.map +1 -0
  497. package/dist/lib/redisAtomicStore.d.ts +120 -0
  498. package/dist/lib/redisAtomicStore.js +177 -0
  499. package/dist/lib/redisAtomicStore.js.map +1 -0
  500. package/dist/node.cjs +2 -323
  501. package/dist/node.cjs.map +1 -1
  502. package/dist/node.d.ts +42 -1
  503. package/dist/node.js +1 -309
  504. package/dist/node.js.map +1 -1
  505. package/dist/platform/browser-only.cjs +37 -0
  506. package/dist/platform/browser-only.cjs.map +1 -0
  507. package/dist/platform/browser-only.d.ts +22 -0
  508. package/dist/platform/browser-only.js +12 -0
  509. package/dist/platform/browser-only.js.map +1 -0
  510. package/dist/platform/browser-only.test.d.ts +1 -0
  511. package/dist/platform/browser-safe.cjs +57 -0
  512. package/dist/platform/browser-safe.cjs.map +1 -0
  513. package/dist/platform/browser-safe.d.ts +29 -0
  514. package/dist/platform/browser-safe.js +31 -0
  515. package/dist/platform/browser-safe.js.map +1 -0
  516. package/dist/platform/browser-safe.test.d.ts +1 -0
  517. package/dist/platform/browser.cjs +488 -0
  518. package/dist/platform/browser.cjs.map +1 -0
  519. package/dist/platform/browser.d.ts +291 -0
  520. package/dist/platform/browser.js +454 -0
  521. package/dist/platform/browser.js.map +1 -0
  522. package/dist/platform/browser.test.d.ts +1 -0
  523. package/dist/platform/index.cjs +50 -0
  524. package/dist/platform/index.cjs.map +1 -0
  525. package/dist/platform/index.d.ts +11 -0
  526. package/dist/platform/index.js +27 -0
  527. package/dist/platform/index.js.map +1 -0
  528. package/dist/platform/interface.cjs +17 -0
  529. package/dist/platform/interface.cjs.map +1 -0
  530. package/dist/platform/interface.d.ts +409 -0
  531. package/dist/platform/interface.js +1 -0
  532. package/dist/platform/interface.js.map +1 -0
  533. package/dist/platform/node.cjs +512 -0
  534. package/dist/platform/node.cjs.map +1 -0
  535. package/dist/platform/node.d.ts +86 -0
  536. package/dist/platform/node.js +481 -0
  537. package/dist/platform/node.js.map +1 -0
  538. package/dist/platform/ports/openpgp-port.cjs +74 -0
  539. package/dist/platform/ports/openpgp-port.cjs.map +1 -0
  540. package/dist/platform/ports/openpgp-port.d.ts +13 -0
  541. package/dist/platform/ports/openpgp-port.js +59 -0
  542. package/dist/platform/ports/openpgp-port.js.map +1 -0
  543. package/dist/platform/ports/pgp-port.cjs +17 -0
  544. package/dist/platform/ports/pgp-port.cjs.map +1 -0
  545. package/dist/platform/ports/pgp-port.d.ts +35 -0
  546. package/dist/platform/ports/pgp-port.js +1 -0
  547. package/dist/platform/ports/pgp-port.js.map +1 -0
  548. package/dist/platform/shared/error-utils.cjs +43 -0
  549. package/dist/platform/shared/error-utils.cjs.map +1 -0
  550. package/dist/platform/shared/error-utils.d.ts +23 -0
  551. package/dist/platform/shared/error-utils.js +18 -0
  552. package/dist/platform/shared/error-utils.js.map +1 -0
  553. package/dist/platform/shared/pgp-utils.cjs +55 -0
  554. package/dist/platform/shared/pgp-utils.cjs.map +1 -0
  555. package/dist/platform/shared/pgp-utils.d.ts +59 -0
  556. package/dist/platform/shared/pgp-utils.js +29 -0
  557. package/dist/platform/shared/pgp-utils.js.map +1 -0
  558. package/dist/platform/shared/stream-utils.cjs +49 -0
  559. package/dist/platform/shared/stream-utils.cjs.map +1 -0
  560. package/dist/platform/shared/stream-utils.d.ts +14 -0
  561. package/dist/platform/shared/stream-utils.js +25 -0
  562. package/dist/platform/shared/stream-utils.js.map +1 -0
  563. package/dist/platform/utils.cjs +114 -0
  564. package/dist/platform/utils.cjs.map +1 -0
  565. package/dist/platform/utils.d.ts +49 -0
  566. package/dist/platform/utils.js +76 -0
  567. package/dist/platform/utils.js.map +1 -0
  568. package/dist/platform/utils.test.d.ts +1 -0
  569. package/dist/platform.browser.d.ts +6 -57
  570. package/dist/platform.browser.js +10 -356
  571. package/dist/platform.browser.js.map +1 -1
  572. package/dist/platform.cjs +14 -698
  573. package/dist/platform.cjs.map +1 -1
  574. package/dist/platform.d.ts +11 -2
  575. package/dist/platform.js +14 -684
  576. package/dist/platform.js.map +1 -1
  577. package/dist/platform.node.cjs +14 -698
  578. package/dist/platform.node.cjs.map +1 -1
  579. package/dist/platform.node.d.ts +7 -98
  580. package/dist/platform.node.js +14 -684
  581. package/dist/platform.node.js.map +1 -1
  582. package/dist/schemas/dataSchema.schema.json +53 -0
  583. package/dist/schemas/grantFile.schema.json +43 -0
  584. package/dist/server/relayerHandler.cjs +452 -0
  585. package/dist/server/relayerHandler.cjs.map +1 -0
  586. package/dist/server/relayerHandler.d.ts +69 -0
  587. package/dist/server/relayerHandler.js +428 -0
  588. package/dist/server/relayerHandler.js.map +1 -0
  589. package/dist/storage/index.cjs +47 -0
  590. package/dist/storage/index.cjs.map +1 -0
  591. package/dist/storage/index.d.ts +57 -0
  592. package/dist/storage/index.js +17 -0
  593. package/dist/storage/index.js.map +1 -0
  594. package/dist/storage/manager.cjs +272 -0
  595. package/dist/storage/manager.cjs.map +1 -0
  596. package/dist/storage/manager.d.ts +241 -0
  597. package/dist/storage/manager.js +248 -0
  598. package/dist/storage/manager.js.map +1 -0
  599. package/dist/storage/providers/callback-storage.cjs +248 -0
  600. package/dist/storage/providers/callback-storage.cjs.map +1 -0
  601. package/dist/storage/providers/callback-storage.d.ts +183 -0
  602. package/dist/storage/providers/callback-storage.js +226 -0
  603. package/dist/storage/providers/callback-storage.js.map +1 -0
  604. package/dist/storage/providers/dropbox.cjs +237 -0
  605. package/dist/storage/providers/dropbox.cjs.map +1 -0
  606. package/dist/storage/providers/dropbox.d.ts +39 -0
  607. package/dist/storage/providers/dropbox.js +215 -0
  608. package/dist/storage/providers/dropbox.js.map +1 -0
  609. package/dist/storage/providers/dropbox.test.d.ts +1 -0
  610. package/dist/storage/providers/google-drive.cjs +516 -0
  611. package/dist/storage/providers/google-drive.cjs.map +1 -0
  612. package/dist/storage/providers/google-drive.d.ts +152 -0
  613. package/dist/storage/providers/google-drive.js +494 -0
  614. package/dist/storage/providers/google-drive.js.map +1 -0
  615. package/dist/storage/providers/google-drive.test.d.ts +1 -0
  616. package/dist/storage/providers/ipfs.cjs +283 -0
  617. package/dist/storage/providers/ipfs.cjs.map +1 -0
  618. package/dist/storage/providers/ipfs.d.ts +160 -0
  619. package/dist/storage/providers/ipfs.js +261 -0
  620. package/dist/storage/providers/ipfs.js.map +1 -0
  621. package/dist/storage/providers/pinata.cjs +339 -0
  622. package/dist/storage/providers/pinata.cjs.map +1 -0
  623. package/dist/storage/providers/pinata.d.ts +168 -0
  624. package/dist/storage/providers/pinata.js +317 -0
  625. package/dist/storage/providers/pinata.js.map +1 -0
  626. package/dist/storage/tests/callbackStorage.test.d.ts +1 -0
  627. package/dist/storage/tests/googleDriveStorage.test.d.ts +1 -0
  628. package/dist/storage/tests/ipfsStorage.test.d.ts +1 -0
  629. package/dist/storage/tests/pinataStorage.test.d.ts +1 -0
  630. package/dist/storage/tests/storageManager.test.d.ts +1 -0
  631. package/dist/tests/abi.test.d.ts +1 -0
  632. package/dist/tests/chains-definitions.test.d.ts +1 -0
  633. package/dist/tests/core-encryption.test.d.ts +1 -0
  634. package/dist/tests/core-extended.test.d.ts +1 -0
  635. package/dist/tests/core-generics-coverage.test.d.ts +1 -0
  636. package/dist/tests/coverage-boost.test.d.ts +1 -0
  637. package/dist/tests/crypto-cross-platform-compatibility.test.d.ts +1 -0
  638. package/dist/tests/data-addfile-permissions-schema.test.d.ts +1 -0
  639. package/dist/tests/data-additional-methods.test.d.ts +1 -0
  640. package/dist/tests/data-controller-edge-cases.test.d.ts +1 -0
  641. package/dist/tests/data-ipfs-gateways.test.d.ts +1 -0
  642. package/dist/tests/data-relayer.test.d.ts +1 -0
  643. package/dist/tests/data-schema-validation.test.d.ts +1 -0
  644. package/dist/tests/data-simple-methods.test.d.ts +1 -0
  645. package/dist/tests/data-upload-owner-validation.test.d.ts +1 -0
  646. package/dist/tests/data.test.d.ts +1 -0
  647. package/dist/tests/demo-integration.test.d.ts +1 -0
  648. package/dist/tests/demo-trusted-server-integration.test.d.ts +1 -0
  649. package/dist/tests/download-relayer.test.d.ts +1 -0
  650. package/dist/tests/dual-mode-permissions.test.d.ts +1 -0
  651. package/dist/tests/dual-mode-trusted-servers.test.d.ts +1 -0
  652. package/dist/tests/encryption-correct-implementation.test.d.ts +1 -0
  653. package/dist/tests/encryption-coverage.test.d.ts +1 -0
  654. package/dist/tests/encryption-edge-cases.test.d.ts +1 -0
  655. package/dist/tests/encryption-utils-updated.test.d.ts +1 -0
  656. package/dist/tests/errors-coverage.test.d.ts +1 -0
  657. package/dist/tests/errors.test.d.ts +1 -0
  658. package/dist/tests/factories/mockFactory.d.ts +316 -0
  659. package/dist/tests/fakes/FakeStorageManager.d.ts +200 -0
  660. package/dist/tests/fakes/FakeStorageManager.test.d.ts +1 -0
  661. package/dist/tests/fakes/FakeWaitForTransactionEvents.d.ts +170 -0
  662. package/dist/tests/fakes/FakeWaitForTransactionEvents.test.d.ts +1 -0
  663. package/dist/tests/fakes/fake-pgp-port.d.ts +13 -0
  664. package/dist/tests/grantValidation-edge-cases.test.d.ts +1 -0
  665. package/dist/tests/grantValidation-unreachable-branch.test.d.ts +1 -0
  666. package/dist/tests/helper-methods.test.d.ts +1 -0
  667. package/dist/tests/helpers/platformTestHelpers.d.ts +106 -0
  668. package/dist/tests/helpers/typedMocks.d.ts +64 -0
  669. package/dist/tests/index-browser.test.d.ts +1 -0
  670. package/dist/tests/index-node.test.d.ts +1 -0
  671. package/dist/tests/index.test.d.ts +1 -0
  672. package/dist/tests/mocks/platformAdapter.d.ts +12 -0
  673. package/dist/tests/new-permissions-methods.test.d.ts +1 -0
  674. package/dist/tests/no-buffer-browser.test.d.ts +1 -0
  675. package/dist/tests/permissions-grantee.test.d.ts +1 -0
  676. package/dist/tests/permissions-revoke-relayer.test.d.ts +1 -0
  677. package/dist/tests/permissions-schema-validation.test.d.ts +1 -0
  678. package/dist/tests/permissions-server-files.test.d.ts +1 -0
  679. package/dist/tests/permissions-transaction-options.test.d.ts +1 -0
  680. package/dist/tests/permissions-trust-servers.test.d.ts +1 -0
  681. package/dist/tests/permissions.test.d.ts +1 -0
  682. package/dist/tests/personal.test.d.ts +1 -0
  683. package/dist/tests/platform-browser.test.d.ts +1 -0
  684. package/dist/tests/platform-crypto-expanded.test.d.ts +1 -0
  685. package/dist/tests/platform-crypto.test.d.ts +1 -0
  686. package/dist/tests/platform-index.test.d.ts +1 -0
  687. package/dist/tests/platform-node.test.d.ts +1 -0
  688. package/dist/tests/platform-shared-utils.test.d.ts +1 -0
  689. package/dist/tests/platform-updated.test.d.ts +1 -0
  690. package/dist/tests/protocol-additional-methods.test.d.ts +1 -0
  691. package/dist/tests/protocol.test.d.ts +1 -0
  692. package/dist/tests/read-only-mode.test.d.ts +1 -0
  693. package/dist/tests/relayer-integration.test.d.ts +1 -0
  694. package/dist/tests/relayer-unified.test.d.ts +1 -0
  695. package/dist/tests/schemas.test.d.ts +1 -0
  696. package/dist/tests/server-relayer-handler.test.d.ts +1 -0
  697. package/dist/tests/setup.d.ts +7 -0
  698. package/dist/tests/signatureFormatter.test.d.ts +1 -0
  699. package/dist/tests/trusted-server-queries.test.d.ts +1 -0
  700. package/dist/tests/typedDataConverter.test.d.ts +1 -0
  701. package/dist/tests/types-contracts.test.d.ts +1 -0
  702. package/dist/tests/types-data.test.d.ts +1 -0
  703. package/dist/tests/types-external-apis.test.d.ts +1 -0
  704. package/dist/tests/types-generics.test.d.ts +1 -0
  705. package/dist/tests/types-permissions.test.d.ts +1 -0
  706. package/dist/tests/types-upload-params.test.d.ts +1 -0
  707. package/dist/tests/types.test.d.ts +1 -0
  708. package/dist/tests/utils-formatters.test.d.ts +1 -0
  709. package/dist/tests/utils-grantFiles-edge-cases.test.d.ts +1 -0
  710. package/dist/tests/utils-grantFiles-validation.test.d.ts +1 -0
  711. package/dist/tests/utils-grantFiles.test.d.ts +1 -0
  712. package/dist/tests/utils-grantValidation-consolidated.test.d.ts +1 -0
  713. package/dist/tests/utils-grants.test.d.ts +1 -0
  714. package/dist/tests/utils-ipfs-additional.test.d.ts +1 -0
  715. package/dist/tests/utils-ipfs.test.d.ts +4 -0
  716. package/dist/tests/utils-schemaValidation.test.d.ts +1 -0
  717. package/dist/tests/vana.test.d.ts +1 -0
  718. package/dist/tests/wallet-crypto-compatibility.test.d.ts +1 -0
  719. package/dist/types/accessSettlement.cjs +17 -0
  720. package/dist/types/accessSettlement.cjs.map +1 -0
  721. package/dist/types/accessSettlement.d.ts +66 -0
  722. package/dist/types/accessSettlement.js +1 -0
  723. package/dist/types/accessSettlement.js.map +1 -0
  724. package/dist/types/atomicStore.cjs +31 -0
  725. package/dist/types/atomicStore.cjs.map +1 -0
  726. package/dist/types/atomicStore.d.ts +236 -0
  727. package/dist/types/atomicStore.js +7 -0
  728. package/dist/types/atomicStore.js.map +1 -0
  729. package/dist/types/blockchain.cjs +17 -0
  730. package/dist/types/blockchain.cjs.map +1 -0
  731. package/dist/types/blockchain.d.ts +85 -0
  732. package/dist/types/blockchain.js +1 -0
  733. package/dist/types/blockchain.js.map +1 -0
  734. package/dist/types/chains-additional.test.d.ts +1 -0
  735. package/dist/types/chains.cjs +36 -0
  736. package/dist/types/chains.cjs.map +1 -0
  737. package/dist/types/chains.d.ts +98 -0
  738. package/dist/types/chains.js +11 -0
  739. package/dist/types/chains.js.map +1 -0
  740. package/dist/types/config.cjs +51 -0
  741. package/dist/types/config.cjs.map +1 -0
  742. package/dist/types/config.d.ts +720 -0
  743. package/dist/types/config.js +23 -0
  744. package/dist/types/config.js.map +1 -0
  745. package/dist/types/contracts.cjs +17 -0
  746. package/dist/types/contracts.cjs.map +1 -0
  747. package/dist/types/contracts.d.ts +129 -0
  748. package/dist/types/contracts.js +1 -0
  749. package/dist/types/contracts.js.map +1 -0
  750. package/dist/types/controller-context.cjs +17 -0
  751. package/dist/types/controller-context.cjs.map +1 -0
  752. package/dist/types/controller-context.d.ts +68 -0
  753. package/dist/types/controller-context.js +1 -0
  754. package/dist/types/controller-context.js.map +1 -0
  755. package/dist/types/data.cjs +17 -0
  756. package/dist/types/data.cjs.map +1 -0
  757. package/dist/types/data.d.ts +763 -0
  758. package/dist/types/data.js +1 -0
  759. package/dist/types/data.js.map +1 -0
  760. package/dist/types/eccrypto-js.d.cjs +2 -0
  761. package/dist/types/eccrypto-js.d.cjs.map +1 -0
  762. package/dist/types/eccrypto-js.d.js +1 -0
  763. package/dist/types/eccrypto-js.d.js.map +1 -0
  764. package/dist/types/external-apis.cjs +61 -0
  765. package/dist/types/external-apis.cjs.map +1 -0
  766. package/dist/types/external-apis.d.ts +184 -0
  767. package/dist/types/external-apis.js +34 -0
  768. package/dist/types/external-apis.js.map +1 -0
  769. package/dist/types/generics.cjs +17 -0
  770. package/dist/types/generics.cjs.map +1 -0
  771. package/dist/types/generics.d.ts +518 -0
  772. package/dist/types/generics.js +1 -0
  773. package/dist/types/generics.js.map +1 -0
  774. package/dist/types/index.cjs +65 -0
  775. package/dist/types/index.cjs.map +1 -0
  776. package/dist/types/index.d.ts +50 -0
  777. package/dist/types/index.js +42 -0
  778. package/dist/types/index.js.map +1 -0
  779. package/dist/types/operationStore.cjs +17 -0
  780. package/dist/types/operationStore.cjs.map +1 -0
  781. package/dist/types/operationStore.d.ts +171 -0
  782. package/dist/types/operationStore.js +1 -0
  783. package/dist/types/operationStore.js.map +1 -0
  784. package/dist/types/operations.cjs +53 -0
  785. package/dist/types/operations.cjs.map +1 -0
  786. package/dist/types/operations.d.ts +204 -0
  787. package/dist/types/operations.js +26 -0
  788. package/dist/types/operations.js.map +1 -0
  789. package/dist/types/options.cjs +17 -0
  790. package/dist/types/options.cjs.map +1 -0
  791. package/dist/types/options.d.ts +308 -0
  792. package/dist/types/options.js +1 -0
  793. package/dist/types/options.js.map +1 -0
  794. package/dist/types/permissions.cjs +17 -0
  795. package/dist/types/permissions.cjs.map +1 -0
  796. package/dist/types/permissions.d.ts +953 -0
  797. package/dist/types/permissions.js +1 -0
  798. package/dist/types/permissions.js.map +1 -0
  799. package/dist/types/personal.cjs +17 -0
  800. package/dist/types/personal.cjs.map +1 -0
  801. package/dist/types/personal.d.ts +174 -0
  802. package/dist/types/personal.js +1 -0
  803. package/dist/types/personal.js.map +1 -0
  804. package/dist/types/relayer.cjs +17 -0
  805. package/dist/types/relayer.cjs.map +1 -0
  806. package/dist/types/relayer.d.ts +553 -0
  807. package/dist/types/relayer.js +1 -0
  808. package/dist/types/relayer.js.map +1 -0
  809. package/dist/types/runtimePermissions.cjs +17 -0
  810. package/dist/types/runtimePermissions.cjs.map +1 -0
  811. package/dist/types/runtimePermissions.d.ts +122 -0
  812. package/dist/types/runtimePermissions.js +1 -0
  813. package/dist/types/runtimePermissions.js.map +1 -0
  814. package/dist/types/storage.cjs +39 -0
  815. package/dist/types/storage.cjs.map +1 -0
  816. package/dist/types/storage.d.ts +117 -0
  817. package/dist/types/storage.js +15 -0
  818. package/dist/types/storage.js.map +1 -0
  819. package/dist/types/transactionResults.cjs +17 -0
  820. package/dist/types/transactionResults.cjs.map +1 -0
  821. package/dist/types/transactionResults.d.ts +193 -0
  822. package/dist/types/transactionResults.js +1 -0
  823. package/dist/types/transactionResults.js.map +1 -0
  824. package/dist/types/utils.cjs +17 -0
  825. package/dist/types/utils.cjs.map +1 -0
  826. package/dist/types/utils.d.ts +771 -0
  827. package/dist/types/utils.js +1 -0
  828. package/dist/types/utils.js.map +1 -0
  829. package/dist/types.cjs +23 -0
  830. package/dist/types.cjs.map +1 -0
  831. package/dist/types.d.ts +30 -0
  832. package/dist/types.js +2 -0
  833. package/dist/types.js.map +1 -0
  834. package/dist/utils/__tests__/chainQuery.test.d.ts +1 -0
  835. package/dist/utils/__tests__/parseTransaction.test.d.ts +1 -0
  836. package/dist/utils/__tests__/pojo-serialization.test.d.ts +1 -0
  837. package/dist/utils/__tests__/signatureCache.test.d.ts +1 -0
  838. package/dist/utils/__tests__/subgraphConsistency.test.d.ts +4 -0
  839. package/dist/utils/__tests__/subgraphPagination.test.d.ts +4 -0
  840. package/dist/utils/__tests__/transaction-edge-cases.test.d.ts +1 -0
  841. package/dist/utils/__tests__/transactionHelpers.test.d.ts +1 -0
  842. package/dist/utils/__tests__/urlResolver.test.d.ts +4 -0
  843. package/dist/utils/blockchain/registry.cjs +81 -0
  844. package/dist/utils/blockchain/registry.cjs.map +1 -0
  845. package/dist/utils/blockchain/registry.d.ts +32 -0
  846. package/dist/utils/blockchain/registry.js +56 -0
  847. package/dist/utils/blockchain/registry.js.map +1 -0
  848. package/dist/utils/blockchain/registry.test.d.ts +1 -0
  849. package/dist/utils/chainQuery.cjs +107 -0
  850. package/dist/utils/chainQuery.cjs.map +1 -0
  851. package/dist/utils/chainQuery.d.ts +31 -0
  852. package/dist/utils/chainQuery.js +82 -0
  853. package/dist/utils/chainQuery.js.map +1 -0
  854. package/dist/utils/crypto-utils.cjs +108 -0
  855. package/dist/utils/crypto-utils.cjs.map +1 -0
  856. package/dist/utils/crypto-utils.d.ts +100 -0
  857. package/dist/utils/crypto-utils.js +76 -0
  858. package/dist/utils/crypto-utils.js.map +1 -0
  859. package/dist/utils/crypto-utils.test.d.ts +1 -0
  860. package/dist/utils/download.cjs +69 -0
  861. package/dist/utils/download.cjs.map +1 -0
  862. package/dist/utils/download.d.ts +40 -0
  863. package/dist/utils/download.js +45 -0
  864. package/dist/utils/download.js.map +1 -0
  865. package/dist/utils/encoding.cjs +66 -0
  866. package/dist/utils/encoding.cjs.map +1 -0
  867. package/dist/utils/encoding.d.ts +52 -0
  868. package/dist/utils/encoding.js +39 -0
  869. package/dist/utils/encoding.js.map +1 -0
  870. package/dist/utils/encoding.test.d.ts +1 -0
  871. package/dist/utils/encryption.cjs +176 -0
  872. package/dist/utils/encryption.cjs.map +1 -0
  873. package/dist/utils/encryption.d.ts +271 -0
  874. package/dist/utils/encryption.js +142 -0
  875. package/dist/utils/encryption.js.map +1 -0
  876. package/dist/utils/formatters.cjs +55 -0
  877. package/dist/utils/formatters.cjs.map +1 -0
  878. package/dist/utils/formatters.d.ts +118 -0
  879. package/dist/utils/formatters.js +28 -0
  880. package/dist/utils/formatters.js.map +1 -0
  881. package/dist/utils/grantFiles.cjs +181 -0
  882. package/dist/utils/grantFiles.cjs.map +1 -0
  883. package/dist/utils/grantFiles.d.ts +172 -0
  884. package/dist/utils/grantFiles.js +143 -0
  885. package/dist/utils/grantFiles.js.map +1 -0
  886. package/dist/utils/grantValidation.cjs +243 -0
  887. package/dist/utils/grantValidation.cjs.map +1 -0
  888. package/dist/utils/grantValidation.d.ts +226 -0
  889. package/dist/utils/grantValidation.js +201 -0
  890. package/dist/utils/grantValidation.js.map +1 -0
  891. package/dist/utils/grants.cjs +108 -0
  892. package/dist/utils/grants.cjs.map +1 -0
  893. package/dist/utils/grants.d.ts +148 -0
  894. package/dist/utils/grants.js +82 -0
  895. package/dist/utils/grants.js.map +1 -0
  896. package/dist/utils/ipfs.cjs +128 -0
  897. package/dist/utils/ipfs.cjs.map +1 -0
  898. package/dist/utils/ipfs.d.ts +88 -0
  899. package/dist/utils/ipfs.js +97 -0
  900. package/dist/utils/ipfs.js.map +1 -0
  901. package/dist/utils/lazy-import.cjs +38 -0
  902. package/dist/utils/lazy-import.cjs.map +1 -0
  903. package/dist/utils/lazy-import.d.ts +43 -0
  904. package/dist/utils/lazy-import.js +14 -0
  905. package/dist/utils/lazy-import.js.map +1 -0
  906. package/dist/utils/multicall.cjs +233 -0
  907. package/dist/utils/multicall.cjs.map +1 -0
  908. package/dist/utils/multicall.d.ts +126 -0
  909. package/dist/utils/multicall.js +208 -0
  910. package/dist/utils/multicall.js.map +1 -0
  911. package/dist/utils/parseTransactionPojo.cjs +87 -0
  912. package/dist/utils/parseTransactionPojo.cjs.map +1 -0
  913. package/dist/utils/parseTransactionPojo.d.ts +31 -0
  914. package/dist/utils/parseTransactionPojo.js +63 -0
  915. package/dist/utils/parseTransactionPojo.js.map +1 -0
  916. package/dist/utils/runtimeGrantFiles.cjs +84 -0
  917. package/dist/utils/runtimeGrantFiles.cjs.map +1 -0
  918. package/dist/utils/runtimeGrantFiles.d.ts +66 -0
  919. package/dist/utils/runtimeGrantFiles.js +58 -0
  920. package/dist/utils/runtimeGrantFiles.js.map +1 -0
  921. package/dist/utils/schemaValidation.cjs +258 -0
  922. package/dist/utils/schemaValidation.cjs.map +1 -0
  923. package/dist/utils/schemaValidation.d.ts +168 -0
  924. package/dist/utils/schemaValidation.js +219 -0
  925. package/dist/utils/schemaValidation.js.map +1 -0
  926. package/dist/utils/signatureCache.cjs +192 -0
  927. package/dist/utils/signatureCache.cjs.map +1 -0
  928. package/dist/utils/signatureCache.d.ts +172 -0
  929. package/dist/utils/signatureCache.js +167 -0
  930. package/dist/utils/signatureCache.js.map +1 -0
  931. package/dist/utils/signatureFormatter.cjs +42 -0
  932. package/dist/utils/signatureFormatter.cjs.map +1 -0
  933. package/dist/utils/signatureFormatter.d.ts +36 -0
  934. package/dist/utils/signatureFormatter.js +18 -0
  935. package/dist/utils/signatureFormatter.js.map +1 -0
  936. package/dist/utils/subgraphConsistency.cjs +184 -0
  937. package/dist/utils/subgraphConsistency.cjs.map +1 -0
  938. package/dist/utils/subgraphConsistency.d.ts +65 -0
  939. package/dist/utils/subgraphConsistency.js +155 -0
  940. package/dist/utils/subgraphConsistency.js.map +1 -0
  941. package/dist/utils/subgraphMetaCache.cjs +101 -0
  942. package/dist/utils/subgraphMetaCache.cjs.map +1 -0
  943. package/dist/utils/subgraphMetaCache.d.ts +56 -0
  944. package/dist/utils/subgraphMetaCache.js +76 -0
  945. package/dist/utils/subgraphMetaCache.js.map +1 -0
  946. package/dist/utils/subgraphPagination.cjs +104 -0
  947. package/dist/utils/subgraphPagination.cjs.map +1 -0
  948. package/dist/utils/subgraphPagination.d.ts +78 -0
  949. package/dist/utils/subgraphPagination.js +78 -0
  950. package/dist/utils/subgraphPagination.js.map +1 -0
  951. package/dist/utils/tests/multicall.test.d.ts +1 -0
  952. package/dist/utils/transactionHelpers.cjs +54 -0
  953. package/dist/utils/transactionHelpers.cjs.map +1 -0
  954. package/dist/utils/transactionHelpers.d.ts +80 -0
  955. package/dist/utils/transactionHelpers.js +29 -0
  956. package/dist/utils/transactionHelpers.js.map +1 -0
  957. package/dist/utils/typeGuards.cjs +109 -0
  958. package/dist/utils/typeGuards.cjs.map +1 -0
  959. package/dist/utils/typeGuards.d.ts +138 -0
  960. package/dist/utils/typeGuards.js +74 -0
  961. package/dist/utils/typeGuards.js.map +1 -0
  962. package/dist/utils/typedDataConverter.cjs +43 -0
  963. package/dist/utils/typedDataConverter.cjs.map +1 -0
  964. package/dist/utils/typedDataConverter.d.ts +46 -0
  965. package/dist/utils/typedDataConverter.js +19 -0
  966. package/dist/utils/typedDataConverter.js.map +1 -0
  967. package/dist/utils/urlResolver.cjs +62 -0
  968. package/dist/utils/urlResolver.cjs.map +1 -0
  969. package/dist/utils/urlResolver.d.ts +56 -0
  970. package/dist/utils/urlResolver.js +37 -0
  971. package/dist/utils/urlResolver.js.map +1 -0
  972. package/dist/utils/wallet.cjs +63 -0
  973. package/dist/utils/wallet.cjs.map +1 -0
  974. package/dist/utils/wallet.d.ts +94 -0
  975. package/dist/utils/wallet.js +37 -0
  976. package/dist/utils/wallet.js.map +1 -0
  977. package/dist/utils/withEvents.cjs +44 -0
  978. package/dist/utils/withEvents.cjs.map +1 -0
  979. package/dist/utils/withEvents.d.ts +56 -0
  980. package/dist/utils/withEvents.js +18 -0
  981. package/dist/utils/withEvents.js.map +1 -0
  982. package/package.json +79 -37
  983. package/dist/browser-cRpdLQ3-.d.ts +0 -237
  984. package/dist/chains.browser.cjs.map +0 -1
  985. package/dist/chains.d.cts +0 -2
  986. package/dist/chains.node.d.cts +0 -2
  987. package/dist/index.d.cts +0 -2
  988. package/dist/node-CkdgwBiv.d.cts +0 -237
  989. package/dist/node-CkdgwBiv.d.ts +0 -237
  990. package/dist/node.d.cts +0 -1
  991. package/dist/platform.d.cts +0 -2
  992. package/dist/platform.node.d.cts +0 -101
@@ -0,0 +1,244 @@
1
+ import { ECIESError, isECIESEncrypted } from "./interface";
2
+ import { CURVE, CIPHER, KDF } from "./constants";
3
+ import { constantTimeEqual } from "./utils";
4
+ import { concat } from "viem";
5
+ class BaseECIESUint8 {
6
+ // Cache for validated public keys to avoid repeated validation
7
+ static validatedKeys = /* @__PURE__ */ new WeakMap();
8
+ /**
9
+ * Normalizes a public key to uncompressed format.
10
+ *
11
+ * @param publicKey - Public key in any format.
12
+ * @returns Uncompressed public key (65 bytes).
13
+ * @throws {ECIESError} If key format is invalid.
14
+ */
15
+ normalizePublicKey(publicKey) {
16
+ if (BaseECIESUint8.validatedKeys.get(publicKey)) {
17
+ return publicKey;
18
+ }
19
+ if (publicKey.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH) {
20
+ if (publicKey[0] !== CURVE.PREFIX.UNCOMPRESSED) {
21
+ throw new ECIESError(
22
+ "Invalid uncompressed public key prefix",
23
+ "INVALID_KEY"
24
+ );
25
+ }
26
+ if (!this.validatePublicKey(publicKey)) {
27
+ throw new ECIESError("Invalid public key", "INVALID_KEY");
28
+ }
29
+ BaseECIESUint8.validatedKeys.set(publicKey, true);
30
+ return publicKey;
31
+ }
32
+ if (publicKey.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH) {
33
+ if (publicKey[0] === CURVE.PREFIX.COMPRESSED_EVEN || publicKey[0] === CURVE.PREFIX.COMPRESSED_ODD) {
34
+ const decompressed = this.decompressPublicKey(publicKey);
35
+ if (!decompressed) {
36
+ throw new ECIESError(
37
+ "Failed to decompress public key",
38
+ "INVALID_KEY"
39
+ );
40
+ }
41
+ BaseECIESUint8.validatedKeys.set(decompressed, true);
42
+ return decompressed;
43
+ }
44
+ throw new ECIESError(
45
+ `Invalid compressed public key prefix: expected 0x02 or 0x03, got 0x${publicKey[0].toString(16).padStart(2, "0")}`,
46
+ "INVALID_KEY"
47
+ );
48
+ }
49
+ throw new ECIESError(
50
+ `Invalid public key length: ${publicKey.length}`,
51
+ "INVALID_KEY"
52
+ );
53
+ }
54
+ /**
55
+ * Encrypts data using ECIES.
56
+ *
57
+ * @param publicKey - The recipient's public key (compressed or uncompressed)
58
+ * @param message - The data to encrypt
59
+ * @returns Promise resolving to encrypted data structure
60
+ */
61
+ async encrypt(publicKey, message) {
62
+ let ephemeralPrivateKey;
63
+ let sharedSecret;
64
+ let kdf;
65
+ let encryptionKey;
66
+ let macKey;
67
+ try {
68
+ if (!(publicKey instanceof Uint8Array)) {
69
+ throw new ECIESError("Public key must be a Uint8Array", "INVALID_KEY");
70
+ }
71
+ if (!(message instanceof Uint8Array)) {
72
+ throw new ECIESError(
73
+ "Message must be a Uint8Array",
74
+ "ENCRYPTION_FAILED"
75
+ );
76
+ }
77
+ if (publicKey.length === 0) {
78
+ throw new ECIESError("Public key cannot be empty", "INVALID_KEY");
79
+ }
80
+ const pubKey = this.normalizePublicKey(publicKey);
81
+ do {
82
+ ephemeralPrivateKey = this.generateRandomBytes(
83
+ CURVE.PRIVATE_KEY_LENGTH
84
+ );
85
+ } while (!this.verifyPrivateKey(ephemeralPrivateKey));
86
+ const ephemeralPublicKey = this.createPublicKey(
87
+ ephemeralPrivateKey,
88
+ false
89
+ );
90
+ if (!ephemeralPublicKey) {
91
+ throw new ECIESError(
92
+ "Failed to generate ephemeral public key",
93
+ "ENCRYPTION_FAILED"
94
+ );
95
+ }
96
+ sharedSecret = this.performECDH(pubKey, ephemeralPrivateKey);
97
+ kdf = this.sha512(sharedSecret);
98
+ encryptionKey = kdf.slice(
99
+ KDF.ENCRYPTION_KEY_OFFSET,
100
+ KDF.ENCRYPTION_KEY_OFFSET + KDF.ENCRYPTION_KEY_LENGTH
101
+ );
102
+ macKey = kdf.slice(
103
+ KDF.MAC_KEY_OFFSET,
104
+ KDF.MAC_KEY_OFFSET + KDF.MAC_KEY_LENGTH
105
+ );
106
+ const iv = this.generateRandomBytes(CIPHER.IV_LENGTH);
107
+ const ciphertext = await this.aesEncrypt(encryptionKey, iv, message);
108
+ const macData = concat([iv, ephemeralPublicKey, ciphertext]);
109
+ const mac = this.hmacSha256(macKey, macData);
110
+ return {
111
+ iv,
112
+ ephemPublicKey: ephemeralPublicKey,
113
+ ciphertext,
114
+ mac
115
+ };
116
+ } catch (error) {
117
+ if (error instanceof ECIESError) throw error;
118
+ throw new ECIESError(
119
+ `Encryption failed: ${error instanceof Error ? error.message : "Unknown error"}`,
120
+ "ENCRYPTION_FAILED",
121
+ error instanceof Error ? error : void 0
122
+ );
123
+ } finally {
124
+ if (ephemeralPrivateKey) this.clearBuffer(ephemeralPrivateKey);
125
+ if (sharedSecret) this.clearBuffer(sharedSecret);
126
+ if (kdf) this.clearBuffer(kdf);
127
+ if (encryptionKey) this.clearBuffer(encryptionKey);
128
+ if (macKey) this.clearBuffer(macKey);
129
+ }
130
+ }
131
+ /**
132
+ * Decrypts ECIES encrypted data.
133
+ *
134
+ * @param privateKey - The recipient's private key (32 bytes)
135
+ * @param encrypted - The encrypted data structure from encrypt()
136
+ * @returns Promise resolving to the original plaintext
137
+ */
138
+ async decrypt(privateKey, encrypted) {
139
+ let sharedSecret;
140
+ let kdf;
141
+ let encryptionKey;
142
+ let macKey;
143
+ try {
144
+ if (!(privateKey instanceof Uint8Array)) {
145
+ throw new ECIESError("Private key must be a Uint8Array", "INVALID_KEY");
146
+ }
147
+ if (!isECIESEncrypted(encrypted)) {
148
+ throw new ECIESError(
149
+ "Invalid encrypted data structure",
150
+ "DECRYPTION_FAILED"
151
+ );
152
+ }
153
+ if (privateKey.length !== CURVE.PRIVATE_KEY_LENGTH) {
154
+ throw new ECIESError(
155
+ `Invalid private key length: ${privateKey.length}`,
156
+ "INVALID_KEY"
157
+ );
158
+ }
159
+ if (!this.verifyPrivateKey(privateKey)) {
160
+ throw new ECIESError("Invalid private key", "INVALID_KEY");
161
+ }
162
+ if (encrypted.ephemPublicKey.length !== CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH) {
163
+ throw new ECIESError(
164
+ `Invalid ephemeral public key: expected ${CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH} bytes (uncompressed), got ${encrypted.ephemPublicKey.length} bytes`,
165
+ "INVALID_KEY"
166
+ );
167
+ }
168
+ if (encrypted.ephemPublicKey[0] !== CURVE.PREFIX.UNCOMPRESSED) {
169
+ throw new ECIESError(
170
+ "Invalid ephemeral public key: must be uncompressed format with 0x04 prefix (eccrypto standard)",
171
+ "INVALID_KEY"
172
+ );
173
+ }
174
+ if (!this.validatePublicKey(encrypted.ephemPublicKey)) {
175
+ throw new ECIESError("Invalid ephemeral public key", "INVALID_KEY");
176
+ }
177
+ const ephemeralPublicKey = encrypted.ephemPublicKey;
178
+ sharedSecret = this.performECDH(ephemeralPublicKey, privateKey);
179
+ kdf = this.sha512(sharedSecret);
180
+ encryptionKey = kdf.slice(
181
+ KDF.ENCRYPTION_KEY_OFFSET,
182
+ KDF.ENCRYPTION_KEY_OFFSET + KDF.ENCRYPTION_KEY_LENGTH
183
+ );
184
+ macKey = kdf.slice(
185
+ KDF.MAC_KEY_OFFSET,
186
+ KDF.MAC_KEY_OFFSET + KDF.MAC_KEY_LENGTH
187
+ );
188
+ const macData = concat([
189
+ encrypted.iv,
190
+ encrypted.ephemPublicKey,
191
+ encrypted.ciphertext
192
+ ]);
193
+ const expectedMac = this.hmacSha256(macKey, macData);
194
+ if (!constantTimeEqual(encrypted.mac, expectedMac)) {
195
+ throw new ECIESError("MAC verification failed", "MAC_MISMATCH");
196
+ }
197
+ const decrypted = await this.aesDecrypt(
198
+ encryptionKey,
199
+ encrypted.iv,
200
+ encrypted.ciphertext
201
+ );
202
+ return decrypted;
203
+ } catch (error) {
204
+ if (error instanceof ECIESError) throw error;
205
+ throw new ECIESError(
206
+ `Decryption failed: ${error instanceof Error ? error.message : "Unknown error"}`,
207
+ "DECRYPTION_FAILED",
208
+ error instanceof Error ? error : void 0
209
+ );
210
+ } finally {
211
+ if (sharedSecret) this.clearBuffer(sharedSecret);
212
+ if (kdf) this.clearBuffer(kdf);
213
+ if (encryptionKey) this.clearBuffer(encryptionKey);
214
+ if (macKey) this.clearBuffer(macKey);
215
+ }
216
+ }
217
+ /**
218
+ * Clears sensitive data from memory using multi-pass overwrite.
219
+ *
220
+ * @remarks
221
+ * Uses multiple passes with different patterns to make it harder
222
+ * for JIT compilers to optimize away the operation. While not
223
+ * guaranteed in JavaScript, this is a best-effort approach to
224
+ * clear sensitive data from memory.
225
+ *
226
+ * @param buffer - The buffer to clear
227
+ */
228
+ clearBuffer(buffer) {
229
+ if (buffer && buffer.length > 0) {
230
+ buffer.fill(0);
231
+ buffer.fill(255);
232
+ buffer.fill(170);
233
+ buffer.fill(0);
234
+ for (let i = 0; i < buffer.length; i++) {
235
+ buffer[i] = i & 255 ^ 90;
236
+ }
237
+ buffer.fill(0);
238
+ }
239
+ }
240
+ }
241
+ export {
242
+ BaseECIESUint8
243
+ };
244
+ //# sourceMappingURL=base.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/base.ts"],"sourcesContent":["import type { ECIESProvider, ECIESEncrypted } from \"./interface\";\nimport { ECIESError, isECIESEncrypted } from \"./interface\";\nimport { CURVE, CIPHER, KDF } from \"./constants\";\nimport { constantTimeEqual } from \"./utils\";\nimport { concat } from \"viem\";\n\n/**\n * Provides shared ECIES encryption logic across platforms using Uint8Array.\n *\n * @remarks\n * Platform implementations extend this class and provide crypto primitives.\n * The base class handles the ECIES protocol flow while maintaining\n * compatibility with the eccrypto data format.\n *\n * **Implementation details:**\n * - KDF: SHA-512(shared_secret) → encKey (32B) || macKey (32B)\n * - Cipher: AES-256-CBC with random 16-byte IV\n * - MAC: HMAC-SHA256(macKey, iv || ephemPublicKey || ciphertext)\n *\n * @category Cryptography\n */\nexport abstract class BaseECIESUint8 implements ECIESProvider {\n // Cache for validated public keys to avoid repeated validation\n private static readonly validatedKeys = new WeakMap<Uint8Array, boolean>();\n\n /**\n * Generates cryptographically secure random bytes.\n *\n * @param length - Number of random bytes to generate.\n * @returns Random bytes array.\n */\n protected abstract generateRandomBytes(length: number): Uint8Array;\n\n /**\n * Verifies a private key is valid for secp256k1.\n *\n * @param privateKey - Private key to verify (32 bytes).\n * @returns `true` if valid private key.\n */\n protected abstract verifyPrivateKey(privateKey: Uint8Array): boolean;\n\n /**\n * Creates a public key from a private key.\n *\n * @param privateKey - Source private key (32 bytes).\n * @param compressed - Generate compressed (33B) or uncompressed (65B) format.\n * @returns Public key or `null` if creation failed.\n */\n protected abstract createPublicKey(\n privateKey: Uint8Array,\n compressed: boolean,\n ): Uint8Array | null;\n\n /**\n * Validates a public key on the secp256k1 curve.\n *\n * @param publicKey - Public key to validate.\n * @returns `true` if valid public key.\n */\n protected abstract validatePublicKey(publicKey: Uint8Array): boolean;\n\n /**\n * Decompresses a compressed public key.\n *\n * @param publicKey - Compressed public key (33 bytes).\n * @returns Uncompressed public key (65 bytes) or `null` if decompression failed.\n */\n protected abstract decompressPublicKey(\n publicKey: Uint8Array,\n ): Uint8Array | null;\n\n /**\n * Performs ECDH key agreement.\n *\n * @param publicKey - Other party's public key.\n * @param privateKey - Your private key.\n * @returns Raw X coordinate of shared point (32 bytes).\n */\n protected abstract performECDH(\n publicKey: Uint8Array,\n privateKey: Uint8Array,\n ): Uint8Array;\n\n /**\n * Computes SHA-512 hash.\n *\n * @param data - Data to hash.\n * @returns SHA-512 hash (64 bytes).\n */\n protected abstract sha512(data: Uint8Array): Uint8Array;\n\n /**\n * Computes HMAC-SHA256 authentication tag.\n *\n * @param key - HMAC key.\n * @param data - Data to authenticate.\n * @returns HMAC-SHA256 (32 bytes).\n */\n protected abstract hmacSha256(key: Uint8Array, data: Uint8Array): Uint8Array;\n\n /**\n * Encrypts data using AES-256-CBC.\n *\n * @param key - Encryption key (32 bytes).\n * @param iv - Initialization vector (16 bytes).\n * @param plaintext - Data to encrypt.\n * @returns Ciphertext with PKCS#7 padding.\n */\n protected abstract aesEncrypt(\n key: Uint8Array,\n iv: Uint8Array,\n plaintext: Uint8Array,\n ): Promise<Uint8Array>;\n\n /**\n * Decrypts data using AES-256-CBC.\n *\n * @param key - Decryption key (32 bytes).\n * @param iv - Initialization vector (16 bytes).\n * @param ciphertext - Data to decrypt.\n * @returns Plaintext with padding removed.\n */\n protected abstract aesDecrypt(\n key: Uint8Array,\n iv: Uint8Array,\n ciphertext: Uint8Array,\n ): Promise<Uint8Array>;\n\n /**\n * Normalizes a public key to uncompressed format.\n *\n * @param publicKey - Public key in any format.\n * @returns Uncompressed public key (65 bytes).\n * @throws {ECIESError} If key format is invalid.\n */\n protected normalizePublicKey(publicKey: Uint8Array): Uint8Array {\n // Check cache first\n if (BaseECIESUint8.validatedKeys.get(publicKey)) {\n return publicKey;\n }\n\n if (publicKey.length === CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH) {\n if (publicKey[0] !== CURVE.PREFIX.UNCOMPRESSED) {\n throw new ECIESError(\n \"Invalid uncompressed public key prefix\",\n \"INVALID_KEY\",\n );\n }\n // Validate and cache\n if (!this.validatePublicKey(publicKey)) {\n throw new ECIESError(\"Invalid public key\", \"INVALID_KEY\");\n }\n BaseECIESUint8.validatedKeys.set(publicKey, true);\n return publicKey;\n }\n\n if (publicKey.length === CURVE.COMPRESSED_PUBLIC_KEY_LENGTH) {\n if (\n publicKey[0] === CURVE.PREFIX.COMPRESSED_EVEN ||\n publicKey[0] === CURVE.PREFIX.COMPRESSED_ODD\n ) {\n const decompressed = this.decompressPublicKey(publicKey);\n if (!decompressed) {\n throw new ECIESError(\n \"Failed to decompress public key\",\n \"INVALID_KEY\",\n );\n }\n // Cache the decompressed key\n BaseECIESUint8.validatedKeys.set(decompressed, true);\n return decompressed;\n }\n throw new ECIESError(\n `Invalid compressed public key prefix: expected 0x02 or 0x03, got 0x${publicKey[0].toString(16).padStart(2, \"0\")}`,\n \"INVALID_KEY\",\n );\n }\n\n throw new ECIESError(\n `Invalid public key length: ${publicKey.length}`,\n \"INVALID_KEY\",\n );\n }\n\n /**\n * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).\n * Must be implemented by derived classes to handle platform-specific operations.\n *\n * @param publicKey - The public key to normalize\n * @returns The normalized uncompressed public key\n */\n public abstract normalizeToUncompressed(publicKey: Uint8Array): Uint8Array;\n\n /**\n * Encrypts data using ECIES.\n *\n * @param publicKey - The recipient's public key (compressed or uncompressed)\n * @param message - The data to encrypt\n * @returns Promise resolving to encrypted data structure\n */\n async encrypt(\n publicKey: Uint8Array,\n message: Uint8Array,\n ): Promise<ECIESEncrypted> {\n // Declare sensitive variables outside try so finally can access them\n let ephemeralPrivateKey: Uint8Array | undefined;\n let sharedSecret: Uint8Array | undefined;\n let kdf: Uint8Array | undefined;\n let encryptionKey: Uint8Array | undefined;\n let macKey: Uint8Array | undefined;\n\n try {\n // Validate inputs\n if (!(publicKey instanceof Uint8Array)) {\n throw new ECIESError(\"Public key must be a Uint8Array\", \"INVALID_KEY\");\n }\n if (!(message instanceof Uint8Array)) {\n throw new ECIESError(\n \"Message must be a Uint8Array\",\n \"ENCRYPTION_FAILED\",\n );\n }\n if (publicKey.length === 0) {\n throw new ECIESError(\"Public key cannot be empty\", \"INVALID_KEY\");\n }\n\n // Normalize public key to uncompressed format\n const pubKey = this.normalizePublicKey(publicKey);\n\n // Generate ephemeral key pair\n do {\n ephemeralPrivateKey = this.generateRandomBytes(\n CURVE.PRIVATE_KEY_LENGTH,\n );\n } while (!this.verifyPrivateKey(ephemeralPrivateKey));\n\n const ephemeralPublicKey = this.createPublicKey(\n ephemeralPrivateKey,\n false,\n );\n if (!ephemeralPublicKey) {\n throw new ECIESError(\n \"Failed to generate ephemeral public key\",\n \"ENCRYPTION_FAILED\",\n );\n }\n\n // Perform ECDH to get shared secret (raw X coordinate)\n sharedSecret = this.performECDH(pubKey, ephemeralPrivateKey);\n\n // Derive keys using SHA-512 (eccrypto-compatible KDF)\n kdf = this.sha512(sharedSecret);\n encryptionKey = kdf.slice(\n KDF.ENCRYPTION_KEY_OFFSET,\n KDF.ENCRYPTION_KEY_OFFSET + KDF.ENCRYPTION_KEY_LENGTH,\n );\n macKey = kdf.slice(\n KDF.MAC_KEY_OFFSET,\n KDF.MAC_KEY_OFFSET + KDF.MAC_KEY_LENGTH,\n );\n\n // Generate random IV and encrypt\n const iv = this.generateRandomBytes(CIPHER.IV_LENGTH);\n const ciphertext = await this.aesEncrypt(encryptionKey, iv, message);\n\n // Calculate MAC (Encrypt-then-MAC)\n const macData = concat([iv, ephemeralPublicKey, ciphertext]);\n const mac = this.hmacSha256(macKey, macData);\n\n return {\n iv,\n ephemPublicKey: ephemeralPublicKey,\n ciphertext,\n mac,\n };\n } catch (error) {\n if (error instanceof ECIESError) throw error;\n throw new ECIESError(\n `Encryption failed: ${error instanceof Error ? error.message : \"Unknown error\"}`,\n \"ENCRYPTION_FAILED\",\n error instanceof Error ? error : undefined,\n );\n } finally {\n // Clear sensitive data on all code paths (success, error, throw)\n if (ephemeralPrivateKey) this.clearBuffer(ephemeralPrivateKey);\n if (sharedSecret) this.clearBuffer(sharedSecret);\n if (kdf) this.clearBuffer(kdf);\n if (encryptionKey) this.clearBuffer(encryptionKey);\n if (macKey) this.clearBuffer(macKey);\n }\n }\n\n /**\n * Decrypts ECIES encrypted data.\n *\n * @param privateKey - The recipient's private key (32 bytes)\n * @param encrypted - The encrypted data structure from encrypt()\n * @returns Promise resolving to the original plaintext\n */\n async decrypt(\n privateKey: Uint8Array,\n encrypted: ECIESEncrypted,\n ): Promise<Uint8Array> {\n // Declare sensitive variables outside try so finally can access them\n let sharedSecret: Uint8Array | undefined;\n let kdf: Uint8Array | undefined;\n let encryptionKey: Uint8Array | undefined;\n let macKey: Uint8Array | undefined;\n\n try {\n // Validate inputs\n if (!(privateKey instanceof Uint8Array)) {\n throw new ECIESError(\"Private key must be a Uint8Array\", \"INVALID_KEY\");\n }\n if (!isECIESEncrypted(encrypted)) {\n throw new ECIESError(\n \"Invalid encrypted data structure\",\n \"DECRYPTION_FAILED\",\n );\n }\n if (privateKey.length !== CURVE.PRIVATE_KEY_LENGTH) {\n throw new ECIESError(\n `Invalid private key length: ${privateKey.length}`,\n \"INVALID_KEY\",\n );\n }\n if (!this.verifyPrivateKey(privateKey)) {\n throw new ECIESError(\"Invalid private key\", \"INVALID_KEY\");\n }\n\n // Strict validation: ephemeral keys must be 65-byte uncompressed (eccrypto standard)\n if (\n encrypted.ephemPublicKey.length !== CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH\n ) {\n throw new ECIESError(\n `Invalid ephemeral public key: expected ${CURVE.UNCOMPRESSED_PUBLIC_KEY_LENGTH} bytes (uncompressed), got ${encrypted.ephemPublicKey.length} bytes`,\n \"INVALID_KEY\",\n );\n }\n if (encrypted.ephemPublicKey[0] !== CURVE.PREFIX.UNCOMPRESSED) {\n throw new ECIESError(\n \"Invalid ephemeral public key: must be uncompressed format with 0x04 prefix (eccrypto standard)\",\n \"INVALID_KEY\",\n );\n }\n if (!this.validatePublicKey(encrypted.ephemPublicKey)) {\n throw new ECIESError(\"Invalid ephemeral public key\", \"INVALID_KEY\");\n }\n const ephemeralPublicKey = encrypted.ephemPublicKey;\n\n // Perform ECDH to recover shared secret\n sharedSecret = this.performECDH(ephemeralPublicKey, privateKey);\n\n // Derive keys using SHA-512 (eccrypto-compatible KDF)\n kdf = this.sha512(sharedSecret);\n encryptionKey = kdf.slice(\n KDF.ENCRYPTION_KEY_OFFSET,\n KDF.ENCRYPTION_KEY_OFFSET + KDF.ENCRYPTION_KEY_LENGTH,\n );\n macKey = kdf.slice(\n KDF.MAC_KEY_OFFSET,\n KDF.MAC_KEY_OFFSET + KDF.MAC_KEY_LENGTH,\n );\n\n // Verify MAC before decryption (Encrypt-then-MAC)\n const macData = concat([\n encrypted.iv,\n encrypted.ephemPublicKey,\n encrypted.ciphertext,\n ]);\n const expectedMac = this.hmacSha256(macKey, macData);\n\n if (!constantTimeEqual(encrypted.mac, expectedMac)) {\n throw new ECIESError(\"MAC verification failed\", \"MAC_MISMATCH\");\n }\n\n // Decrypt the ciphertext\n const decrypted = await this.aesDecrypt(\n encryptionKey,\n encrypted.iv,\n encrypted.ciphertext,\n );\n\n return decrypted;\n } catch (error) {\n if (error instanceof ECIESError) throw error;\n throw new ECIESError(\n `Decryption failed: ${error instanceof Error ? error.message : \"Unknown error\"}`,\n \"DECRYPTION_FAILED\",\n error instanceof Error ? error : undefined,\n );\n } finally {\n // Clear sensitive data on all code paths (success, error, throw)\n if (sharedSecret) this.clearBuffer(sharedSecret);\n if (kdf) this.clearBuffer(kdf);\n if (encryptionKey) this.clearBuffer(encryptionKey);\n if (macKey) this.clearBuffer(macKey);\n }\n }\n\n /**\n * Clears sensitive data from memory using multi-pass overwrite.\n *\n * @remarks\n * Uses multiple passes with different patterns to make it harder\n * for JIT compilers to optimize away the operation. While not\n * guaranteed in JavaScript, this is a best-effort approach to\n * clear sensitive data from memory.\n *\n * @param buffer - The buffer to clear\n */\n protected clearBuffer(buffer: Uint8Array): void {\n if (buffer && buffer.length > 0) {\n // Multi-pass overwrite to resist compiler optimization\n buffer.fill(0x00); // Fill with zeros\n buffer.fill(0xff); // Fill with ones\n buffer.fill(0xaa); // Fill with alternating pattern\n buffer.fill(0x00); // Final zero fill\n\n // Additional pattern write to further discourage optimization\n for (let i = 0; i < buffer.length; i++) {\n buffer[i] = (i & 0xff) ^ 0x5a; // XOR with pattern\n }\n buffer.fill(0x00); // Final clear\n }\n }\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,165 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var browser_exports = {};
30
+ __export(browser_exports, {
31
+ BrowserECIESUint8Provider: () => BrowserECIESUint8Provider
32
+ });
33
+ module.exports = __toCommonJS(browser_exports);
34
+ var secp256k1 = __toESM(require("@noble/secp256k1"), 1);
35
+ var import_base = require("./base");
36
+ var import_viem = require("viem");
37
+ var import_hmac = require("@noble/hashes/hmac");
38
+ var import_sha2 = require("@noble/hashes/sha2");
39
+ class BrowserECIESUint8Provider extends import_base.BaseECIESUint8 {
40
+ generateRandomBytes(length) {
41
+ const bytes = new Uint8Array(length);
42
+ crypto.getRandomValues(bytes);
43
+ return bytes;
44
+ }
45
+ verifyPrivateKey(privateKey) {
46
+ try {
47
+ return secp256k1.utils.isValidPrivateKey(privateKey);
48
+ } catch {
49
+ return false;
50
+ }
51
+ }
52
+ createPublicKey(privateKey, compressed) {
53
+ try {
54
+ return secp256k1.getPublicKey(privateKey, compressed);
55
+ } catch {
56
+ return null;
57
+ }
58
+ }
59
+ validatePublicKey(publicKey) {
60
+ try {
61
+ secp256k1.Point.fromHex(publicKey);
62
+ return true;
63
+ } catch {
64
+ return false;
65
+ }
66
+ }
67
+ decompressPublicKey(publicKey) {
68
+ try {
69
+ const point = secp256k1.Point.fromHex(publicKey);
70
+ return point.toRawBytes(false);
71
+ } catch {
72
+ return null;
73
+ }
74
+ }
75
+ performECDH(publicKey, privateKey) {
76
+ try {
77
+ const sharedPoint = secp256k1.getSharedSecret(
78
+ privateKey,
79
+ publicKey,
80
+ true
81
+ );
82
+ return sharedPoint.slice(1);
83
+ } catch (error) {
84
+ throw new Error(
85
+ `ECDH failed: ${error instanceof Error ? error.message : "Unknown error"}`
86
+ );
87
+ }
88
+ }
89
+ sha512(data) {
90
+ return (0, import_sha2.sha512)(data);
91
+ }
92
+ hmacSha256(key, data) {
93
+ return (0, import_hmac.hmac)(import_sha2.sha256, key, data);
94
+ }
95
+ async aesEncrypt(key, iv, plaintext) {
96
+ const cryptoKey = await crypto.subtle.importKey(
97
+ "raw",
98
+ key,
99
+ { name: "AES-CBC" },
100
+ false,
101
+ ["encrypt"]
102
+ );
103
+ const encrypted = await crypto.subtle.encrypt(
104
+ { name: "AES-CBC", iv },
105
+ cryptoKey,
106
+ plaintext
107
+ );
108
+ return new Uint8Array(encrypted);
109
+ }
110
+ async aesDecrypt(key, iv, ciphertext) {
111
+ const cryptoKey = await crypto.subtle.importKey(
112
+ "raw",
113
+ key,
114
+ { name: "AES-CBC" },
115
+ false,
116
+ ["decrypt"]
117
+ );
118
+ const decrypted = await crypto.subtle.decrypt(
119
+ { name: "AES-CBC", iv },
120
+ cryptoKey,
121
+ ciphertext
122
+ );
123
+ return new Uint8Array(decrypted);
124
+ }
125
+ /**
126
+ * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).
127
+ * Handles compressed (33 bytes) and uncompressed (65 bytes) formats only.
128
+ *
129
+ * @remarks
130
+ * Strict policy: Does not accept 64-byte raw coordinates to avoid masking
131
+ * malformed data. Callers must provide properly formatted keys.
132
+ *
133
+ * @param publicKey - The public key to normalize (33 or 65 bytes)
134
+ * @returns The normalized uncompressed public key (65 bytes)
135
+ * @throws {Error} When public key format is invalid or decompression fails
136
+ */
137
+ normalizeToUncompressed(publicKey) {
138
+ const len = publicKey.length;
139
+ if (len === 65 && publicKey[0] === 4) {
140
+ return publicKey;
141
+ }
142
+ if (len === 33 && (publicKey[0] === 2 || publicKey[0] === 3)) {
143
+ const decompressed = this.decompressPublicKey(publicKey);
144
+ if (!decompressed) {
145
+ throw new Error(
146
+ `Failed to decompress public key with prefix ${(0, import_viem.toHex)(publicKey[0])}`
147
+ );
148
+ }
149
+ return decompressed;
150
+ }
151
+ if (len === 64) {
152
+ throw new Error(
153
+ "Raw public key coordinates (64 bytes) are not accepted. Please provide a properly formatted compressed (33 bytes) or uncompressed (65 bytes) public key."
154
+ );
155
+ }
156
+ throw new Error(
157
+ `Invalid public key format: expected compressed (33 bytes) or uncompressed (65 bytes), got ${len} bytes`
158
+ );
159
+ }
160
+ }
161
+ // Annotate the CommonJS export names for ESM import in node:
162
+ 0 && (module.exports = {
163
+ BrowserECIESUint8Provider
164
+ });
165
+ //# sourceMappingURL=browser.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/browser.ts"],"sourcesContent":["/**\n * Browser implementation of ECIES using @noble/secp256k1 with Uint8Array\n *\n * @remarks\n * Uses native browser crypto APIs and @noble/secp256k1 for elliptic curve operations.\n * This implementation is polyfill-free and works in all modern browsers.\n */\n\nimport * as secp256k1 from \"@noble/secp256k1\";\nimport { BaseECIESUint8 } from \"./base\";\nimport { toHex } from \"viem\";\nimport { hmac } from \"@noble/hashes/hmac\";\nimport { sha256, sha512 as nobleSha512 } from \"@noble/hashes/sha2\";\n\n/**\n * Browser-specific ECIES provider using @noble/secp256k1\n *\n * @remarks\n * This implementation uses:\n * - Web Crypto API for AES operations\n * - @noble/secp256k1 for elliptic curve operations\n * - @noble/hashes for SHA and HMAC operations\n * - No Buffer or Node.js dependencies\n */\nexport class BrowserECIESUint8Provider extends BaseECIESUint8 {\n protected generateRandomBytes(length: number): Uint8Array {\n const bytes = new Uint8Array(length);\n crypto.getRandomValues(bytes);\n return bytes;\n }\n\n protected verifyPrivateKey(privateKey: Uint8Array): boolean {\n try {\n return secp256k1.utils.isValidPrivateKey(privateKey);\n } catch {\n return false;\n }\n }\n\n protected createPublicKey(\n privateKey: Uint8Array,\n compressed: boolean,\n ): Uint8Array | null {\n try {\n return secp256k1.getPublicKey(privateKey, compressed);\n } catch {\n return null;\n }\n }\n\n protected validatePublicKey(publicKey: Uint8Array): boolean {\n try {\n // @noble/secp256k1 will throw if the point is not on the curve\n secp256k1.Point.fromHex(publicKey);\n return true;\n } catch {\n return false;\n }\n }\n\n protected decompressPublicKey(publicKey: Uint8Array): Uint8Array | null {\n try {\n // @noble/secp256k1 handles both compressed and uncompressed\n const point = secp256k1.Point.fromHex(publicKey);\n return point.toRawBytes(false); // false = uncompressed\n } catch {\n return null;\n }\n }\n\n protected performECDH(\n publicKey: Uint8Array,\n privateKey: Uint8Array,\n ): Uint8Array {\n try {\n // Use @noble/secp256k1's getSharedSecret which is optimized and secure\n // The 'true' parameter returns the raw x-coordinate (32 bytes)\n // This matches eccrypto's behavior\n const sharedPoint = secp256k1.getSharedSecret(\n privateKey,\n publicKey,\n true,\n );\n\n // getSharedSecret returns compressed point (33 bytes) when true\n // We need just the x-coordinate (32 bytes) for eccrypto compatibility\n // Remove the prefix byte\n return sharedPoint.slice(1);\n } catch (error) {\n throw new Error(\n `ECDH failed: ${error instanceof Error ? error.message : \"Unknown error\"}`,\n );\n }\n }\n\n protected sha512(data: Uint8Array): Uint8Array {\n return nobleSha512(data);\n }\n\n protected hmacSha256(key: Uint8Array, data: Uint8Array): Uint8Array {\n return hmac(sha256, key, data);\n }\n\n protected async aesEncrypt(\n key: Uint8Array,\n iv: Uint8Array,\n plaintext: Uint8Array,\n ): Promise<Uint8Array> {\n // Import the key for AES-CBC\n const cryptoKey = await crypto.subtle.importKey(\n \"raw\",\n key as BufferSource,\n { name: \"AES-CBC\" },\n false,\n [\"encrypt\"],\n );\n\n // Encrypt with Web Crypto API\n // Note: Web Crypto API automatically handles PKCS#7 padding for AES-CBC\n const encrypted = await crypto.subtle.encrypt(\n { name: \"AES-CBC\", iv: iv as BufferSource },\n cryptoKey,\n plaintext as BufferSource,\n );\n\n return new Uint8Array(encrypted);\n }\n\n protected async aesDecrypt(\n key: Uint8Array,\n iv: Uint8Array,\n ciphertext: Uint8Array,\n ): Promise<Uint8Array> {\n // Import the key for AES-CBC\n const cryptoKey = await crypto.subtle.importKey(\n \"raw\",\n key as BufferSource,\n { name: \"AES-CBC\" },\n false,\n [\"decrypt\"],\n );\n\n // Decrypt with Web Crypto API\n // Note: Web Crypto API automatically handles PKCS#7 padding removal\n const decrypted = await crypto.subtle.decrypt(\n { name: \"AES-CBC\", iv: iv as BufferSource },\n cryptoKey,\n ciphertext as BufferSource,\n );\n\n return new Uint8Array(decrypted);\n }\n\n /**\n * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).\n * Handles compressed (33 bytes) and uncompressed (65 bytes) formats only.\n *\n * @remarks\n * Strict policy: Does not accept 64-byte raw coordinates to avoid masking\n * malformed data. Callers must provide properly formatted keys.\n *\n * @param publicKey - The public key to normalize (33 or 65 bytes)\n * @returns The normalized uncompressed public key (65 bytes)\n * @throws {Error} When public key format is invalid or decompression fails\n */\n normalizeToUncompressed(publicKey: Uint8Array): Uint8Array {\n const len = publicKey.length;\n\n // Already uncompressed\n if (len === 65 && publicKey[0] === 0x04) {\n return publicKey;\n }\n\n // Compressed - decompress using @noble/secp256k1\n if (len === 33 && (publicKey[0] === 0x02 || publicKey[0] === 0x03)) {\n const decompressed = this.decompressPublicKey(publicKey);\n if (!decompressed) {\n throw new Error(\n `Failed to decompress public key with prefix ${toHex(publicKey[0])}`,\n );\n }\n return decompressed;\n }\n\n // Reject raw coordinates (64 bytes) - require proper formatting\n if (len === 64) {\n throw new Error(\n \"Raw public key coordinates (64 bytes) are not accepted. \" +\n \"Please provide a properly formatted compressed (33 bytes) or uncompressed (65 bytes) public key.\",\n );\n }\n\n throw new Error(\n `Invalid public key format: expected compressed (33 bytes) or uncompressed (65 bytes), got ${len} bytes`,\n );\n }\n}\n"],"mappings":"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","names":["nobleSha512"]}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * Browser implementation of ECIES using @noble/secp256k1 with Uint8Array
3
+ *
4
+ * @remarks
5
+ * Uses native browser crypto APIs and @noble/secp256k1 for elliptic curve operations.
6
+ * This implementation is polyfill-free and works in all modern browsers.
7
+ */
8
+ import { BaseECIESUint8 } from "./base";
9
+ /**
10
+ * Browser-specific ECIES provider using @noble/secp256k1
11
+ *
12
+ * @remarks
13
+ * This implementation uses:
14
+ * - Web Crypto API for AES operations
15
+ * - @noble/secp256k1 for elliptic curve operations
16
+ * - @noble/hashes for SHA and HMAC operations
17
+ * - No Buffer or Node.js dependencies
18
+ */
19
+ export declare class BrowserECIESUint8Provider extends BaseECIESUint8 {
20
+ protected generateRandomBytes(length: number): Uint8Array;
21
+ protected verifyPrivateKey(privateKey: Uint8Array): boolean;
22
+ protected createPublicKey(privateKey: Uint8Array, compressed: boolean): Uint8Array | null;
23
+ protected validatePublicKey(publicKey: Uint8Array): boolean;
24
+ protected decompressPublicKey(publicKey: Uint8Array): Uint8Array | null;
25
+ protected performECDH(publicKey: Uint8Array, privateKey: Uint8Array): Uint8Array;
26
+ protected sha512(data: Uint8Array): Uint8Array;
27
+ protected hmacSha256(key: Uint8Array, data: Uint8Array): Uint8Array;
28
+ protected aesEncrypt(key: Uint8Array, iv: Uint8Array, plaintext: Uint8Array): Promise<Uint8Array>;
29
+ protected aesDecrypt(key: Uint8Array, iv: Uint8Array, ciphertext: Uint8Array): Promise<Uint8Array>;
30
+ /**
31
+ * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).
32
+ * Handles compressed (33 bytes) and uncompressed (65 bytes) formats only.
33
+ *
34
+ * @remarks
35
+ * Strict policy: Does not accept 64-byte raw coordinates to avoid masking
36
+ * malformed data. Callers must provide properly formatted keys.
37
+ *
38
+ * @param publicKey - The public key to normalize (33 or 65 bytes)
39
+ * @returns The normalized uncompressed public key (65 bytes)
40
+ * @throws {Error} When public key format is invalid or decompression fails
41
+ */
42
+ normalizeToUncompressed(publicKey: Uint8Array): Uint8Array;
43
+ }
@@ -0,0 +1,131 @@
1
+ import * as secp256k1 from "@noble/secp256k1";
2
+ import { BaseECIESUint8 } from "./base";
3
+ import { toHex } from "viem";
4
+ import { hmac } from "@noble/hashes/hmac";
5
+ import { sha256, sha512 as nobleSha512 } from "@noble/hashes/sha2";
6
+ class BrowserECIESUint8Provider extends BaseECIESUint8 {
7
+ generateRandomBytes(length) {
8
+ const bytes = new Uint8Array(length);
9
+ crypto.getRandomValues(bytes);
10
+ return bytes;
11
+ }
12
+ verifyPrivateKey(privateKey) {
13
+ try {
14
+ return secp256k1.utils.isValidPrivateKey(privateKey);
15
+ } catch {
16
+ return false;
17
+ }
18
+ }
19
+ createPublicKey(privateKey, compressed) {
20
+ try {
21
+ return secp256k1.getPublicKey(privateKey, compressed);
22
+ } catch {
23
+ return null;
24
+ }
25
+ }
26
+ validatePublicKey(publicKey) {
27
+ try {
28
+ secp256k1.Point.fromHex(publicKey);
29
+ return true;
30
+ } catch {
31
+ return false;
32
+ }
33
+ }
34
+ decompressPublicKey(publicKey) {
35
+ try {
36
+ const point = secp256k1.Point.fromHex(publicKey);
37
+ return point.toRawBytes(false);
38
+ } catch {
39
+ return null;
40
+ }
41
+ }
42
+ performECDH(publicKey, privateKey) {
43
+ try {
44
+ const sharedPoint = secp256k1.getSharedSecret(
45
+ privateKey,
46
+ publicKey,
47
+ true
48
+ );
49
+ return sharedPoint.slice(1);
50
+ } catch (error) {
51
+ throw new Error(
52
+ `ECDH failed: ${error instanceof Error ? error.message : "Unknown error"}`
53
+ );
54
+ }
55
+ }
56
+ sha512(data) {
57
+ return nobleSha512(data);
58
+ }
59
+ hmacSha256(key, data) {
60
+ return hmac(sha256, key, data);
61
+ }
62
+ async aesEncrypt(key, iv, plaintext) {
63
+ const cryptoKey = await crypto.subtle.importKey(
64
+ "raw",
65
+ key,
66
+ { name: "AES-CBC" },
67
+ false,
68
+ ["encrypt"]
69
+ );
70
+ const encrypted = await crypto.subtle.encrypt(
71
+ { name: "AES-CBC", iv },
72
+ cryptoKey,
73
+ plaintext
74
+ );
75
+ return new Uint8Array(encrypted);
76
+ }
77
+ async aesDecrypt(key, iv, ciphertext) {
78
+ const cryptoKey = await crypto.subtle.importKey(
79
+ "raw",
80
+ key,
81
+ { name: "AES-CBC" },
82
+ false,
83
+ ["decrypt"]
84
+ );
85
+ const decrypted = await crypto.subtle.decrypt(
86
+ { name: "AES-CBC", iv },
87
+ cryptoKey,
88
+ ciphertext
89
+ );
90
+ return new Uint8Array(decrypted);
91
+ }
92
+ /**
93
+ * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).
94
+ * Handles compressed (33 bytes) and uncompressed (65 bytes) formats only.
95
+ *
96
+ * @remarks
97
+ * Strict policy: Does not accept 64-byte raw coordinates to avoid masking
98
+ * malformed data. Callers must provide properly formatted keys.
99
+ *
100
+ * @param publicKey - The public key to normalize (33 or 65 bytes)
101
+ * @returns The normalized uncompressed public key (65 bytes)
102
+ * @throws {Error} When public key format is invalid or decompression fails
103
+ */
104
+ normalizeToUncompressed(publicKey) {
105
+ const len = publicKey.length;
106
+ if (len === 65 && publicKey[0] === 4) {
107
+ return publicKey;
108
+ }
109
+ if (len === 33 && (publicKey[0] === 2 || publicKey[0] === 3)) {
110
+ const decompressed = this.decompressPublicKey(publicKey);
111
+ if (!decompressed) {
112
+ throw new Error(
113
+ `Failed to decompress public key with prefix ${toHex(publicKey[0])}`
114
+ );
115
+ }
116
+ return decompressed;
117
+ }
118
+ if (len === 64) {
119
+ throw new Error(
120
+ "Raw public key coordinates (64 bytes) are not accepted. Please provide a properly formatted compressed (33 bytes) or uncompressed (65 bytes) public key."
121
+ );
122
+ }
123
+ throw new Error(
124
+ `Invalid public key format: expected compressed (33 bytes) or uncompressed (65 bytes), got ${len} bytes`
125
+ );
126
+ }
127
+ }
128
+ export {
129
+ BrowserECIESUint8Provider
130
+ };
131
+ //# sourceMappingURL=browser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/crypto/ecies/browser.ts"],"sourcesContent":["/**\n * Browser implementation of ECIES using @noble/secp256k1 with Uint8Array\n *\n * @remarks\n * Uses native browser crypto APIs and @noble/secp256k1 for elliptic curve operations.\n * This implementation is polyfill-free and works in all modern browsers.\n */\n\nimport * as secp256k1 from \"@noble/secp256k1\";\nimport { BaseECIESUint8 } from \"./base\";\nimport { toHex } from \"viem\";\nimport { hmac } from \"@noble/hashes/hmac\";\nimport { sha256, sha512 as nobleSha512 } from \"@noble/hashes/sha2\";\n\n/**\n * Browser-specific ECIES provider using @noble/secp256k1\n *\n * @remarks\n * This implementation uses:\n * - Web Crypto API for AES operations\n * - @noble/secp256k1 for elliptic curve operations\n * - @noble/hashes for SHA and HMAC operations\n * - No Buffer or Node.js dependencies\n */\nexport class BrowserECIESUint8Provider extends BaseECIESUint8 {\n protected generateRandomBytes(length: number): Uint8Array {\n const bytes = new Uint8Array(length);\n crypto.getRandomValues(bytes);\n return bytes;\n }\n\n protected verifyPrivateKey(privateKey: Uint8Array): boolean {\n try {\n return secp256k1.utils.isValidPrivateKey(privateKey);\n } catch {\n return false;\n }\n }\n\n protected createPublicKey(\n privateKey: Uint8Array,\n compressed: boolean,\n ): Uint8Array | null {\n try {\n return secp256k1.getPublicKey(privateKey, compressed);\n } catch {\n return null;\n }\n }\n\n protected validatePublicKey(publicKey: Uint8Array): boolean {\n try {\n // @noble/secp256k1 will throw if the point is not on the curve\n secp256k1.Point.fromHex(publicKey);\n return true;\n } catch {\n return false;\n }\n }\n\n protected decompressPublicKey(publicKey: Uint8Array): Uint8Array | null {\n try {\n // @noble/secp256k1 handles both compressed and uncompressed\n const point = secp256k1.Point.fromHex(publicKey);\n return point.toRawBytes(false); // false = uncompressed\n } catch {\n return null;\n }\n }\n\n protected performECDH(\n publicKey: Uint8Array,\n privateKey: Uint8Array,\n ): Uint8Array {\n try {\n // Use @noble/secp256k1's getSharedSecret which is optimized and secure\n // The 'true' parameter returns the raw x-coordinate (32 bytes)\n // This matches eccrypto's behavior\n const sharedPoint = secp256k1.getSharedSecret(\n privateKey,\n publicKey,\n true,\n );\n\n // getSharedSecret returns compressed point (33 bytes) when true\n // We need just the x-coordinate (32 bytes) for eccrypto compatibility\n // Remove the prefix byte\n return sharedPoint.slice(1);\n } catch (error) {\n throw new Error(\n `ECDH failed: ${error instanceof Error ? error.message : \"Unknown error\"}`,\n );\n }\n }\n\n protected sha512(data: Uint8Array): Uint8Array {\n return nobleSha512(data);\n }\n\n protected hmacSha256(key: Uint8Array, data: Uint8Array): Uint8Array {\n return hmac(sha256, key, data);\n }\n\n protected async aesEncrypt(\n key: Uint8Array,\n iv: Uint8Array,\n plaintext: Uint8Array,\n ): Promise<Uint8Array> {\n // Import the key for AES-CBC\n const cryptoKey = await crypto.subtle.importKey(\n \"raw\",\n key as BufferSource,\n { name: \"AES-CBC\" },\n false,\n [\"encrypt\"],\n );\n\n // Encrypt with Web Crypto API\n // Note: Web Crypto API automatically handles PKCS#7 padding for AES-CBC\n const encrypted = await crypto.subtle.encrypt(\n { name: \"AES-CBC\", iv: iv as BufferSource },\n cryptoKey,\n plaintext as BufferSource,\n );\n\n return new Uint8Array(encrypted);\n }\n\n protected async aesDecrypt(\n key: Uint8Array,\n iv: Uint8Array,\n ciphertext: Uint8Array,\n ): Promise<Uint8Array> {\n // Import the key for AES-CBC\n const cryptoKey = await crypto.subtle.importKey(\n \"raw\",\n key as BufferSource,\n { name: \"AES-CBC\" },\n false,\n [\"decrypt\"],\n );\n\n // Decrypt with Web Crypto API\n // Note: Web Crypto API automatically handles PKCS#7 padding removal\n const decrypted = await crypto.subtle.decrypt(\n { name: \"AES-CBC\", iv: iv as BufferSource },\n cryptoKey,\n ciphertext as BufferSource,\n );\n\n return new Uint8Array(decrypted);\n }\n\n /**\n * Normalizes a public key to uncompressed format (65 bytes with 0x04 prefix).\n * Handles compressed (33 bytes) and uncompressed (65 bytes) formats only.\n *\n * @remarks\n * Strict policy: Does not accept 64-byte raw coordinates to avoid masking\n * malformed data. Callers must provide properly formatted keys.\n *\n * @param publicKey - The public key to normalize (33 or 65 bytes)\n * @returns The normalized uncompressed public key (65 bytes)\n * @throws {Error} When public key format is invalid or decompression fails\n */\n normalizeToUncompressed(publicKey: Uint8Array): Uint8Array {\n const len = publicKey.length;\n\n // Already uncompressed\n if (len === 65 && publicKey[0] === 0x04) {\n return publicKey;\n }\n\n // Compressed - decompress using @noble/secp256k1\n if (len === 33 && (publicKey[0] === 0x02 || publicKey[0] === 0x03)) {\n const decompressed = this.decompressPublicKey(publicKey);\n if (!decompressed) {\n throw new Error(\n `Failed to decompress public key with prefix ${toHex(publicKey[0])}`,\n );\n }\n return decompressed;\n }\n\n // Reject raw coordinates (64 bytes) - require proper formatting\n if (len === 64) {\n throw new Error(\n \"Raw public key coordinates (64 bytes) are not accepted. \" +\n \"Please provide a properly formatted compressed (33 bytes) or uncompressed (65 bytes) public key.\",\n );\n }\n\n throw new Error(\n `Invalid public key format: expected compressed (33 bytes) or uncompressed (65 bytes), got ${len} bytes`,\n );\n }\n}\n"],"mappings":"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","names":[]}