@lidofinance/lsv-cli 1.6.0 → 1.8.0

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 (445) hide show
  1. package/README.md +15 -9
  2. package/dist/abi/defi-wrapper/GenericStrategy.d.ts +308 -0
  3. package/dist/abi/defi-wrapper/GenericStrategy.js +409 -0
  4. package/dist/abi/defi-wrapper/GenericStrategy.js.map +1 -0
  5. package/dist/abi/defi-wrapper/{StvStETHPool.js → StvStEthPool.js} +1 -1
  6. package/dist/abi/defi-wrapper/{StvStETHPool.js.map → StvStEthPool.js.map} +1 -1
  7. package/dist/abi/defi-wrapper/index.d.ts +2 -1
  8. package/dist/abi/defi-wrapper/index.js +2 -1
  9. package/dist/abi/defi-wrapper/index.js.map +1 -1
  10. package/dist/abi/defi-wrapper/sources.d.ts +103 -0
  11. package/dist/abi/defi-wrapper/sources.js +104 -0
  12. package/dist/abi/defi-wrapper/sources.js.map +1 -0
  13. package/dist/command/index.js.map +1 -1
  14. package/dist/configs/constants.d.ts +21 -6
  15. package/dist/configs/deployed.d.ts +5 -0
  16. package/dist/configs/deployed.js +29 -10
  17. package/dist/configs/deployed.js.map +1 -1
  18. package/dist/configs/envs.js +2 -0
  19. package/dist/configs/envs.js.map +1 -1
  20. package/dist/configs/utils.js +1 -1
  21. package/dist/configs/utils.js.map +1 -1
  22. package/dist/contracts/dashboard-impl.d.ts +1 -1
  23. package/dist/contracts/dashboard-impl.js +1 -1
  24. package/dist/contracts/defi-wrapper/distributor.d.ts +1 -1
  25. package/dist/contracts/defi-wrapper/distributor.js +1 -1
  26. package/dist/contracts/defi-wrapper/factory.d.ts +1 -1
  27. package/dist/contracts/defi-wrapper/factory.js +1 -1
  28. package/dist/contracts/defi-wrapper/generic-strategy.d.ts +5 -0
  29. package/dist/contracts/defi-wrapper/generic-strategy.js +12 -0
  30. package/dist/contracts/defi-wrapper/generic-strategy.js.map +1 -0
  31. package/dist/contracts/defi-wrapper/index.d.ts +1 -0
  32. package/dist/contracts/defi-wrapper/index.js +1 -0
  33. package/dist/contracts/defi-wrapper/index.js.map +1 -1
  34. package/dist/contracts/defi-wrapper/ossifiable-proxy.d.ts +1 -1
  35. package/dist/contracts/defi-wrapper/ossifiable-proxy.js +1 -1
  36. package/dist/contracts/defi-wrapper/strategy-factory.d.ts +1 -1
  37. package/dist/contracts/defi-wrapper/strategy-factory.js +1 -1
  38. package/dist/contracts/defi-wrapper/stv-pool.d.ts +1 -1
  39. package/dist/contracts/defi-wrapper/stv-pool.js +1 -1
  40. package/dist/contracts/defi-wrapper/stv-steth-pool.d.ts +1 -1
  41. package/dist/contracts/defi-wrapper/stv-steth-pool.js +1 -1
  42. package/dist/contracts/defi-wrapper/timelock.d.ts +1 -1
  43. package/dist/contracts/defi-wrapper/timelock.js +1 -1
  44. package/dist/contracts/defi-wrapper/withdrawal-queue.d.ts +1 -1
  45. package/dist/contracts/defi-wrapper/withdrawal-queue.js +1 -1
  46. package/dist/contracts/lazy-oracle.d.ts +2 -2
  47. package/dist/contracts/lazy-oracle.js +3 -3
  48. package/dist/contracts/lazy-oracle.js.map +1 -1
  49. package/dist/contracts/locator.d.ts +1 -1
  50. package/dist/contracts/locator.js +1 -1
  51. package/dist/contracts/operator-grid.d.ts +2 -2
  52. package/dist/contracts/operator-grid.js +3 -3
  53. package/dist/contracts/operator-grid.js.map +1 -1
  54. package/dist/contracts/pdg.d.ts +2 -2
  55. package/dist/contracts/pdg.js +3 -3
  56. package/dist/contracts/pdg.js.map +1 -1
  57. package/dist/contracts/steth.d.ts +2 -2
  58. package/dist/contracts/steth.js +3 -3
  59. package/dist/contracts/steth.js.map +1 -1
  60. package/dist/contracts/vault-factory.d.ts +2 -2
  61. package/dist/contracts/vault-factory.js +2 -2
  62. package/dist/contracts/vault-hub.d.ts +2 -2
  63. package/dist/contracts/vault-hub.js +3 -3
  64. package/dist/contracts/vault-hub.js.map +1 -1
  65. package/dist/contracts/vault-viewer.d.ts +1 -1
  66. package/dist/contracts/vault-viewer.js +2 -3
  67. package/dist/contracts/vault-viewer.js.map +1 -1
  68. package/dist/contracts/vault.d.ts +1 -1
  69. package/dist/contracts/vault.js +1 -1
  70. package/dist/contracts/wsteth.d.ts +2 -2
  71. package/dist/contracts/wsteth.js +3 -3
  72. package/dist/contracts/wsteth.js.map +1 -1
  73. package/dist/features/consolidation.d.ts +1 -1
  74. package/dist/features/defi-wrapper/defi-wrapper-factory.d.ts +4 -1
  75. package/dist/features/defi-wrapper/defi-wrapper-factory.js +7 -4
  76. package/dist/features/defi-wrapper/defi-wrapper-factory.js.map +1 -1
  77. package/dist/features/defi-wrapper/distributor.d.ts +3 -1
  78. package/dist/features/defi-wrapper/distributor.js +31 -16
  79. package/dist/features/defi-wrapper/distributor.js.map +1 -1
  80. package/dist/features/defi-wrapper/index.d.ts +1 -0
  81. package/dist/features/defi-wrapper/index.js +1 -0
  82. package/dist/features/defi-wrapper/index.js.map +1 -1
  83. package/dist/features/defi-wrapper/pool-info.d.ts +18 -1
  84. package/dist/features/defi-wrapper/pool-info.js +52 -8
  85. package/dist/features/defi-wrapper/pool-info.js.map +1 -1
  86. package/dist/features/defi-wrapper/timelock-roles.d.ts +5 -0
  87. package/dist/features/defi-wrapper/timelock-roles.js +43 -0
  88. package/dist/features/defi-wrapper/timelock-roles.js.map +1 -0
  89. package/dist/features/defi-wrapper/timelock.d.ts +2 -7
  90. package/dist/features/defi-wrapper/timelock.js +6 -53
  91. package/dist/features/defi-wrapper/timelock.js.map +1 -1
  92. package/dist/features/defi-wrapper/verify-contracts.d.ts +20 -0
  93. package/dist/features/defi-wrapper/verify-contracts.js +145 -0
  94. package/dist/features/defi-wrapper/verify-contracts.js.map +1 -0
  95. package/dist/features/deposits/make-pdg-proof.js +1 -1
  96. package/dist/features/metrics.d.ts +2 -2
  97. package/dist/features/metrics.js +1 -1
  98. package/dist/features/mint-burn/mint-limit.js +1 -1
  99. package/dist/features/mint-burn/mint-limit.js.map +1 -1
  100. package/dist/features/utils/minting-capacity.js +1 -1
  101. package/dist/features/utils/try-fetch.js +4 -2
  102. package/dist/features/utils/try-fetch.js.map +1 -1
  103. package/dist/features/vault-factory.js +6 -5
  104. package/dist/features/vault-factory.js.map +1 -1
  105. package/dist/features/vault-operations/dashboard-by-vault.js +3 -7
  106. package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -1
  107. package/dist/features/vault-operations/vault-info.js +1 -1
  108. package/dist/features/vault-operations/vault-info.js.map +1 -1
  109. package/dist/features/vault-operations/vault-overview.js +1 -1
  110. package/dist/features/vault-operations/vault-overview.js.map +1 -1
  111. package/dist/features/with-report.d.ts +1 -1
  112. package/dist/features/with-report.js +1 -1
  113. package/dist/features/with-report.js.map +1 -1
  114. package/dist/index.js +7 -2
  115. package/dist/index.js.map +1 -1
  116. package/dist/programs/account/write.js +2 -1
  117. package/dist/programs/account/write.js.map +1 -1
  118. package/dist/programs/config.js +4 -2
  119. package/dist/programs/config.js.map +1 -1
  120. package/dist/programs/contracts/dashboard/read.js +3 -6
  121. package/dist/programs/contracts/dashboard/read.js.map +1 -1
  122. package/dist/programs/contracts/dashboard/write.js +2 -2
  123. package/dist/programs/contracts/dashboard/write.js.map +1 -1
  124. package/dist/programs/contracts/lazy-oracle/config.js +2 -2
  125. package/dist/programs/contracts/lazy-oracle/config.js.map +1 -1
  126. package/dist/programs/contracts/pdg/write.js +1 -1
  127. package/dist/programs/contracts/vault/config.js +1 -1
  128. package/dist/programs/contracts/vault/config.js.map +1 -1
  129. package/dist/programs/contracts/vault-factory/write.js +8 -9
  130. package/dist/programs/contracts/vault-factory/write.js.map +1 -1
  131. package/dist/programs/contracts/vault-viewer/config.js +8 -8
  132. package/dist/programs/contracts/vault-viewer/config.js.map +1 -1
  133. package/dist/programs/defi-wrapper/contracts/distributor/config.d.ts +1 -1
  134. package/dist/programs/defi-wrapper/contracts/distributor/read.js +2 -2
  135. package/dist/programs/defi-wrapper/contracts/distributor/write.js +1 -1
  136. package/dist/programs/defi-wrapper/contracts/factory/config.d.ts +1 -1
  137. package/dist/programs/defi-wrapper/contracts/factory/read.js +2 -2
  138. package/dist/programs/defi-wrapper/contracts/factory/write.js +79 -8
  139. package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -1
  140. package/dist/programs/defi-wrapper/contracts/index.d.ts +1 -0
  141. package/dist/programs/defi-wrapper/contracts/index.js +1 -0
  142. package/dist/programs/defi-wrapper/contracts/index.js.map +1 -1
  143. package/dist/programs/defi-wrapper/contracts/strategy/config.d.ts +3 -0
  144. package/dist/programs/defi-wrapper/contracts/strategy/config.js +40 -0
  145. package/dist/programs/defi-wrapper/contracts/strategy/config.js.map +1 -0
  146. package/dist/programs/defi-wrapper/contracts/strategy/index.d.ts +3 -0
  147. package/dist/programs/defi-wrapper/contracts/strategy/index.js +4 -0
  148. package/dist/programs/defi-wrapper/contracts/strategy/index.js.map +1 -0
  149. package/dist/programs/defi-wrapper/contracts/strategy/main.d.ts +1 -0
  150. package/dist/programs/defi-wrapper/contracts/strategy/main.js +6 -0
  151. package/dist/programs/defi-wrapper/contracts/strategy/main.js.map +1 -0
  152. package/dist/programs/defi-wrapper/contracts/strategy/read.js +30 -0
  153. package/dist/programs/defi-wrapper/contracts/strategy/read.js.map +1 -0
  154. package/dist/programs/defi-wrapper/contracts/strategy/write.d.ts +1 -0
  155. package/dist/programs/defi-wrapper/contracts/strategy/write.js +34 -0
  156. package/dist/programs/defi-wrapper/contracts/strategy/write.js.map +1 -0
  157. package/dist/programs/defi-wrapper/contracts/stv-pool/config.d.ts +1 -1
  158. package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +2 -2
  159. package/dist/programs/defi-wrapper/contracts/stv-pool/write.js +1 -1
  160. package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.d.ts +1 -1
  161. package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js +2 -2
  162. package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js +58 -22
  163. package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js.map +1 -1
  164. package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.d.ts +1 -1
  165. package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js +1 -1
  166. package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js.map +1 -1
  167. package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +2 -2
  168. package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +4 -5
  169. package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js.map +1 -1
  170. package/dist/programs/defi-wrapper/use-cases/distributor/read.js +2 -2
  171. package/dist/programs/defi-wrapper/use-cases/distributor/write.js +139 -31
  172. package/dist/programs/defi-wrapper/use-cases/distributor/write.js.map +1 -1
  173. package/dist/programs/defi-wrapper/use-cases/health/read.js +2 -2
  174. package/dist/programs/defi-wrapper/use-cases/health/utils.js +2 -2
  175. package/dist/programs/defi-wrapper/use-cases/health/utils.js.map +1 -1
  176. package/dist/programs/defi-wrapper/use-cases/health/write.js +3 -3
  177. package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js +7 -12
  178. package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js.map +1 -1
  179. package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js +6 -10
  180. package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js.map +1 -1
  181. package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js +5 -5
  182. package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js.map +1 -1
  183. package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.d.ts +1 -0
  184. package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js +1 -0
  185. package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js.map +1 -1
  186. package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js +6 -6
  187. package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js.map +1 -1
  188. package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js +1 -1
  189. package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js +5 -5
  190. package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js.map +1 -1
  191. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/index.d.ts +2 -0
  192. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/index.js +3 -0
  193. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/index.js.map +1 -0
  194. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/main.d.ts +1 -0
  195. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/main.js +6 -0
  196. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/main.js.map +1 -0
  197. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/write.d.ts +1 -0
  198. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/write.js +57 -0
  199. package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/write.js.map +1 -0
  200. package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js +5 -5
  201. package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js.map +1 -1
  202. package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js +37 -16
  203. package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js.map +1 -1
  204. package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js +18 -17
  205. package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js.map +1 -1
  206. package/dist/programs/dev-tools/anvil/write.js +2 -2
  207. package/dist/programs/dev-tools/anvil/write.js.map +1 -1
  208. package/dist/programs/dev-tools/defi-wrapper/write.js +1 -1
  209. package/dist/programs/pdg-helpers.js +4 -0
  210. package/dist/programs/pdg-helpers.js.map +1 -1
  211. package/dist/programs/use-cases/consolidation/write.js +4 -3
  212. package/dist/programs/use-cases/consolidation/write.js.map +1 -1
  213. package/dist/programs/use-cases/deposits/read.js +1 -2
  214. package/dist/programs/use-cases/deposits/read.js.map +1 -1
  215. package/dist/programs/use-cases/metrics/read.js +115 -1
  216. package/dist/programs/use-cases/metrics/read.js.map +1 -1
  217. package/dist/programs/use-cases/report/write.js +1 -3
  218. package/dist/programs/use-cases/report/write.js.map +1 -1
  219. package/dist/programs/use-cases/vault-operations/create-vault.js +8 -9
  220. package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -1
  221. package/dist/programs/use-cases/vault-operations/write.js +2 -14
  222. package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
  223. package/dist/providers/wallet.d.ts +687 -10399
  224. package/dist/providers/wallet.js +80 -9
  225. package/dist/providers/wallet.js.map +1 -1
  226. package/dist/tests/fixtures/consolidation-fixtures.d.ts +64 -0
  227. package/dist/tests/fixtures/consolidation-fixtures.js +56 -0
  228. package/dist/tests/fixtures/consolidation-fixtures.js.map +1 -0
  229. package/dist/tests/integration/deposits.test.js +1 -1
  230. package/dist/tests/integration/gas-estimation.test.d.ts +1 -0
  231. package/dist/tests/integration/gas-estimation.test.js +76 -0
  232. package/dist/tests/integration/gas-estimation.test.js.map +1 -0
  233. package/dist/tests/integration/{globalSetup.js → global-setup.js} +2 -2
  234. package/dist/tests/integration/global-setup.js.map +1 -0
  235. package/dist/tests/integration/helpers/test-client.d.ts +586 -7068
  236. package/dist/tests/integration/helpers/test-config.js +4 -4
  237. package/dist/tests/integration/helpers/test-config.js.map +1 -1
  238. package/dist/tests/integration/metrics.test.js +1 -2
  239. package/dist/tests/integration/metrics.test.js.map +1 -1
  240. package/dist/tests/integration/mint-burn.test.js +1 -2
  241. package/dist/tests/integration/mint-burn.test.js.map +1 -1
  242. package/dist/tests/integration/minting-capacity.test.d.ts +1 -0
  243. package/dist/tests/integration/minting-capacity.test.js +52 -0
  244. package/dist/tests/integration/minting-capacity.test.js.map +1 -0
  245. package/dist/tests/integration/quarantine.test.d.ts +1 -0
  246. package/dist/tests/integration/quarantine.test.js +32 -0
  247. package/dist/tests/integration/quarantine.test.js.map +1 -0
  248. package/dist/tests/integration/report-fresh.test.d.ts +1 -0
  249. package/dist/tests/integration/report-fresh.test.js +47 -0
  250. package/dist/tests/integration/report-fresh.test.js.map +1 -0
  251. package/dist/tests/utils/arguments-security.test.d.ts +1 -0
  252. package/dist/tests/utils/arguments-security.test.js +34 -0
  253. package/dist/tests/utils/arguments-security.test.js.map +1 -0
  254. package/dist/tests/utils/arguments.test.js +5 -24
  255. package/dist/tests/utils/arguments.test.js.map +1 -1
  256. package/dist/tests/utils/big-int.test.d.ts +1 -0
  257. package/dist/tests/utils/{bigInt.test.js → big-int.test.js} +2 -2
  258. package/dist/tests/utils/big-int.test.js.map +1 -0
  259. package/dist/tests/utils/cache-security.test.d.ts +1 -0
  260. package/dist/tests/utils/cache-security.test.js +62 -0
  261. package/dist/tests/utils/cache-security.test.js.map +1 -0
  262. package/dist/tests/utils/cache.test.d.ts +1 -0
  263. package/dist/tests/utils/cache.test.js +233 -0
  264. package/dist/tests/utils/cache.test.js.map +1 -0
  265. package/dist/tests/utils/calculate-overview-v2.test.js +1 -1
  266. package/dist/tests/utils/calculate-overview.test.js +4 -2
  267. package/dist/tests/utils/calculate-overview.test.js.map +1 -1
  268. package/dist/tests/utils/confirmations.test.d.ts +1 -0
  269. package/dist/tests/utils/confirmations.test.js +35 -0
  270. package/dist/tests/utils/confirmations.test.js.map +1 -0
  271. package/dist/tests/utils/consolidation-checks.test.d.ts +1 -0
  272. package/dist/tests/utils/consolidation-checks.test.js +77 -0
  273. package/dist/tests/utils/consolidation-checks.test.js.map +1 -0
  274. package/dist/tests/utils/consolidation-pubkeys.test.d.ts +1 -0
  275. package/dist/tests/utils/consolidation-pubkeys.test.js +101 -0
  276. package/dist/tests/utils/consolidation-pubkeys.test.js.map +1 -0
  277. package/dist/tests/utils/consolidation-validator-info.test.d.ts +1 -0
  278. package/dist/tests/utils/consolidation-validator-info.test.js +101 -0
  279. package/dist/tests/utils/consolidation-validator-info.test.js.map +1 -0
  280. package/dist/tests/utils/consolidation-validators-checks.test.d.ts +1 -0
  281. package/dist/tests/utils/consolidation-validators-checks.test.js +156 -0
  282. package/dist/tests/utils/consolidation-validators-checks.test.js.map +1 -0
  283. package/dist/tests/utils/consts.test.d.ts +1 -0
  284. package/dist/tests/utils/consts.test.js +24 -0
  285. package/dist/tests/utils/consts.test.js.map +1 -0
  286. package/dist/tests/utils/contract-write-stateoverride.test.d.ts +1 -0
  287. package/dist/tests/utils/contract-write-stateoverride.test.js +135 -0
  288. package/dist/tests/utils/contract-write-stateoverride.test.js.map +1 -0
  289. package/dist/tests/utils/csv-file.test.js +1 -1
  290. package/dist/tests/utils/data-validators.test.js +22 -6
  291. package/dist/tests/utils/data-validators.test.js.map +1 -1
  292. package/dist/tests/utils/deployed-security.test.d.ts +1 -0
  293. package/dist/tests/utils/deployed-security.test.js +51 -0
  294. package/dist/tests/utils/deployed-security.test.js.map +1 -0
  295. package/dist/tests/utils/get-commands.test.js +1 -1
  296. package/dist/tests/utils/get-commands.test.js.map +1 -1
  297. package/dist/tests/utils/get-confirmations.test.d.ts +1 -0
  298. package/dist/tests/utils/get-confirmations.test.js +40 -0
  299. package/dist/tests/utils/get-confirmations.test.js.map +1 -0
  300. package/dist/tests/utils/ipfs-security.test.d.ts +1 -0
  301. package/dist/tests/utils/ipfs-security.test.js +105 -0
  302. package/dist/tests/utils/ipfs-security.test.js.map +1 -0
  303. package/dist/tests/utils/ipfs.test.js +10 -9
  304. package/dist/tests/utils/ipfs.test.js.map +1 -1
  305. package/dist/tests/utils/lido-apr.test.js +1 -1
  306. package/dist/tests/utils/logging.test.js +1 -1
  307. package/dist/tests/utils/logging.test.js.map +1 -1
  308. package/dist/tests/utils/merkle-utils.test.js +1 -0
  309. package/dist/tests/utils/merkle-utils.test.js.map +1 -1
  310. package/dist/tests/utils/public-client-gas-estimation.test.d.ts +1 -0
  311. package/dist/tests/utils/public-client-gas-estimation.test.js +231 -0
  312. package/dist/tests/utils/public-client-gas-estimation.test.js.map +1 -0
  313. package/dist/tests/utils/rate-limit-security.test.d.ts +1 -0
  314. package/dist/tests/utils/rate-limit-security.test.js +82 -0
  315. package/dist/tests/utils/rate-limit-security.test.js.map +1 -0
  316. package/dist/tests/utils/rebase-rewards.test.js +1 -1
  317. package/dist/tests/utils/report-statistic.test.js +1 -1
  318. package/dist/tests/utils/resove-path.test.js +2 -2
  319. package/dist/tests/utils/resove-path.test.js.map +1 -1
  320. package/dist/tests/utils/salt.test.d.ts +1 -0
  321. package/dist/tests/utils/salt.test.js +20 -0
  322. package/dist/tests/utils/salt.test.js.map +1 -0
  323. package/dist/tests/utils/snake-to-camel.test.js +1 -1
  324. package/dist/tests/utils/timestamp.test.js +1 -1
  325. package/dist/tests/utils/with-error.test.d.ts +1 -0
  326. package/dist/tests/utils/with-error.test.js +42 -0
  327. package/dist/tests/utils/with-error.test.js.map +1 -0
  328. package/dist/utils/arguments.d.ts +2 -7
  329. package/dist/utils/arguments.js +34 -34
  330. package/dist/utils/arguments.js.map +1 -1
  331. package/dist/utils/big-int.js +7 -0
  332. package/dist/utils/big-int.js.map +1 -0
  333. package/dist/utils/cache.js +25 -22
  334. package/dist/utils/cache.js.map +1 -1
  335. package/dist/utils/calculate-overview-v2.js +1 -1
  336. package/dist/utils/calculate-overview-v2.js.map +1 -1
  337. package/dist/utils/calculate-overview.js +2 -2
  338. package/dist/utils/calculate-overview.js.map +1 -1
  339. package/dist/utils/charts/blessed/charts-apr.js +2 -2
  340. package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
  341. package/dist/utils/charts/blessed/charts-rewards.js +2 -2
  342. package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
  343. package/dist/utils/charts/blessed/datasets/prepare-metrics.js +1 -2
  344. package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
  345. package/dist/utils/charts/blessed/utils.js +1 -0
  346. package/dist/utils/charts/blessed/utils.js.map +1 -1
  347. package/dist/utils/charts/overview.js +3 -3
  348. package/dist/utils/charts/overview.js.map +1 -1
  349. package/dist/utils/commands/confirmations.js +15 -8
  350. package/dist/utils/commands/confirmations.js.map +1 -1
  351. package/dist/utils/consolidation/validator-info.d.ts +1 -1
  352. package/dist/utils/consolidation/validator-info.js +4 -4
  353. package/dist/utils/consolidation/validator-info.js.map +1 -1
  354. package/dist/utils/consolidation/validators-checks.d.ts +1 -1
  355. package/dist/utils/consolidation/validators-checks.js +5 -5
  356. package/dist/utils/consolidation/validators-checks.js.map +1 -1
  357. package/dist/utils/csv-file.js +1 -1
  358. package/dist/utils/csv-file.js.map +1 -1
  359. package/dist/utils/data-validators.d.ts +3 -2
  360. package/dist/utils/data-validators.js +11 -14
  361. package/dist/utils/data-validators.js.map +1 -1
  362. package/dist/utils/{fetchCL.d.ts → fetch-cl.d.ts} +15 -17
  363. package/dist/utils/{fetchCL.js → fetch-cl.js} +5 -3
  364. package/dist/utils/fetch-cl.js.map +1 -0
  365. package/dist/utils/get-commands.js +3 -2
  366. package/dist/utils/get-commands.js.map +1 -1
  367. package/dist/utils/get-value.js +1 -1
  368. package/dist/utils/get-value.js.map +1 -1
  369. package/dist/utils/index.d.ts +7 -6
  370. package/dist/utils/index.js +7 -6
  371. package/dist/utils/index.js.map +1 -1
  372. package/dist/utils/interrupt-handler.js +1 -1
  373. package/dist/utils/interrupt-handler.js.map +1 -1
  374. package/dist/utils/ipfs.d.ts +11 -2
  375. package/dist/utils/ipfs.js +52 -12
  376. package/dist/utils/ipfs.js.map +1 -1
  377. package/dist/utils/logging/console.d.ts +1 -0
  378. package/dist/utils/logging/console.js +35 -7
  379. package/dist/utils/logging/console.js.map +1 -1
  380. package/dist/utils/prompts/account.d.ts +1 -0
  381. package/dist/utils/prompts/account.js +13 -0
  382. package/dist/utils/prompts/account.js.map +1 -0
  383. package/dist/utils/prompts/index.d.ts +3 -0
  384. package/dist/utils/prompts/index.js +3 -0
  385. package/dist/utils/prompts/index.js.map +1 -1
  386. package/dist/utils/prompts/predeposit-guarantee.js +1 -1
  387. package/dist/utils/prompts/strategy.d.ts +15398 -0
  388. package/dist/utils/prompts/strategy.js +10 -0
  389. package/dist/utils/prompts/strategy.js.map +1 -0
  390. package/dist/utils/prompts/timelock-roles.d.ts +1 -0
  391. package/dist/utils/prompts/timelock-roles.js +13 -0
  392. package/dist/utils/prompts/timelock-roles.js.map +1 -0
  393. package/dist/utils/proof/create-proof.js +1 -1
  394. package/dist/utils/proof/create-proof.js.map +1 -1
  395. package/dist/utils/proof/merkle-utils.js +1 -1
  396. package/dist/utils/proof/merkle-utils.js.map +1 -1
  397. package/dist/utils/rate-limit.d.ts +6 -9
  398. package/dist/utils/rate-limit.js +27 -5
  399. package/dist/utils/rate-limit.js.map +1 -1
  400. package/dist/utils/read-programs-by-abi.d.ts +1 -1
  401. package/dist/utils/read-programs-by-abi.js +11 -12
  402. package/dist/utils/read-programs-by-abi.js.map +1 -1
  403. package/dist/utils/report/report-proof.js +1 -1
  404. package/dist/utils/report/report-proof.js.map +1 -1
  405. package/dist/utils/report/report.js +2 -2
  406. package/dist/utils/report/report.js.map +1 -1
  407. package/dist/utils/report/statistic-data.js +1 -1
  408. package/dist/utils/resolve-path.js +2 -2
  409. package/dist/utils/resolve-path.js.map +1 -1
  410. package/dist/utils/salt.d.ts +3 -0
  411. package/dist/utils/salt.js +8 -0
  412. package/dist/utils/salt.js.map +1 -0
  413. package/dist/utils/share-rate.js +1 -1
  414. package/dist/utils/share-rate.js.map +1 -1
  415. package/dist/utils/snake-to-camel.js +1 -1
  416. package/dist/utils/snake-to-camel.js.map +1 -1
  417. package/dist/utils/spinner/spinners.js +2 -1
  418. package/dist/utils/spinner/spinners.js.map +1 -1
  419. package/dist/utils/statistic/report-statistic.d.ts +1 -1
  420. package/dist/utils/transactions/tx-private-key.d.ts +2 -1
  421. package/dist/utils/transactions/tx-private-key.js +5 -8
  422. package/dist/utils/transactions/tx-private-key.js.map +1 -1
  423. package/dist/utils/transactions/tx-wc.d.ts +2 -2
  424. package/dist/utils/transactions/tx-wc.js +11 -15
  425. package/dist/utils/transactions/tx-wc.js.map +1 -1
  426. package/dist/utils/transactions/utils.d.ts +1 -0
  427. package/dist/utils/transactions/utils.js +12 -0
  428. package/dist/utils/transactions/utils.js.map +1 -1
  429. package/dist/utils/wallet-connect.js +2 -3
  430. package/dist/utils/wallet-connect.js.map +1 -1
  431. package/dist/version/index.js +1 -1
  432. package/dist/vitest.config.js +1 -1
  433. package/dist/vitest.config.js.map +1 -1
  434. package/dist/vitest.integration.config.js +2 -2
  435. package/dist/vitest.integration.config.js.map +1 -1
  436. package/package.json +18 -24
  437. package/dist/tests/integration/globalSetup.js.map +0 -1
  438. package/dist/tests/utils/bigInt.test.js.map +0 -1
  439. package/dist/utils/bigInt.js +0 -3
  440. package/dist/utils/bigInt.js.map +0 -1
  441. package/dist/utils/fetchCL.js.map +0 -1
  442. /package/dist/abi/defi-wrapper/{StvStETHPool.d.ts → StvStEthPool.d.ts} +0 -0
  443. /package/dist/{tests/utils/bigInt.test.d.ts → programs/defi-wrapper/contracts/strategy/read.d.ts} +0 -0
  444. /package/dist/tests/integration/{globalSetup.d.ts → global-setup.d.ts} +0 -0
  445. /package/dist/utils/{bigInt.d.ts → big-int.d.ts} +0 -0
@@ -0,0 +1,101 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { parseGwei } from 'viem';
3
+ import { getTargetAndSourceValidatorsInfo } from '../../utils/consolidation/validator-info.js';
4
+ import { VALID_PUBKEY_1, VALID_PUBKEY_2, VALID_PUBKEY_3, VALID_PUBKEY_4, createCLValidatorData, createValidatorsInfo, } from '../fixtures/consolidation-fixtures.js';
5
+ describe('getTargetAndSourceValidatorsInfo', () => {
6
+ it('should create correct map from matched pubkeys', () => {
7
+ const targetPubkeys = [VALID_PUBKEY_1];
8
+ const sourcePubkeys = [[VALID_PUBKEY_2]];
9
+ const targetValidatorsInfo = createValidatorsInfo([
10
+ createCLValidatorData(VALID_PUBKEY_1, {
11
+ withdrawal_credentials: '0x0200000000000000000000000000000000000000000000000000000000000001',
12
+ balance: '32000000000',
13
+ effective_balance: '32000000000',
14
+ index: '100',
15
+ status: 'active_ongoing',
16
+ }),
17
+ ]);
18
+ const sourceValidatorsInfo = createValidatorsInfo([
19
+ createCLValidatorData(VALID_PUBKEY_2, {
20
+ withdrawal_credentials: '0x0100000000000000000000000000000000000000000000000000000000000001',
21
+ balance: '31500000000',
22
+ effective_balance: '31000000000',
23
+ index: '200',
24
+ status: 'active_ongoing',
25
+ }),
26
+ ]);
27
+ const result = getTargetAndSourceValidatorsInfo(targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo);
28
+ expect(result.size).toBe(1);
29
+ const entry = result.get(VALID_PUBKEY_1);
30
+ expect(entry).toBeDefined();
31
+ if (!entry)
32
+ return;
33
+ expect(entry.info.status).toBe('active_ongoing');
34
+ expect(entry.info.balance).toBe(parseGwei('32000000000'));
35
+ expect(entry.info.index).toBe('100');
36
+ expect(entry.sourceValidators.size).toBe(1);
37
+ const sourceEntry = entry.sourceValidators.get(VALID_PUBKEY_2);
38
+ expect(sourceEntry).toBeDefined();
39
+ if (!sourceEntry)
40
+ return;
41
+ expect(sourceEntry.status).toBe('active_ongoing');
42
+ expect(sourceEntry.balance).toBe(parseGwei('31500000000'));
43
+ expect(sourceEntry.index).toBe('200');
44
+ });
45
+ it('should throw when target pubkey not found in targetValidatorsInfo', () => {
46
+ const targetPubkeys = [VALID_PUBKEY_1];
47
+ const sourcePubkeys = [[VALID_PUBKEY_2]];
48
+ const targetValidatorsInfo = createValidatorsInfo([
49
+ createCLValidatorData(VALID_PUBKEY_3), // wrong pubkey
50
+ ]);
51
+ const sourceValidatorsInfo = createValidatorsInfo([
52
+ createCLValidatorData(VALID_PUBKEY_2),
53
+ ]);
54
+ expect(() => getTargetAndSourceValidatorsInfo(targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo)).toThrow(`Target validator with pubkey ${VALID_PUBKEY_1} not found`);
55
+ });
56
+ it('should throw when source pubkey not found in sourceValidatorsInfo', () => {
57
+ const targetPubkeys = [VALID_PUBKEY_1];
58
+ const sourcePubkeys = [[VALID_PUBKEY_2]];
59
+ const targetValidatorsInfo = createValidatorsInfo([
60
+ createCLValidatorData(VALID_PUBKEY_1),
61
+ ]);
62
+ const sourceValidatorsInfo = createValidatorsInfo([
63
+ createCLValidatorData(VALID_PUBKEY_3), // wrong pubkey
64
+ ]);
65
+ expect(() => getTargetAndSourceValidatorsInfo(targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo)).toThrow(`Source validator with pubkey ${VALID_PUBKEY_2} not found`);
66
+ });
67
+ it('should handle multiple targets with multiple source groups', () => {
68
+ const targetPubkeys = [VALID_PUBKEY_1, VALID_PUBKEY_3];
69
+ const sourcePubkeys = [[VALID_PUBKEY_2], [VALID_PUBKEY_4]];
70
+ const targetValidatorsInfo = createValidatorsInfo([
71
+ createCLValidatorData(VALID_PUBKEY_1, { index: '1' }),
72
+ createCLValidatorData(VALID_PUBKEY_3, { index: '2' }),
73
+ ]);
74
+ const sourceValidatorsInfo = createValidatorsInfo([
75
+ createCLValidatorData(VALID_PUBKEY_2, { index: '10' }),
76
+ createCLValidatorData(VALID_PUBKEY_4, { index: '20' }),
77
+ ]);
78
+ const result = getTargetAndSourceValidatorsInfo(targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo);
79
+ expect(result.size).toBe(2);
80
+ expect(result.get(VALID_PUBKEY_1)?.sourceValidators.size).toBe(1);
81
+ expect(result.get(VALID_PUBKEY_3)?.sourceValidators.size).toBe(1);
82
+ });
83
+ it('should handle empty pubkey arrays', () => {
84
+ const targetValidatorsInfo = createValidatorsInfo([]);
85
+ const sourceValidatorsInfo = createValidatorsInfo([]);
86
+ const result = getTargetAndSourceValidatorsInfo([], targetValidatorsInfo, [], sourceValidatorsInfo);
87
+ expect(result.size).toBe(0);
88
+ });
89
+ it('should handle target with empty source group', () => {
90
+ const targetPubkeys = [VALID_PUBKEY_1];
91
+ const sourcePubkeys = [[]];
92
+ const targetValidatorsInfo = createValidatorsInfo([
93
+ createCLValidatorData(VALID_PUBKEY_1),
94
+ ]);
95
+ const sourceValidatorsInfo = createValidatorsInfo([]);
96
+ const result = getTargetAndSourceValidatorsInfo(targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo);
97
+ expect(result.size).toBe(1);
98
+ expect(result.get(VALID_PUBKEY_1)?.sourceValidators.size).toBe(0);
99
+ });
100
+ });
101
+ //# sourceMappingURL=consolidation-validator-info.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consolidation-validator-info.test.js","sourceRoot":"","sources":["../../../tests/utils/consolidation-validator-info.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,156 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { checkSourceValidators, checkTargetValidators, removeInactiveValidators, } from '../../utils/consolidation/validators-checks.js';
3
+ import { VALID_PUBKEY_1, VALID_PUBKEY_2, VALID_PUBKEY_3, VALID_PUBKEY_4, createTargetAndSourceMap, createCLValidatorData, } from '../fixtures/consolidation-fixtures.js';
4
+ describe('checkSourceValidators', () => {
5
+ const FINALIZED_EPOCH = 1000;
6
+ it('should pass with valid 0x01 withdrawal credentials and sufficient epochs', () => {
7
+ const validators = [
8
+ createCLValidatorData(VALID_PUBKEY_1, {
9
+ withdrawal_credentials: '0x0100000000000000000000000000000000000000000000000000000000000001',
10
+ activation_epoch: '0',
11
+ }),
12
+ ];
13
+ expect(() => checkSourceValidators(validators, FINALIZED_EPOCH)).not.toThrow();
14
+ });
15
+ it('should pass with valid 0x02 withdrawal credentials', () => {
16
+ const validators = [
17
+ createCLValidatorData(VALID_PUBKEY_1, {
18
+ withdrawal_credentials: '0x0200000000000000000000000000000000000000000000000000000000000001',
19
+ activation_epoch: '0',
20
+ }),
21
+ ];
22
+ expect(() => checkSourceValidators(validators, FINALIZED_EPOCH)).not.toThrow();
23
+ });
24
+ it('should throw when withdrawal credentials start with 0x00', () => {
25
+ const validators = [
26
+ createCLValidatorData(VALID_PUBKEY_1, {
27
+ withdrawal_credentials: '0x0000000000000000000000000000000000000000000000000000000000000001',
28
+ activation_epoch: '0',
29
+ }),
30
+ ];
31
+ expect(() => checkSourceValidators(validators, FINALIZED_EPOCH)).toThrow('All source pubkeys must have a withdrawal credentials starting with 0x01 or 0x02');
32
+ });
33
+ it('should throw when activation epoch is less than 256 epochs before finalized', () => {
34
+ const validators = [
35
+ createCLValidatorData(VALID_PUBKEY_1, {
36
+ withdrawal_credentials: '0x0100000000000000000000000000000000000000000000000000000000000001',
37
+ activation_epoch: '900', // 1000 - 900 = 100, less than 256
38
+ }),
39
+ ];
40
+ expect(() => checkSourceValidators(validators, FINALIZED_EPOCH)).toThrow('activation epoch less than the finalized epoch by at least 256 epochs');
41
+ });
42
+ it('should pass with empty array', () => {
43
+ expect(() => checkSourceValidators([], FINALIZED_EPOCH)).not.toThrow();
44
+ });
45
+ it('should list all invalid pubkeys in error message', () => {
46
+ const validators = [
47
+ createCLValidatorData(VALID_PUBKEY_1, {
48
+ withdrawal_credentials: '0x0000000000000000000000000000000000000000000000000000000000000001',
49
+ activation_epoch: '0',
50
+ }),
51
+ createCLValidatorData(VALID_PUBKEY_2, {
52
+ withdrawal_credentials: '0x0000000000000000000000000000000000000000000000000000000000000001',
53
+ activation_epoch: '0',
54
+ }),
55
+ ];
56
+ expect(() => checkSourceValidators(validators, FINALIZED_EPOCH)).toThrow(new RegExp(`${VALID_PUBKEY_1}.*${VALID_PUBKEY_2}|${VALID_PUBKEY_2}.*${VALID_PUBKEY_1}`));
57
+ });
58
+ });
59
+ describe('checkTargetValidators', () => {
60
+ it('should pass with 0x02 withdrawal credentials', () => {
61
+ const validators = [
62
+ createCLValidatorData(VALID_PUBKEY_1, {
63
+ withdrawal_credentials: '0x0200000000000000000000000000000000000000000000000000000000000001',
64
+ }),
65
+ ];
66
+ expect(() => checkTargetValidators(validators)).not.toThrow();
67
+ });
68
+ it('should throw when withdrawal credentials start with 0x01', () => {
69
+ const validators = [
70
+ createCLValidatorData(VALID_PUBKEY_1, {
71
+ withdrawal_credentials: '0x0100000000000000000000000000000000000000000000000000000000000001',
72
+ }),
73
+ ];
74
+ expect(() => checkTargetValidators(validators)).toThrow('All target pubkeys must have a withdrawal credentials starting with 0x02');
75
+ });
76
+ it('should throw when withdrawal credentials start with 0x00', () => {
77
+ const validators = [
78
+ createCLValidatorData(VALID_PUBKEY_1, {
79
+ withdrawal_credentials: '0x0000000000000000000000000000000000000000000000000000000000000001',
80
+ }),
81
+ ];
82
+ expect(() => checkTargetValidators(validators)).toThrow('All target pubkeys must have a withdrawal credentials starting with 0x02');
83
+ });
84
+ it('should pass with empty array', () => {
85
+ expect(() => checkTargetValidators([])).not.toThrow();
86
+ });
87
+ });
88
+ describe('removeInactiveValidators', () => {
89
+ it('should remove source validators with non-active_ongoing status', () => {
90
+ const map = createTargetAndSourceMap([
91
+ {
92
+ target: VALID_PUBKEY_1,
93
+ sources: [
94
+ { pubkey: VALID_PUBKEY_2, info: { status: 'active_ongoing' } },
95
+ { pubkey: VALID_PUBKEY_3, info: { status: 'exited' } },
96
+ ],
97
+ },
98
+ ]);
99
+ removeInactiveValidators(map);
100
+ expect(map.size).toBe(1);
101
+ const entry = map.get(VALID_PUBKEY_1);
102
+ expect(entry?.sourceValidators.size).toBe(1);
103
+ expect(entry?.sourceValidators.has(VALID_PUBKEY_2)).toBe(true);
104
+ expect(entry?.sourceValidators.has(VALID_PUBKEY_3)).toBe(false);
105
+ });
106
+ it('should remove target entries when all sources are removed', () => {
107
+ const map = createTargetAndSourceMap([
108
+ {
109
+ target: VALID_PUBKEY_1,
110
+ sources: [
111
+ { pubkey: VALID_PUBKEY_2, info: { status: 'exited' } },
112
+ { pubkey: VALID_PUBKEY_3, info: { status: 'withdrawal_done' } },
113
+ ],
114
+ },
115
+ ]);
116
+ removeInactiveValidators(map);
117
+ expect(map.size).toBe(0);
118
+ });
119
+ it('should preserve active validators', () => {
120
+ const map = createTargetAndSourceMap([
121
+ {
122
+ target: VALID_PUBKEY_1,
123
+ sources: [
124
+ { pubkey: VALID_PUBKEY_2, info: { status: 'active_ongoing' } },
125
+ ],
126
+ },
127
+ ]);
128
+ removeInactiveValidators(map);
129
+ expect(map.size).toBe(1);
130
+ expect(map.get(VALID_PUBKEY_1)?.sourceValidators.size).toBe(1);
131
+ });
132
+ it('should handle empty map', () => {
133
+ const map = createTargetAndSourceMap([]);
134
+ removeInactiveValidators(map);
135
+ expect(map.size).toBe(0);
136
+ });
137
+ it('should handle multiple targets independently', () => {
138
+ const map = createTargetAndSourceMap([
139
+ {
140
+ target: VALID_PUBKEY_1,
141
+ sources: [
142
+ { pubkey: VALID_PUBKEY_2, info: { status: 'active_ongoing' } },
143
+ ],
144
+ },
145
+ {
146
+ target: VALID_PUBKEY_3,
147
+ sources: [{ pubkey: VALID_PUBKEY_4, info: { status: 'exited' } }],
148
+ },
149
+ ]);
150
+ removeInactiveValidators(map);
151
+ expect(map.size).toBe(1);
152
+ expect(map.has(VALID_PUBKEY_1)).toBe(true);
153
+ expect(map.has(VALID_PUBKEY_3)).toBe(false);
154
+ });
155
+ });
156
+ //# sourceMappingURL=consolidation-validators-checks.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consolidation-validators-checks.test.js","sourceRoot":"","sources":["../../../tests/utils/consolidation-validators-checks.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EACL,qBAAqB,EACrB,qBAAqB,EACrB,wBAAwB,GACzB,MAAM,gDAAgD,CAAC;AACxD,OAAO,EACL,cAAc,EACd,cAAc,EACd,cAAc,EACd,cAAc,EACd,wBAAwB,EACxB,qBAAqB,GACtB,MAAM,uCAAuC,CAAC;AAE/C,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,eAAe,GAAG,IAAI,CAAC;IAE7B,EAAE,CAAC,0EAA0E,EAAE,GAAG,EAAE;QAClF,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;gBACtE,gBAAgB,EAAE,GAAG;aACtB,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CACV,qBAAqB,CAAC,UAAU,EAAE,eAAe,CAAC,CACnD,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;gBACtE,gBAAgB,EAAE,GAAG;aACtB,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CACV,qBAAqB,CAAC,UAAU,EAAE,eAAe,CAAC,CACnD,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAClB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0DAA0D,EAAE,GAAG,EAAE;QAClE,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;gBACtE,gBAAgB,EAAE,GAAG;aACtB,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,OAAO,CACtE,kFAAkF,CACnF,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6EAA6E,EAAE,GAAG,EAAE;QACrF,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;gBACtE,gBAAgB,EAAE,KAAK,EAAE,kCAAkC;aAC5D,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,OAAO,CACtE,uEAAuE,CACxE,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IACzE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC1D,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;gBACtE,gBAAgB,EAAE,GAAG;aACtB,CAAC;YACF,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;gBACtE,gBAAgB,EAAE,GAAG;aACtB,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,OAAO,CACtE,IAAI,MAAM,CACR,GAAG,cAAc,KAAK,cAAc,IAAI,cAAc,KAAK,cAAc,EAAE,CAC5E,CACF,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;aACvE,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0DAA0D,EAAE,GAAG,EAAE;QAClE,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;aACvE,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CACrD,0EAA0E,CAC3E,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0DAA0D,EAAE,GAAG,EAAE;QAClE,MAAM,UAAU,GAAG;YACjB,qBAAqB,CAAC,cAAc,EAAE;gBACpC,sBAAsB,EACpB,oEAAoE;aACvE,CAAC;SACH,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CACrD,0EAA0E,CAC3E,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACxC,EAAE,CAAC,gEAAgE,EAAE,GAAG,EAAE;QACxE,MAAM,GAAG,GAAG,wBAAwB,CAAC;YACnC;gBACE,MAAM,EAAE,cAAc;gBACtB,OAAO,EAAE;oBACP,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAAE;oBAC9D,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE;iBACvD;aACF;SACF,CAAC,CAAC;QACH,wBAAwB,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACtC,MAAM,CAAC,KAAK,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,KAAK,EAAE,gBAAgB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/D,MAAM,CAAC,KAAK,EAAE,gBAAgB,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,GAAG,GAAG,wBAAwB,CAAC;YACnC;gBACE,MAAM,EAAE,cAAc;gBACtB,OAAO,EAAE;oBACP,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE;oBACtD,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,iBAAiB,EAAE,EAAE;iBAChE;aACF;SACF,CAAC,CAAC;QACH,wBAAwB,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,GAAG,GAAG,wBAAwB,CAAC;YACnC;gBACE,MAAM,EAAE,cAAc;gBACtB,OAAO,EAAE;oBACP,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAAE;iBAC/D;aACF;SACF,CAAC,CAAC;QACH,wBAAwB,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,MAAM,GAAG,GAAG,wBAAwB,CAAC,EAAE,CAAC,CAAC;QACzC,wBAAwB,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,GAAG,GAAG,wBAAwB,CAAC;YACnC;gBACE,MAAM,EAAE,cAAc;gBACtB,OAAO,EAAE;oBACP,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAAE;iBAC/D;aACF;YACD;gBACE,MAAM,EAAE,cAAc;gBACtB,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,CAAC;aAClE;SACF,CAAC,CAAC;QACH,wBAAwB,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3C,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,24 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { hoodi, mainnet } from 'viem/chains';
3
+ import { BASIS_POINTS_DENOMINATOR, DECIMALS, SCALING_FACTOR, V3_START_BLOCKS, } from '../../utils/consts.js';
4
+ describe('consts', () => {
5
+ it('should have BASIS_POINTS_DENOMINATOR equal to 10000', () => {
6
+ expect(BASIS_POINTS_DENOMINATOR).toBe(10000n);
7
+ });
8
+ it('should have DECIMALS equal to 18', () => {
9
+ expect(DECIMALS).toBe(18n);
10
+ });
11
+ it('should have SCALING_FACTOR equal to 10^DECIMALS', () => {
12
+ expect(SCALING_FACTOR).toBe(10n ** DECIMALS);
13
+ expect(SCALING_FACTOR).toBe(1000000000000000000n);
14
+ });
15
+ it('should have V3_START_BLOCKS for mainnet', () => {
16
+ expect(V3_START_BLOCKS[mainnet.id]).toBeDefined();
17
+ expect(V3_START_BLOCKS[mainnet.id]).toBeGreaterThan(0n);
18
+ });
19
+ it('should have V3_START_BLOCKS for hoodi', () => {
20
+ expect(V3_START_BLOCKS[hoodi.id]).toBeDefined();
21
+ expect(V3_START_BLOCKS[hoodi.id]).toBeGreaterThan(0n);
22
+ });
23
+ });
24
+ //# sourceMappingURL=consts.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"consts.test.js","sourceRoot":"","sources":["../../../tests/utils/consts.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EACL,wBAAwB,EACxB,QAAQ,EACR,cAAc,EACd,eAAe,GAChB,MAAM,uBAAuB,CAAC;AAE/B,QAAQ,CAAC,QAAQ,EAAE,GAAG,EAAE;IACtB,EAAE,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC7D,MAAM,CAAC,wBAAwB,CAAC,CAAC,IAAI,CAAC,MAAO,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,kCAAkC,EAAE,GAAG,EAAE;QAC1C,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,GAAG,IAAI,QAAQ,CAAC,CAAC;QAC7C,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAClD,MAAM,CAAC,eAAe,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;QAChD,MAAM,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,135 @@
1
+ /**
2
+ * End-to-end regression test for the balanceAwareTransport fix.
3
+ *
4
+ * Verifies that stateOverride is injected into eth_estimateGas even when the
5
+ * call originates from contract.write[method]() — the path that bypassed the
6
+ * old client.extend() override due to viem's bound-method closure bug.
7
+ *
8
+ * Uses real viem (createWalletClient, getContract, writeContract) with a mock
9
+ * at the fetch level so we can inspect the exact JSON-RPC payload sent to the
10
+ * node without needing a live chain.
11
+ */
12
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
13
+ import { createWalletClient, getContract, parseAbi } from 'viem';
14
+ import { privateKeyToAccount } from 'viem/accounts';
15
+ import { balanceAwareTransport } from '../../providers/wallet.js';
16
+ const MAX_UINT256_HEX = '0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff';
17
+ const TEST_PRIVATE_KEY = '0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80';
18
+ const MOCK_CHAIN = {
19
+ id: 1337,
20
+ name: 'mocknet',
21
+ nativeCurrency: { name: 'ETH', symbol: 'ETH', decimals: 18 },
22
+ rpcUrls: { default: { http: ['http://localhost:8545'] } },
23
+ };
24
+ const CONTRACT_ADDRESS = '0x5FbDB2315678afecb367f032d93F642f64180aa3';
25
+ const RECIPIENT = '0x70997970C51812dc3A010C7d01b50e0d17dc79C8';
26
+ const ERC20_ABI = parseAbi([
27
+ 'function transfer(address to, uint256 amount) returns (bool)',
28
+ ]);
29
+ // Helpers -------------------------------------------------------------------
30
+ const jsonRpc = (id, result) => Response.json({ jsonrpc: '2.0', id, result }, { headers: { 'Content-Type': 'application/json' } });
31
+ /**
32
+ * Builds a fetch mock that answers every RPC call viem makes during
33
+ * contract.write (chainId, nonce, fee estimation, gas estimation, sendTx).
34
+ *
35
+ * The capturedEstimateGasCalls array is populated with the full JSON-RPC
36
+ * body of every eth_estimateGas request so the test can assert on it.
37
+ */
38
+ const buildFetchMock = (capturedEstimateGasCalls) => vi.fn(async (_url, init) => {
39
+ const body = JSON.parse(init?.body ?? '{}');
40
+ const { id, method } = body;
41
+ switch (method) {
42
+ case 'eth_chainId': {
43
+ return jsonRpc(id, `0x${MOCK_CHAIN.id.toString(16)}`);
44
+ }
45
+ case 'eth_getTransactionCount': {
46
+ return jsonRpc(id, '0x0');
47
+ }
48
+ // EIP-1559 fee history used by prepareTransactionRequest
49
+ case 'eth_feeHistory': {
50
+ return jsonRpc(id, {
51
+ baseFeePerGas: ['0x1', '0x1'],
52
+ gasUsedRatio: [0.5],
53
+ reward: [['0x1']],
54
+ oldestBlock: '0x1',
55
+ });
56
+ }
57
+ case 'eth_getBlockByNumber': {
58
+ return jsonRpc(id, {
59
+ baseFeePerGas: '0x1',
60
+ number: '0x1',
61
+ hash: `0x${'a'.repeat(64)}`,
62
+ transactions: [],
63
+ });
64
+ }
65
+ case 'eth_maxPriorityFeePerGas': {
66
+ return jsonRpc(id, '0x1');
67
+ }
68
+ case 'eth_estimateGas': {
69
+ capturedEstimateGasCalls.push(body);
70
+ return jsonRpc(id, '0x5208');
71
+ }
72
+ case 'eth_sendRawTransaction': {
73
+ return jsonRpc(id, `0x${'b'.repeat(64)}`);
74
+ }
75
+ default: {
76
+ return jsonRpc(id, null);
77
+ }
78
+ }
79
+ });
80
+ // Tests ---------------------------------------------------------------------
81
+ describe('contract.write — stateOverride injected via balanceAwareTransport', () => {
82
+ beforeEach(() => {
83
+ vi.clearAllMocks();
84
+ });
85
+ afterEach(() => {
86
+ vi.restoreAllMocks();
87
+ });
88
+ it('eth_estimateGas called by contract.write includes stateOverride for the sender', async () => {
89
+ const capturedEstimateGasCalls = [];
90
+ vi.spyOn(globalThis, 'fetch').mockImplementation(buildFetchMock(capturedEstimateGasCalls));
91
+ const account = privateKeyToAccount(TEST_PRIVATE_KEY);
92
+ const client = createWalletClient({
93
+ account,
94
+ chain: MOCK_CHAIN,
95
+ transport: balanceAwareTransport('http://localhost:8545'),
96
+ });
97
+ const contract = getContract({
98
+ client,
99
+ abi: ERC20_ABI,
100
+ address: CONTRACT_ADDRESS,
101
+ });
102
+ // This is the exact path that was broken: viem's bound writeContract →
103
+ // sendTransaction → prepareTransactionRequest → estimateGas never reached
104
+ // the client.extend() override. With transport-level interception it works.
105
+ await contract.write.transfer([RECIPIENT, 100n]);
106
+ expect(capturedEstimateGasCalls).toHaveLength(1);
107
+ const estimateGasParams = capturedEstimateGasCalls[0].params;
108
+ // params[0] = tx object, params[1] = blockTag, params[2] = stateOverride
109
+ expect(estimateGasParams).toHaveLength(3);
110
+ expect(estimateGasParams[2]).toMatchObject({
111
+ [account.address]: { balance: MAX_UINT256_HEX },
112
+ });
113
+ });
114
+ it('walletClient.sendTransaction also injects stateOverride (non-contract path)', async () => {
115
+ const capturedEstimateGasCalls = [];
116
+ vi.spyOn(globalThis, 'fetch').mockImplementation(buildFetchMock(capturedEstimateGasCalls));
117
+ const account = privateKeyToAccount(TEST_PRIVATE_KEY);
118
+ const client = createWalletClient({
119
+ account,
120
+ chain: MOCK_CHAIN,
121
+ transport: balanceAwareTransport('http://localhost:8545'),
122
+ });
123
+ await client.sendTransaction({
124
+ to: RECIPIENT,
125
+ value: 0n,
126
+ });
127
+ expect(capturedEstimateGasCalls).toHaveLength(1);
128
+ const estimateGasParams = capturedEstimateGasCalls[0].params;
129
+ expect(estimateGasParams).toHaveLength(3);
130
+ expect(estimateGasParams[2]).toMatchObject({
131
+ [account.address]: { balance: MAX_UINT256_HEX },
132
+ });
133
+ });
134
+ });
135
+ //# sourceMappingURL=contract-write-stateoverride.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contract-write-stateoverride.test.js","sourceRoot":"","sources":["../../../tests/utils/contract-write-stateoverride.test.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
2
2
  import fs from 'fs-extra';
3
- import { exportCsv } from 'utils/csv-file.js';
3
+ import { exportCsv } from '../../utils/csv-file.js';
4
4
  vi.mock('fs-extra');
5
5
  describe('exportCsv', () => {
6
6
  const mockEnsureFileSync = vi.mocked(fs.ensureFileSync);
@@ -1,18 +1,34 @@
1
1
  import { describe, expect, test } from 'vitest';
2
- import { validateConfig, isValidUrl, transformAddressesToArray, validateAddressesMap, validateAddressMap, } from '../../utils/data-validators.js';
2
+ import { assertSafeUrl, validateConfig, transformAddressesToArray, validateAddressesMap, validateAddressMap, } from '../../utils/data-validators.js';
3
3
  describe('data-validators', () => {
4
+ describe('assertSafeUrl', () => {
5
+ test('passes for http URL', () => {
6
+ expect(() => assertSafeUrl('http://example.com', 'url')).not.toThrow();
7
+ });
8
+ test('passes for https URL', () => {
9
+ expect(() => assertSafeUrl('https://example.com/path?q=1', 'url')).not.toThrow();
10
+ });
11
+ test('throws for invalid URL', () => {
12
+ expect(() => assertSafeUrl('not-a-url', 'callback URL')).toThrow('callback URL: invalid URL: not-a-url');
13
+ });
14
+ test('throws for ftp scheme', () => {
15
+ expect(() => assertSafeUrl('ftp://example.com', 'url')).toThrow('unsupported URL scheme "ftp:" (only http/https allowed)');
16
+ });
17
+ test('throws for file scheme', () => {
18
+ expect(() => assertSafeUrl('file:///etc/passwd', 'url')).toThrow('unsupported URL scheme "file:" (only http/https allowed)');
19
+ });
20
+ test('includes label in error message', () => {
21
+ expect(() => assertSafeUrl('ftp://example.com', 'my label')).toThrow('my label:');
22
+ });
23
+ });
4
24
  test('validateConfig detects NaN', () => {
5
- const errors = validateConfig({ CHAIN_ID: NaN, DEPLOYED: 'true' });
25
+ const errors = validateConfig({ CHAIN_ID: Number.NaN, DEPLOYED: 'true' });
6
26
  expect(errors).toHaveProperty('CHAIN_ID');
7
27
  });
8
28
  test('validateConfig passes with number', () => {
9
29
  const errors = validateConfig({ CHAIN_ID: 1, DEPLOYED: 'true' });
10
30
  expect(errors).toEqual({});
11
31
  });
12
- test('isValidUrl works', () => {
13
- expect(isValidUrl('https://example.com')).toBe(true);
14
- expect(isValidUrl('not a url')).toBe(false);
15
- });
16
32
  test('transformAddressesToArray', () => {
17
33
  const role1 = '0x0000000000000000000000000000000000000001';
18
34
  const role2 = '0x0000000000000000000000000000000000000002';
@@ -1 +1 @@
1
- {"version":3,"file":"data-validators.test.js","sourceRoot":"","sources":["../../../tests/utils/data-validators.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAEhD,OAAO,EACL,cAAc,EACd,UAAU,EACV,yBAAyB,EACzB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,gCAAgC,CAAC;AAExC,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,IAAI,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACtC,MAAM,MAAM,GAAG,cAAc,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;QACnE,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC7C,MAAM,MAAM,GAAG,cAAc,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC;QACjE,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kBAAkB,EAAE,GAAG,EAAE;QAC5B,MAAM,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrD,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2BAA2B,EAAE,GAAG,EAAE;QACrC,MAAM,KAAK,GAAG,4CAA4C,CAAC;QAC3D,MAAM,KAAK,GAAG,4CAA4C,CAAC;QAE3D,MAAM,KAAK,GAAqB;YAC9B;gBACE,IAAI,EAAE,KAAK;gBACX,OAAO,EAAE,4CAA4C;aACtD;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,OAAO,EAAE,4CAA4C;aACtD;YACD;gBACE,IAAI,EAAE,KAAK;gBACX,OAAO,EAAE,4CAA4C;aACtD;SACF,CAAC;QACF,MAAM,MAAM,GAAG,yBAAyB,CAAC,KAAK,CAAC,CAAC;QAChD,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,CAAC,KAAK,CAAC,EAAE;gBACP,4CAA4C;gBAC5C,4CAA4C;aAC7C;YACD,CAAC,KAAK,CAAC,EAAE,CAAC,4CAA4C,CAAC;SACxD,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;QAC1D,MAAM,MAAM,GAAG,oBAAoB,CAAC;YAClC,IAAI,EAAE,CAAC,4CAA4C,EAAE,OAAO,CAAC;SAC9D,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACtD,MAAM,MAAM,GAAG,kBAAkB,CAAC;YAChC,IAAI,EAAE,OAAO;SACd,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,6BAA6B,CAAC,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"data-validators.test.js","sourceRoot":"","sources":["../../../tests/utils/data-validators.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,51 @@
1
+ import { describe, test, expect, vi, beforeEach } from 'vitest';
2
+ const mockEnvs = vi.hoisted(() => {
3
+ return {};
4
+ });
5
+ // Mock envs to control DEPLOYED value
6
+ vi.mock('../../configs/envs.js', () => ({
7
+ envs: new Proxy(mockEnvs, {
8
+ get: (_target, prop) => mockEnvs[prop],
9
+ }),
10
+ }));
11
+ // Mock fs calls so we don't hit actual filesystem
12
+ vi.mock('node:fs', async (importOriginal) => {
13
+ const actual = (await importOriginal());
14
+ return {
15
+ ...actual,
16
+ lstatSync: vi.fn(() => ({ isFile: () => true })),
17
+ readFileSync: vi.fn(() => '{"networkId": 1}'),
18
+ };
19
+ });
20
+ import { importDeployFile } from '../../configs/deployed.js';
21
+ beforeEach(() => {
22
+ vi.clearAllMocks();
23
+ // Clear all keys from mockEnvs
24
+ for (const key of Object.keys(mockEnvs)) {
25
+ delete mockEnvs[key];
26
+ }
27
+ });
28
+ describe('path traversal prevention (H4)', () => {
29
+ test('rejects path traversal with ../', () => {
30
+ mockEnvs.DEPLOYED = '../../etc/passwd';
31
+ expect(() => importDeployFile()).toThrow('Path traversal detected');
32
+ });
33
+ test('rejects path traversal with absolute path escape', () => {
34
+ mockEnvs.DEPLOYED = '../../../etc/shadow';
35
+ expect(() => importDeployFile()).toThrow('Path traversal detected');
36
+ });
37
+ test('allows valid filename in configs dir', () => {
38
+ mockEnvs.DEPLOYED = 'deployed-hoodi-vaults.json';
39
+ const result = importDeployFile();
40
+ expect(result).toEqual({ networkId: 1 });
41
+ });
42
+ test('allows subdirectory within configs', () => {
43
+ mockEnvs.DEPLOYED = 'subdir/deployed.json';
44
+ const result = importDeployFile();
45
+ expect(result).toEqual({ networkId: 1 });
46
+ });
47
+ test('throws when DEPLOYED is not set', () => {
48
+ expect(() => importDeployFile()).toThrow('Deployed contracts file is not set');
49
+ });
50
+ });
51
+ //# sourceMappingURL=deployed-security.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"deployed-security.test.js","sourceRoot":"","sources":["../../../tests/utils/deployed-security.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEhE,MAAM,QAAQ,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE;IAC/B,OAAO,EAAwC,CAAC;AAClD,CAAC,CAAC,CAAC;AAEH,sCAAsC;AACtC,EAAE,CAAC,IAAI,CAAC,uBAAuB,EAAE,GAAG,EAAE,CAAC,CAAC;IACtC,IAAI,EAAE,IAAI,KAAK,CAAC,QAAQ,EAAE;QACxB,GAAG,EAAE,CAAC,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAc,CAAC;KACjD,CAAC;CACH,CAAC,CAAC,CAAC;AAEJ,kDAAkD;AAClD,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE;IAC1C,MAAM,MAAM,GAAG,CAAC,MAAM,cAAc,EAAE,CAAQ,CAAC;IAC/C,OAAO;QACL,GAAG,MAAM;QACT,SAAS,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QAChD,YAAY,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;KAC9C,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAE7D,UAAU,CAAC,GAAG,EAAE;IACd,EAAE,CAAC,aAAa,EAAE,CAAC;IACnB,+BAA+B;IAC/B,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC;QACxC,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC;IACvB,CAAC;AACH,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,gCAAgC,EAAE,GAAG,EAAE;IAC9C,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC3C,QAAQ,CAAC,QAAQ,GAAG,kBAAkB,CAAC;QACvC,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,EAAE,CAAC,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC5D,QAAQ,CAAC,QAAQ,GAAG,qBAAqB,CAAC;QAC1C,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,EAAE,CAAC,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC;IACtE,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAChD,QAAQ,CAAC,QAAQ,GAAG,4BAA4B,CAAC;QACjD,MAAM,MAAM,GAAG,gBAAgB,EAAE,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC9C,QAAQ,CAAC,QAAQ,GAAG,sBAAsB,CAAC;QAC3C,MAAM,MAAM,GAAG,gBAAgB,EAAE,CAAC;QAClC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC3C,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,EAAE,CAAC,CAAC,OAAO,CACtC,oCAAoC,CACrC,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -12,7 +12,7 @@ describe('getCommandsJson', () => {
12
12
  const json = getCommandsJson(program);
13
13
  const arr = JSON.parse(json);
14
14
  expect(arr).toEqual([
15
- { Command: 'run r\\<file>', Description: 'Run command' },
15
+ { Command: String.raw `run r\<file>`, Description: 'Run command' },
16
16
  ]);
17
17
  });
18
18
  });
@@ -1 +1 @@
1
- {"version":3,"file":"get-commands.test.js","sourceRoot":"","sources":["../../../tests/utils/get-commands.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAChD,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;QAC9B,OAAO;aACJ,OAAO,CAAC,KAAK,CAAC;aACd,KAAK,CAAC,GAAG,CAAC;aACV,WAAW,CAAC,aAAa,CAAC;aAC1B,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtB,MAAM,IAAI,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;YAClB,EAAE,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,aAAa,EAAE;SACzD,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"get-commands.test.js","sourceRoot":"","sources":["../../../tests/utils/get-commands.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAE9D,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAChD,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;QAC9B,OAAO;aACJ,OAAO,CAAC,KAAK,CAAC;aACd,KAAK,CAAC,GAAG,CAAC;aACV,WAAW,CAAC,aAAa,CAAC;aAC1B,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACtB,MAAM,IAAI,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;YAClB,EAAE,OAAO,EAAE,MAAM,CAAC,GAAG,CAAA,cAAc,EAAE,WAAW,EAAE,aAAa,EAAE;SAClE,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1 @@
1
+ export {};