@lidofinance/lsv-cli 1.0.0-alpha.54 → 1.0.0-alpha.56

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 (509) hide show
  1. package/README.md +3 -3
  2. package/dist/abi/AccessControlConfirmable.d.ts +331 -0
  3. package/dist/abi/AccessControlConfirmable.js +430 -0
  4. package/dist/abi/AccessControlConfirmable.js.map +1 -0
  5. package/dist/abi/Dashboard.d.ts +813 -374
  6. package/dist/abi/Dashboard.js +458 -277
  7. package/dist/abi/Dashboard.js.map +1 -1
  8. package/dist/abi/LazyOracle.d.ts +604 -0
  9. package/dist/abi/LazyOracle.js +782 -0
  10. package/dist/abi/LazyOracle.js.map +1 -0
  11. package/dist/abi/LidoLocator.d.ts +28 -0
  12. package/dist/abi/LidoLocator.js +36 -0
  13. package/dist/abi/LidoLocator.js.map +1 -1
  14. package/dist/abi/OperatorGrid.d.ts +340 -169
  15. package/dist/abi/OperatorGrid.js +344 -164
  16. package/dist/abi/OperatorGrid.js.map +1 -1
  17. package/dist/abi/PredepositGuarantee.d.ts +371 -56
  18. package/dist/abi/PredepositGuarantee.js +290 -69
  19. package/dist/abi/PredepositGuarantee.js.map +1 -1
  20. package/dist/abi/StakingVault.d.ts +97 -425
  21. package/dist/abi/StakingVault.js +94 -419
  22. package/dist/abi/StakingVault.js.map +1 -1
  23. package/dist/abi/VaultFactory.d.ts +209 -134
  24. package/dist/abi/VaultFactory.js +66 -10
  25. package/dist/abi/VaultFactory.js.map +1 -1
  26. package/dist/abi/VaultHub.d.ts +1109 -445
  27. package/dist/abi/VaultHub.js +1502 -559
  28. package/dist/abi/VaultHub.js.map +1 -1
  29. package/dist/abi/VaultViewer.d.ts +308 -1
  30. package/dist/abi/VaultViewer.js +399 -1
  31. package/dist/abi/VaultViewer.js.map +1 -1
  32. package/dist/abi/index.d.ts +2 -3
  33. package/dist/abi/index.js +2 -4
  34. package/dist/abi/index.js.map +1 -1
  35. package/dist/command/index.js +1 -1
  36. package/dist/command/index.js.map +1 -1
  37. package/dist/contracts/index.d.ts +1 -4
  38. package/dist/contracts/index.js +1 -4
  39. package/dist/contracts/index.js.map +1 -1
  40. package/dist/contracts/lazy-oracle.d.ts +3 -0
  41. package/dist/contracts/lazy-oracle.js +18 -0
  42. package/dist/contracts/lazy-oracle.js.map +1 -0
  43. package/dist/contracts/locator.d.ts +1342 -38
  44. package/dist/contracts/operator-grid.d.ts +1 -0
  45. package/dist/contracts/pdg.d.ts +1 -0
  46. package/dist/contracts/vault-factory.d.ts +8849 -3187
  47. package/dist/contracts/vault-viewer.d.ts +6467 -73
  48. package/dist/contracts/vault-viewer.js +1 -1
  49. package/dist/contracts/vault.d.ts +1 -0
  50. package/dist/features/dashboard.js +5 -250
  51. package/dist/features/dashboard.js.map +1 -1
  52. package/dist/features/deposits/check-bls-deposits.d.ts +3 -0
  53. package/dist/features/deposits/check-bls-deposits.js +15 -0
  54. package/dist/features/deposits/check-bls-deposits.js.map +1 -0
  55. package/dist/features/deposits/index.d.ts +3 -0
  56. package/dist/features/deposits/index.js +4 -0
  57. package/dist/features/deposits/index.js.map +1 -0
  58. package/dist/features/deposits/make-pdg-proof.d.ts +3 -0
  59. package/dist/features/deposits/make-pdg-proof.js +52 -0
  60. package/dist/features/deposits/make-pdg-proof.js.map +1 -0
  61. package/dist/features/deposits/no-pdg.d.ts +21 -0
  62. package/dist/features/deposits/no-pdg.js +92 -0
  63. package/dist/features/deposits/no-pdg.js.map +1 -0
  64. package/dist/features/index.d.ts +4 -0
  65. package/dist/features/index.js +4 -0
  66. package/dist/features/index.js.map +1 -1
  67. package/dist/features/mint-burn/allowance.d.ts +2 -0
  68. package/dist/features/mint-burn/allowance.js +49 -0
  69. package/dist/features/mint-burn/allowance.js.map +1 -0
  70. package/dist/features/mint-burn/burn-shares.d.ts +3 -0
  71. package/dist/features/mint-burn/burn-shares.js +33 -0
  72. package/dist/features/mint-burn/burn-shares.js.map +1 -0
  73. package/dist/features/mint-burn/burn-steth.d.ts +3 -0
  74. package/dist/features/mint-burn/burn-steth.js +35 -0
  75. package/dist/features/mint-burn/burn-steth.js.map +1 -0
  76. package/dist/features/mint-burn/index.d.ts +5 -0
  77. package/dist/features/mint-burn/index.js +6 -0
  78. package/dist/features/mint-burn/index.js.map +1 -0
  79. package/dist/features/mint-burn/mint-shares.d.ts +3 -0
  80. package/dist/features/mint-burn/mint-shares.js +37 -0
  81. package/dist/features/mint-burn/mint-shares.js.map +1 -0
  82. package/dist/features/mint-burn/mint-steth.d.ts +3 -0
  83. package/dist/features/mint-burn/mint-steth.js +39 -0
  84. package/dist/features/mint-burn/mint-steth.js.map +1 -0
  85. package/dist/features/pdg.js +17 -23
  86. package/dist/features/pdg.js.map +1 -1
  87. package/dist/features/utils/get-address.d.ts +2 -0
  88. package/dist/features/utils/get-address.js +16 -0
  89. package/dist/features/utils/get-address.js.map +1 -0
  90. package/dist/features/utils/index.d.ts +4 -0
  91. package/dist/features/utils/index.js +5 -0
  92. package/dist/features/utils/index.js.map +1 -0
  93. package/dist/features/utils/liability-shares.d.ts +2 -0
  94. package/dist/features/utils/liability-shares.js +10 -0
  95. package/dist/features/utils/liability-shares.js.map +1 -0
  96. package/dist/features/utils/minting-capacity.d.ts +2 -0
  97. package/dist/features/utils/minting-capacity.js +11 -0
  98. package/dist/features/utils/minting-capacity.js.map +1 -0
  99. package/dist/features/utils/report-fresh.d.ts +2 -0
  100. package/dist/features/utils/report-fresh.js +18 -0
  101. package/dist/features/utils/report-fresh.js.map +1 -0
  102. package/dist/features/vault-factory.d.ts +17 -1
  103. package/dist/features/vault-factory.js +44 -8
  104. package/dist/features/vault-factory.js.map +1 -1
  105. package/dist/features/vault-hub.js +6 -6
  106. package/dist/features/vault-hub.js.map +1 -1
  107. package/dist/features/vault-operations/create-vault.d.ts +2 -0
  108. package/dist/features/vault-operations/create-vault.js +58 -0
  109. package/dist/features/vault-operations/create-vault.js.map +1 -0
  110. package/dist/features/vault-operations/dashboard-by-vault.d.ts +11 -0
  111. package/dist/features/vault-operations/dashboard-by-vault.js +34 -0
  112. package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -0
  113. package/dist/features/vault-operations/index.d.ts +7 -0
  114. package/dist/features/vault-operations/index.js +8 -0
  115. package/dist/features/vault-operations/index.js.map +1 -0
  116. package/dist/features/vault-operations/vault-health.d.ts +2 -0
  117. package/dist/features/vault-operations/vault-health.js +24 -0
  118. package/dist/features/vault-operations/vault-health.js.map +1 -0
  119. package/dist/features/vault-operations/vault-info.d.ts +2 -0
  120. package/dist/features/vault-operations/vault-info.js +107 -0
  121. package/dist/features/vault-operations/vault-info.js.map +1 -0
  122. package/dist/features/vault-operations/vault-overview.d.ts +2 -0
  123. package/dist/features/vault-operations/vault-overview.js +139 -0
  124. package/dist/features/vault-operations/vault-overview.js.map +1 -0
  125. package/dist/features/vault-operations/vault-roles.d.ts +6 -0
  126. package/dist/features/vault-operations/vault-roles.js +62 -0
  127. package/dist/features/vault-operations/vault-roles.js.map +1 -0
  128. package/dist/features/vault-operations/vaults-by-role.d.ts +3 -0
  129. package/dist/features/vault-operations/vaults-by-role.js +45 -0
  130. package/dist/features/vault-operations/vaults-by-role.js.map +1 -0
  131. package/dist/features/vault.js +6 -14
  132. package/dist/features/vault.js.map +1 -1
  133. package/dist/index.js +16 -1
  134. package/dist/index.js.map +1 -1
  135. package/dist/programs/account/read.js +5 -1
  136. package/dist/programs/account/read.js.map +1 -1
  137. package/dist/programs/contracts/dashboard/config.d.ts +3 -0
  138. package/dist/programs/{dashboard → contracts/dashboard}/config.js +43 -35
  139. package/dist/programs/contracts/dashboard/config.js.map +1 -0
  140. package/dist/programs/contracts/dashboard/index.js.map +1 -0
  141. package/dist/programs/contracts/dashboard/main.js +5 -0
  142. package/dist/programs/contracts/dashboard/main.js.map +1 -0
  143. package/dist/programs/{dashboard → contracts/dashboard}/read.js +6 -33
  144. package/dist/programs/contracts/dashboard/read.js.map +1 -0
  145. package/dist/programs/{dashboard → contracts/dashboard}/write.js +109 -130
  146. package/dist/programs/contracts/dashboard/write.js.map +1 -0
  147. package/dist/programs/contracts/hub/config.d.ts +3 -0
  148. package/dist/programs/contracts/hub/config.js +165 -0
  149. package/dist/programs/contracts/hub/config.js.map +1 -0
  150. package/dist/programs/contracts/hub/index.js.map +1 -0
  151. package/dist/programs/contracts/hub/main.js +5 -0
  152. package/dist/programs/contracts/hub/main.js.map +1 -0
  153. package/dist/programs/{hub → contracts/hub}/read.js +13 -18
  154. package/dist/programs/contracts/hub/read.js.map +1 -0
  155. package/dist/programs/contracts/hub/write.js +425 -0
  156. package/dist/programs/contracts/hub/write.js.map +1 -0
  157. package/dist/programs/contracts/index.d.ts +8 -0
  158. package/dist/programs/contracts/index.js +9 -0
  159. package/dist/programs/contracts/index.js.map +1 -0
  160. package/dist/programs/contracts/main.d.ts +1 -0
  161. package/dist/programs/contracts/main.js +6 -0
  162. package/dist/programs/contracts/main.js.map +1 -0
  163. package/dist/programs/contracts/operator-grid/config.d.ts +3 -0
  164. package/dist/programs/{operator-grid → contracts/operator-grid}/config.js +40 -34
  165. package/dist/programs/contracts/operator-grid/config.js.map +1 -0
  166. package/dist/programs/contracts/operator-grid/index.js.map +1 -0
  167. package/dist/programs/contracts/operator-grid/main.js +5 -0
  168. package/dist/programs/contracts/operator-grid/main.js.map +1 -0
  169. package/dist/programs/{operator-grid → contracts/operator-grid}/read.js +4 -4
  170. package/dist/programs/contracts/operator-grid/read.js.map +1 -0
  171. package/dist/programs/{operator-grid → contracts/operator-grid}/write.js +27 -32
  172. package/dist/programs/contracts/operator-grid/write.js.map +1 -0
  173. package/dist/programs/contracts/pdg/config.d.ts +3 -0
  174. package/dist/programs/{pdg → contracts/pdg}/config.js +53 -27
  175. package/dist/programs/contracts/pdg/config.js.map +1 -0
  176. package/dist/programs/contracts/pdg/index.js.map +1 -0
  177. package/dist/programs/contracts/pdg/main.js +5 -0
  178. package/dist/programs/contracts/pdg/main.js.map +1 -0
  179. package/dist/programs/{pdg → contracts/pdg}/read.js +4 -4
  180. package/dist/programs/contracts/pdg/read.js.map +1 -0
  181. package/dist/programs/{pdg → contracts/pdg}/write.js +38 -20
  182. package/dist/programs/contracts/pdg/write.js.map +1 -0
  183. package/dist/programs/contracts/vault/config.d.ts +3 -0
  184. package/dist/programs/{vault → contracts/vault}/config.js +0 -28
  185. package/dist/programs/contracts/vault/config.js.map +1 -0
  186. package/dist/programs/contracts/vault/index.js.map +1 -0
  187. package/dist/programs/contracts/vault/main.js +3 -0
  188. package/dist/programs/contracts/vault/main.js.map +1 -0
  189. package/dist/programs/{vault → contracts/vault}/read.js +4 -4
  190. package/dist/programs/contracts/vault/read.js.map +1 -0
  191. package/dist/programs/{vault → contracts/vault}/write.js +37 -70
  192. package/dist/programs/contracts/vault/write.js.map +1 -0
  193. package/dist/programs/contracts/vault-factory/config.d.ts +3 -0
  194. package/dist/programs/contracts/vault-factory/config.js.map +1 -0
  195. package/dist/programs/contracts/vault-factory/index.js.map +1 -0
  196. package/dist/programs/contracts/vault-factory/main.js +5 -0
  197. package/dist/programs/contracts/vault-factory/main.js.map +1 -0
  198. package/dist/programs/{vault-factory → contracts/vault-factory}/read.js +4 -4
  199. package/dist/programs/contracts/vault-factory/read.js.map +1 -0
  200. package/dist/programs/contracts/vault-factory/write.js +126 -0
  201. package/dist/programs/contracts/vault-factory/write.js.map +1 -0
  202. package/dist/programs/contracts/vault-viewer/config.d.ts +3 -0
  203. package/dist/programs/contracts/vault-viewer/config.js.map +1 -0
  204. package/dist/programs/contracts/vault-viewer/index.js.map +1 -0
  205. package/dist/programs/contracts/vault-viewer/main.js +5 -0
  206. package/dist/programs/contracts/vault-viewer/main.js.map +1 -0
  207. package/dist/programs/contracts/vault-viewer/read.d.ts +1 -0
  208. package/dist/programs/{vault-viewer → contracts/vault-viewer}/read.js +20 -10
  209. package/dist/programs/contracts/vault-viewer/read.js.map +1 -0
  210. package/dist/programs/index.d.ts +2 -9
  211. package/dist/programs/index.js +2 -9
  212. package/dist/programs/index.js.map +1 -1
  213. package/dist/programs/pdg-helpers.js +46 -10
  214. package/dist/programs/pdg-helpers.js.map +1 -1
  215. package/dist/programs/use-cases/deposits/index.js.map +1 -0
  216. package/dist/programs/use-cases/deposits/main.d.ts +1 -0
  217. package/dist/programs/use-cases/deposits/main.js +6 -0
  218. package/dist/programs/use-cases/deposits/main.js.map +1 -0
  219. package/dist/programs/use-cases/deposits/read.js +13 -0
  220. package/dist/programs/use-cases/deposits/read.js.map +1 -0
  221. package/dist/programs/use-cases/deposits/write.js +211 -0
  222. package/dist/programs/use-cases/deposits/write.js.map +1 -0
  223. package/dist/programs/use-cases/index.d.ts +4 -0
  224. package/dist/programs/use-cases/index.js +5 -0
  225. package/dist/programs/use-cases/index.js.map +1 -0
  226. package/dist/programs/use-cases/metrics/index.js.map +1 -0
  227. package/dist/programs/use-cases/metrics/main.js +6 -0
  228. package/dist/programs/use-cases/metrics/main.js.map +1 -0
  229. package/dist/programs/{metrics → use-cases/metrics}/read.js +29 -23
  230. package/dist/programs/use-cases/metrics/read.js.map +1 -0
  231. package/dist/programs/use-cases/report/index.d.ts +3 -0
  232. package/dist/programs/use-cases/report/index.js +4 -0
  233. package/dist/programs/use-cases/report/index.js.map +1 -0
  234. package/dist/programs/use-cases/report/main.js +6 -0
  235. package/dist/programs/use-cases/report/main.js.map +1 -0
  236. package/dist/programs/{report → use-cases/report}/read.js +32 -41
  237. package/dist/programs/use-cases/report/read.js.map +1 -0
  238. package/dist/programs/{report → use-cases/report}/write.js +33 -42
  239. package/dist/programs/use-cases/report/write.js.map +1 -0
  240. package/dist/programs/use-cases/vault-operations/create-vault.js +129 -0
  241. package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -0
  242. package/dist/programs/use-cases/vault-operations/index.d.ts +4 -0
  243. package/dist/programs/use-cases/vault-operations/index.js +5 -0
  244. package/dist/programs/use-cases/vault-operations/index.js.map +1 -0
  245. package/dist/programs/use-cases/vault-operations/main.d.ts +1 -0
  246. package/dist/programs/use-cases/vault-operations/main.js +6 -0
  247. package/dist/programs/use-cases/vault-operations/main.js.map +1 -0
  248. package/dist/programs/use-cases/vault-operations/read.js +46 -0
  249. package/dist/programs/use-cases/vault-operations/read.js.map +1 -0
  250. package/dist/programs/use-cases/vault-operations/write.d.ts +1 -0
  251. package/dist/programs/use-cases/vault-operations/write.js +148 -0
  252. package/dist/programs/use-cases/vault-operations/write.js.map +1 -0
  253. package/dist/providers/wallet.d.ts +10 -10
  254. package/dist/tests/utils/error-handler.test.js +0 -8
  255. package/dist/tests/utils/error-handler.test.js.map +1 -1
  256. package/dist/tests/utils/ipfs.test.js +2 -2
  257. package/dist/tests/utils/ipfs.test.js.map +1 -1
  258. package/dist/types/common.d.ts +6 -2
  259. package/dist/utils/arguments.d.ts +1 -0
  260. package/dist/utils/arguments.js +3 -0
  261. package/dist/utils/arguments.js.map +1 -1
  262. package/dist/utils/cache.d.ts +2 -2
  263. package/dist/utils/cache.js +7 -7
  264. package/dist/utils/cache.js.map +1 -1
  265. package/dist/utils/calculate-overview-v2.d.ts +4 -7
  266. package/dist/utils/calculate-overview-v2.js +23 -21
  267. package/dist/utils/calculate-overview-v2.js.map +1 -1
  268. package/dist/utils/calculate-overview.d.ts +0 -1
  269. package/dist/utils/calculate-overview.js +1 -3
  270. package/dist/utils/calculate-overview.js.map +1 -1
  271. package/dist/utils/charts/blessed/charts-apr.js +6 -3
  272. package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
  273. package/dist/utils/charts/blessed/charts-rewards.js +3 -3
  274. package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
  275. package/dist/utils/charts/blessed/datasets/prepare-metrics.js +4 -4
  276. package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
  277. package/dist/utils/charts/simple/simple-charts.js +5 -5
  278. package/dist/utils/charts/simple/simple-charts.js.map +1 -1
  279. package/dist/utils/commands/confirmations.d.ts +20 -8
  280. package/dist/utils/commands/confirmations.js +30 -14
  281. package/dist/utils/commands/confirmations.js.map +1 -1
  282. package/dist/utils/commands/index.d.ts +0 -2
  283. package/dist/utils/commands/index.js +0 -2
  284. package/dist/utils/commands/index.js.map +1 -1
  285. package/dist/utils/commands/report.d.ts +1 -1
  286. package/dist/utils/commands/report.js +18 -25
  287. package/dist/utils/commands/report.js.map +1 -1
  288. package/dist/utils/consts.d.ts +3 -0
  289. package/dist/utils/consts.js +4 -0
  290. package/dist/utils/consts.js.map +1 -0
  291. package/dist/utils/fetchCL.d.ts +22 -0
  292. package/dist/utils/fetchCL.js +12 -0
  293. package/dist/utils/fetchCL.js.map +1 -1
  294. package/dist/utils/index.d.ts +2 -1
  295. package/dist/utils/index.js +2 -1
  296. package/dist/utils/index.js.map +1 -1
  297. package/dist/utils/prompts/confirmations.js +2 -2
  298. package/dist/utils/prompts/confirmations.js.map +1 -1
  299. package/dist/utils/prompts/default.d.ts +2 -0
  300. package/dist/utils/prompts/default.js +7 -0
  301. package/dist/utils/prompts/default.js.map +1 -1
  302. package/dist/utils/prompts/index.d.ts +1 -1
  303. package/dist/utils/prompts/index.js +1 -1
  304. package/dist/utils/prompts/index.js.map +1 -1
  305. package/dist/utils/prompts/mint-burn/confirm-burn.d.ts +17 -0
  306. package/dist/utils/prompts/mint-burn/confirm-burn.js +23 -0
  307. package/dist/utils/prompts/mint-burn/confirm-burn.js.map +1 -0
  308. package/dist/utils/prompts/{dashboard.d.ts → mint-burn/confirm-mint.d.ts} +0 -15
  309. package/dist/utils/prompts/mint-burn/confirm-mint.js +23 -0
  310. package/dist/utils/prompts/mint-burn/confirm-mint.js.map +1 -0
  311. package/dist/utils/prompts/mint-burn/constants.d.ts +2 -0
  312. package/dist/utils/prompts/mint-burn/constants.js +6 -0
  313. package/dist/utils/prompts/mint-burn/constants.js.map +1 -0
  314. package/dist/utils/prompts/mint-burn/index.d.ts +2 -0
  315. package/dist/utils/prompts/mint-burn/index.js +3 -0
  316. package/dist/utils/prompts/mint-burn/index.js.map +1 -0
  317. package/dist/utils/prompts/operations.d.ts +1 -1
  318. package/dist/utils/prompts/operations.js +3 -3
  319. package/dist/utils/prompts/operations.js.map +1 -1
  320. package/dist/utils/prompts/predeposit-guarantee.d.ts +2 -2
  321. package/dist/utils/prompts/predeposit-guarantee.js.map +1 -1
  322. package/dist/utils/proof/create-proof.d.ts +4 -0
  323. package/dist/utils/proof/create-proof.js +2 -0
  324. package/dist/utils/proof/create-proof.js.map +1 -1
  325. package/dist/utils/proof/index.d.ts +0 -1
  326. package/dist/utils/proof/index.js +0 -1
  327. package/dist/utils/proof/index.js.map +1 -1
  328. package/dist/utils/read-programs-by-abi.d.ts +11 -4
  329. package/dist/utils/read-programs-by-abi.js +4 -3
  330. package/dist/utils/read-programs-by-abi.js.map +1 -1
  331. package/dist/utils/report/index.d.ts +2 -1
  332. package/dist/utils/report/index.js +2 -1
  333. package/dist/utils/report/index.js.map +1 -1
  334. package/dist/utils/report/report-proof.d.ts +42 -0
  335. package/dist/utils/report/report-proof.js +38 -0
  336. package/dist/utils/report/report-proof.js.map +1 -0
  337. package/dist/utils/report/report.d.ts +3 -60
  338. package/dist/utils/report/report.js +14 -8
  339. package/dist/utils/report/report.js.map +1 -1
  340. package/dist/utils/report/statistic-data.d.ts +1 -1
  341. package/dist/utils/report/statistic-data.js +5 -6
  342. package/dist/utils/report/statistic-data.js.map +1 -1
  343. package/dist/utils/report/types.d.ts +69 -0
  344. package/dist/utils/report/types.js +2 -0
  345. package/dist/utils/report/types.js.map +1 -0
  346. package/dist/utils/statistic/index.d.ts +1 -0
  347. package/dist/utils/statistic/index.js +2 -0
  348. package/dist/utils/statistic/index.js.map +1 -0
  349. package/dist/utils/{report → statistic}/report-statistic.d.ts +3 -3
  350. package/dist/utils/{report → statistic}/report-statistic.js +16 -19
  351. package/dist/utils/statistic/report-statistic.js.map +1 -0
  352. package/dist/version/index.js +1 -1
  353. package/package.json +2 -1
  354. package/dist/abi/BlsHarness.d.ts +0 -178
  355. package/dist/abi/BlsHarness.js +0 -232
  356. package/dist/abi/BlsHarness.js.map +0 -1
  357. package/dist/abi/CLProofVerifier.d.ts +0 -188
  358. package/dist/abi/CLProofVerifier.js +0 -247
  359. package/dist/abi/CLProofVerifier.js.map +0 -1
  360. package/dist/abi/ReportChecker.d.ts +0 -83
  361. package/dist/abi/ReportChecker.js +0 -109
  362. package/dist/abi/ReportChecker.js.map +0 -1
  363. package/dist/contracts/blsHarness.d.ts +0 -947
  364. package/dist/contracts/blsHarness.js +0 -24
  365. package/dist/contracts/blsHarness.js.map +0 -1
  366. package/dist/contracts/clProofVerifier.d.ts +0 -2647
  367. package/dist/contracts/clProofVerifier.js +0 -23
  368. package/dist/contracts/clProofVerifier.js.map +0 -1
  369. package/dist/contracts/reportChecker.d.ts +0 -758
  370. package/dist/contracts/reportChecker.js +0 -23
  371. package/dist/contracts/reportChecker.js.map +0 -1
  372. package/dist/contracts/voting.d.ts +0 -6
  373. package/dist/contracts/voting.js +0 -19
  374. package/dist/contracts/voting.js.map +0 -1
  375. package/dist/programs/dashboard/config.d.ts +0 -2
  376. package/dist/programs/dashboard/config.js.map +0 -1
  377. package/dist/programs/dashboard/index.js.map +0 -1
  378. package/dist/programs/dashboard/main.js +0 -5
  379. package/dist/programs/dashboard/main.js.map +0 -1
  380. package/dist/programs/dashboard/read.js.map +0 -1
  381. package/dist/programs/dashboard/write.js.map +0 -1
  382. package/dist/programs/hub/config.d.ts +0 -2
  383. package/dist/programs/hub/config.js +0 -123
  384. package/dist/programs/hub/config.js.map +0 -1
  385. package/dist/programs/hub/index.js.map +0 -1
  386. package/dist/programs/hub/main.js +0 -5
  387. package/dist/programs/hub/main.js.map +0 -1
  388. package/dist/programs/hub/read.js.map +0 -1
  389. package/dist/programs/hub/write.js +0 -246
  390. package/dist/programs/hub/write.js.map +0 -1
  391. package/dist/programs/metrics/index.js.map +0 -1
  392. package/dist/programs/metrics/main.js +0 -3
  393. package/dist/programs/metrics/main.js.map +0 -1
  394. package/dist/programs/metrics/read.js.map +0 -1
  395. package/dist/programs/operator-grid/config.d.ts +0 -2
  396. package/dist/programs/operator-grid/config.js.map +0 -1
  397. package/dist/programs/operator-grid/index.js.map +0 -1
  398. package/dist/programs/operator-grid/main.js +0 -5
  399. package/dist/programs/operator-grid/main.js.map +0 -1
  400. package/dist/programs/operator-grid/read.js.map +0 -1
  401. package/dist/programs/operator-grid/write.js.map +0 -1
  402. package/dist/programs/pdg/config.d.ts +0 -2
  403. package/dist/programs/pdg/config.js.map +0 -1
  404. package/dist/programs/pdg/index.js.map +0 -1
  405. package/dist/programs/pdg/main.js +0 -5
  406. package/dist/programs/pdg/main.js.map +0 -1
  407. package/dist/programs/pdg/read.js.map +0 -1
  408. package/dist/programs/pdg/write.js.map +0 -1
  409. package/dist/programs/report/index.js.map +0 -1
  410. package/dist/programs/report/main.js +0 -3
  411. package/dist/programs/report/main.js.map +0 -1
  412. package/dist/programs/report/read.js.map +0 -1
  413. package/dist/programs/report/write.js.map +0 -1
  414. package/dist/programs/vault/config.d.ts +0 -2
  415. package/dist/programs/vault/config.js.map +0 -1
  416. package/dist/programs/vault/index.js.map +0 -1
  417. package/dist/programs/vault/main.js +0 -3
  418. package/dist/programs/vault/main.js.map +0 -1
  419. package/dist/programs/vault/read.js.map +0 -1
  420. package/dist/programs/vault/write.js.map +0 -1
  421. package/dist/programs/vault-factory/config.d.ts +0 -2
  422. package/dist/programs/vault-factory/config.js.map +0 -1
  423. package/dist/programs/vault-factory/index.js.map +0 -1
  424. package/dist/programs/vault-factory/main.js +0 -5
  425. package/dist/programs/vault-factory/main.js.map +0 -1
  426. package/dist/programs/vault-factory/read.js.map +0 -1
  427. package/dist/programs/vault-factory/write.js +0 -86
  428. package/dist/programs/vault-factory/write.js.map +0 -1
  429. package/dist/programs/vault-viewer/config.d.ts +0 -2
  430. package/dist/programs/vault-viewer/config.js.map +0 -1
  431. package/dist/programs/vault-viewer/index.js.map +0 -1
  432. package/dist/programs/vault-viewer/main.js +0 -10
  433. package/dist/programs/vault-viewer/main.js.map +0 -1
  434. package/dist/programs/vault-viewer/read.js.map +0 -1
  435. package/dist/tests/__mocks__/@lodestar/types.js +0 -6
  436. package/dist/tests/__mocks__/@lodestar/types.js.map +0 -1
  437. package/dist/tests/utils/fetchCL.test.js +0 -57
  438. package/dist/tests/utils/fetchCL.test.js.map +0 -1
  439. package/dist/tests/utils/report-proof.test.js +0 -29
  440. package/dist/tests/utils/report-proof.test.js.map +0 -1
  441. package/dist/tests/utils/report-statistic.test.d.ts +0 -1
  442. package/dist/tests/utils/report-statistic.test.js +0 -247
  443. package/dist/tests/utils/report-statistic.test.js.map +0 -1
  444. package/dist/tests/utils/required-lock.test.d.ts +0 -1
  445. package/dist/tests/utils/required-lock.test.js +0 -26
  446. package/dist/tests/utils/required-lock.test.js.map +0 -1
  447. package/dist/utils/commands/dashboard.d.ts +0 -6
  448. package/dist/utils/commands/dashboard.js +0 -145
  449. package/dist/utils/commands/dashboard.js.map +0 -1
  450. package/dist/utils/commands/utils.d.ts +0 -6
  451. package/dist/utils/commands/utils.js +0 -57
  452. package/dist/utils/commands/utils.js.map +0 -1
  453. package/dist/utils/prompts/dashboard.js +0 -45
  454. package/dist/utils/prompts/dashboard.js.map +0 -1
  455. package/dist/utils/proof/report-proof.d.ts +0 -5
  456. package/dist/utils/proof/report-proof.js +0 -26
  457. package/dist/utils/proof/report-proof.js.map +0 -1
  458. package/dist/utils/report/report-statistic.js.map +0 -1
  459. package/dist/utils/required-lock.d.ts +0 -5
  460. package/dist/utils/required-lock.js +0 -21
  461. package/dist/utils/required-lock.js.map +0 -1
  462. /package/dist/programs/{dashboard → contracts/dashboard}/index.d.ts +0 -0
  463. /package/dist/programs/{dashboard → contracts/dashboard}/index.js +0 -0
  464. /package/dist/programs/{dashboard → contracts/dashboard}/main.d.ts +0 -0
  465. /package/dist/programs/{dashboard → contracts/dashboard}/read.d.ts +0 -0
  466. /package/dist/programs/{dashboard → contracts/dashboard}/write.d.ts +0 -0
  467. /package/dist/programs/{hub → contracts/hub}/index.d.ts +0 -0
  468. /package/dist/programs/{hub → contracts/hub}/index.js +0 -0
  469. /package/dist/programs/{hub → contracts/hub}/main.d.ts +0 -0
  470. /package/dist/programs/{hub → contracts/hub}/read.d.ts +0 -0
  471. /package/dist/programs/{hub → contracts/hub}/write.d.ts +0 -0
  472. /package/dist/programs/{operator-grid → contracts/operator-grid}/index.d.ts +0 -0
  473. /package/dist/programs/{operator-grid → contracts/operator-grid}/index.js +0 -0
  474. /package/dist/programs/{operator-grid → contracts/operator-grid}/main.d.ts +0 -0
  475. /package/dist/programs/{metrics → contracts/operator-grid}/read.d.ts +0 -0
  476. /package/dist/programs/{operator-grid → contracts/operator-grid}/write.d.ts +0 -0
  477. /package/dist/programs/{pdg → contracts/pdg}/index.d.ts +0 -0
  478. /package/dist/programs/{pdg → contracts/pdg}/index.js +0 -0
  479. /package/dist/programs/{pdg → contracts/pdg}/main.d.ts +0 -0
  480. /package/dist/programs/{operator-grid → contracts/pdg}/read.d.ts +0 -0
  481. /package/dist/programs/{pdg → contracts/pdg}/write.d.ts +0 -0
  482. /package/dist/programs/{vault-factory → contracts/vault}/index.d.ts +0 -0
  483. /package/dist/programs/{vault-factory → contracts/vault}/index.js +0 -0
  484. /package/dist/programs/{vault → contracts/vault}/main.d.ts +0 -0
  485. /package/dist/programs/{report → contracts/vault}/read.d.ts +0 -0
  486. /package/dist/programs/{vault-factory → contracts/vault}/write.d.ts +0 -0
  487. /package/dist/programs/{vault-factory → contracts/vault-factory}/config.js +0 -0
  488. /package/dist/programs/{report → contracts/vault-factory}/index.d.ts +0 -0
  489. /package/dist/programs/{report → contracts/vault-factory}/index.js +0 -0
  490. /package/dist/programs/{vault-factory → contracts/vault-factory}/main.d.ts +0 -0
  491. /package/dist/programs/{pdg → contracts/vault-factory}/read.d.ts +0 -0
  492. /package/dist/programs/{report → contracts/vault-factory}/write.d.ts +0 -0
  493. /package/dist/programs/{vault-viewer → contracts/vault-viewer}/config.js +0 -0
  494. /package/dist/programs/{metrics → contracts/vault-viewer}/index.d.ts +0 -0
  495. /package/dist/programs/{metrics → contracts/vault-viewer}/index.js +0 -0
  496. /package/dist/programs/{vault-viewer → contracts/vault-viewer}/main.d.ts +0 -0
  497. /package/dist/programs/{vault → use-cases/deposits}/index.d.ts +0 -0
  498. /package/dist/programs/{vault → use-cases/deposits}/index.js +0 -0
  499. /package/dist/programs/{vault-factory → use-cases/deposits}/read.d.ts +0 -0
  500. /package/dist/programs/{vault → use-cases/deposits}/write.d.ts +0 -0
  501. /package/dist/programs/{vault-viewer → use-cases/metrics}/index.d.ts +0 -0
  502. /package/dist/programs/{vault-viewer → use-cases/metrics}/index.js +0 -0
  503. /package/dist/programs/{metrics → use-cases/metrics}/main.d.ts +0 -0
  504. /package/dist/programs/{vault-viewer → use-cases/metrics}/read.d.ts +0 -0
  505. /package/dist/programs/{report → use-cases/report}/main.d.ts +0 -0
  506. /package/dist/programs/{vault → use-cases/report}/read.d.ts +0 -0
  507. /package/dist/{tests/__mocks__/@lodestar/types.d.ts → programs/use-cases/report/write.d.ts} +0 -0
  508. /package/dist/{tests/utils/fetchCL.test.d.ts → programs/use-cases/vault-operations/create-vault.d.ts} +0 -0
  509. /package/dist/{tests/utils/report-proof.test.d.ts → programs/use-cases/vault-operations/read.d.ts} +0 -0
@@ -0,0 +1,58 @@
1
+ import { numberPrompt, selectPrompt } from '../../utils/index.js';
2
+ const MIN_CONFIRM_EXPIRY = 24 * 60 * 60;
3
+ const MAX_CONFIRM_EXPIRY = 24 * 60 * 60 * 30;
4
+ const validateConfirmExpiry = (confirmExpiry) => {
5
+ const minInHours = MIN_CONFIRM_EXPIRY / 3600;
6
+ const maxInHours = MAX_CONFIRM_EXPIRY / 3600;
7
+ if (confirmExpiry < minInHours)
8
+ throw new Error(`Confirm expiry must be greater than ${minInHours} hours. Current value: ${confirmExpiry} hours (${confirmExpiry * 3600} seconds)`);
9
+ if (confirmExpiry > maxInHours)
10
+ throw new Error(`Confirm expiry must be less than ${maxInHours} hours. Current value: ${confirmExpiry} hours (${confirmExpiry * 3600} seconds)`);
11
+ if (confirmExpiry % 1 !== 0)
12
+ throw new Error('Confirm expiry must be a multiple of hours');
13
+ };
14
+ const validateNodeOperatorFeeRate = (nodeOperatorFeeRate, type) => {
15
+ if (nodeOperatorFeeRate < 0)
16
+ throw new Error('Node operator fee rate must be greater than 0');
17
+ if (type === 'basis points' && nodeOperatorFeeRate > 10000)
18
+ throw new Error(`Node operator fee rate must be less than 10000. Current value: ${nodeOperatorFeeRate}`);
19
+ if (type === 'percentage' && nodeOperatorFeeRate > 100)
20
+ throw new Error(`Node operator fee rate must be less than 100. Current value: ${nodeOperatorFeeRate}`);
21
+ if (type === 'basis points' && nodeOperatorFeeRate % 100 !== 0)
22
+ throw new Error(`Node operator fee rate must be a multiple of 100. Current value: ${nodeOperatorFeeRate}`);
23
+ if (type === 'percentage' && nodeOperatorFeeRate % 1 !== 0)
24
+ throw new Error(`Node operator fee rate must be a whole number. Current value: ${nodeOperatorFeeRate}`);
25
+ };
26
+ export const getConfirmExpiry = async (confirmExpiry) => {
27
+ if (!confirmExpiry) {
28
+ const confirmExpiryValue = await numberPrompt('Enter the confirm expiry (in hours)', 'value');
29
+ if (!confirmExpiryValue.value)
30
+ throw new Error('Invalid confirm expiry');
31
+ validateConfirmExpiry(confirmExpiryValue.value);
32
+ return confirmExpiryValue.value * 3600;
33
+ }
34
+ validateConfirmExpiry(confirmExpiry / 3600);
35
+ return confirmExpiry;
36
+ };
37
+ export const getNodeOperatorFeeRate = async (nodeOperatorFeeRate) => {
38
+ if (!nodeOperatorFeeRate) {
39
+ const chooseFeeType = await selectPrompt('Choose the fee type', 'feeType', [
40
+ { title: 'basis points', value: 'basis points' },
41
+ { title: 'percentage', value: 'percentage' },
42
+ ]);
43
+ if (!chooseFeeType.feeType)
44
+ throw new Error('Invalid fee type');
45
+ const nodeOperatorFeeRateValue = await numberPrompt(`Enter the node operator fee rate (in ${chooseFeeType.feeType})`, 'value');
46
+ if (!nodeOperatorFeeRateValue.value)
47
+ throw new Error('Invalid node operator fee rate');
48
+ if (chooseFeeType.feeType === 'basis points') {
49
+ validateNodeOperatorFeeRate(nodeOperatorFeeRateValue.value, 'basis points');
50
+ return nodeOperatorFeeRateValue.value;
51
+ }
52
+ validateNodeOperatorFeeRate(nodeOperatorFeeRateValue.value, 'percentage');
53
+ return nodeOperatorFeeRateValue.value * 100;
54
+ }
55
+ validateNodeOperatorFeeRate(nodeOperatorFeeRate, 'basis points');
56
+ return nodeOperatorFeeRate;
57
+ };
58
+ //# sourceMappingURL=create-vault.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/create-vault.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { Address } from 'viem';
2
+ import { DashboardContract } from '../../contracts/index.js';
3
+ export declare const getDashboardByVault: (vault: Address) => Promise<`0x${string}`>;
4
+ export declare const chooseVaultAndGetDashboard: (args: {
5
+ vault?: Address;
6
+ isNotMember?: boolean;
7
+ }) => Promise<{
8
+ address: Address;
9
+ contract: DashboardContract;
10
+ vault: Address;
11
+ }>;
@@ -0,0 +1,34 @@
1
+ import { getDashboardContract, getVaultHubContract, } from '../../contracts/index.js';
2
+ import { getPublicClient } from '../../providers/index.js';
3
+ import { callReadMethodSilent, enterContractAddress } from '../../utils/index.js';
4
+ import { chooseVault } from './vaults-by-role.js';
5
+ export const getDashboardByVault = async (vault) => {
6
+ const vaultHub = await getVaultHubContract();
7
+ const vaultConnection = await callReadMethodSilent(vaultHub, 'vaultConnection', [vault]);
8
+ const vaultOwner = vaultConnection.owner;
9
+ const dashboard = getDashboardContract(vaultOwner);
10
+ const publicClient = getPublicClient();
11
+ const bytecode = await publicClient.getCode({ address: vaultOwner });
12
+ if (!bytecode || bytecode === '0x') {
13
+ throw new Error(`Owner ${vaultOwner} is not a contract (probably EOA)`);
14
+ }
15
+ return dashboard.address;
16
+ };
17
+ export const chooseVaultAndGetDashboard = async (args) => {
18
+ const { vault, isNotMember = false } = args;
19
+ let chosenVault;
20
+ if (isNotMember) {
21
+ chosenVault = vault ?? (await enterContractAddress('stVault'));
22
+ }
23
+ else {
24
+ chosenVault = vault ?? (await chooseVault());
25
+ }
26
+ const dashboard = await getDashboardByVault(chosenVault);
27
+ const dashboardContract = getDashboardContract(dashboard);
28
+ return {
29
+ address: dashboard,
30
+ contract: dashboardContract,
31
+ vault: chosenVault,
32
+ };
33
+ };
34
+ //# sourceMappingURL=dashboard-by-vault.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dashboard-by-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/dashboard-by-vault.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAEnE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EAAE,KAAc,EAAE,EAAE;IAC1D,MAAM,QAAQ,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC7C,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAChD,QAAQ,EACR,iBAAiB,EACjB,CAAC,KAAK,CAAC,CACR,CAAC;IAEF,MAAM,UAAU,GAAG,eAAe,CAAC,KAAK,CAAC;IACzC,MAAM,SAAS,GAAG,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAC;IAErE,IAAI,CAAC,QAAQ,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,SAAS,UAAU,mCAAmC,CAAC,CAAC;IAC1E,CAAC;IAED,OAAO,SAAS,CAAC,OAAO,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,EAAE,IAGhD,EAIE,EAAE;IACH,MAAM,EAAE,KAAK,EAAE,WAAW,GAAG,KAAK,EAAE,GAAG,IAAI,CAAC;IAC5C,IAAI,WAAoB,CAAC;IAEzB,IAAI,WAAW,EAAE,CAAC;QAChB,WAAW,GAAG,KAAK,IAAI,CAAC,MAAM,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC;IACjE,CAAC;SAAM,CAAC;QACN,WAAW,GAAG,KAAK,IAAI,CAAC,MAAM,WAAW,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,SAAS,GAAG,MAAM,mBAAmB,CAAC,WAAW,CAAC,CAAC;IACzD,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAE1D,OAAO;QACL,OAAO,EAAE,SAAS;QAClB,QAAQ,EAAE,iBAAiB;QAC3B,KAAK,EAAE,WAAW;KACnB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ export * from './vault-health.js';
2
+ export * from './vaults-by-role.js';
3
+ export * from './dashboard-by-vault.js';
4
+ export * from './vault-info.js';
5
+ export * from './vault-overview.js';
6
+ export * from './vault-roles.js';
7
+ export * from './create-vault.js';
@@ -0,0 +1,8 @@
1
+ export * from './vault-health.js';
2
+ export * from './vaults-by-role.js';
3
+ export * from './dashboard-by-vault.js';
4
+ export * from './vault-info.js';
5
+ export * from './vault-overview.js';
6
+ export * from './vault-roles.js';
7
+ export * from './create-vault.js';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../features/vault-operations/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { DashboardContract } from '../../contracts/index.js';
2
+ export declare const getVaultHealthByDashboard: (contract: DashboardContract) => Promise<void>;
@@ -0,0 +1,24 @@
1
+ import { logTable, logInfo, logResult, formatBP, fetchAndCalculateVaultHealth, } from '../../utils/index.js';
2
+ export const getVaultHealthByDashboard = async (contract) => {
3
+ try {
4
+ const { healthRatio, isHealthy, totalValueInEth, liabilitySharesInSteth, forceRebalanceThresholdBP, liabilityShares, } = await fetchAndCalculateVaultHealth(contract);
5
+ logResult({});
6
+ logInfo('Vault Health');
7
+ logTable({
8
+ data: [
9
+ ['Vault Healthy', isHealthy],
10
+ ['Health Rate', `${healthRatio}%`],
11
+ ['Total Value, ETH', totalValueInEth],
12
+ ['Liability Shares', liabilityShares],
13
+ ['Liability Shares in stETH', liabilitySharesInSteth],
14
+ ['Rebalance Threshold, %', formatBP(forceRebalanceThresholdBP)],
15
+ ],
16
+ });
17
+ }
18
+ catch (err) {
19
+ if (err instanceof Error) {
20
+ logInfo('Error when getting info:\n', err.message);
21
+ }
22
+ }
23
+ };
24
+ //# sourceMappingURL=vault-health.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vault-health.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-health.ts"],"names":[],"mappings":"AACA,OAAO,EACL,QAAQ,EACR,OAAO,EACP,SAAS,EACT,QAAQ,EACR,4BAA4B,GAC7B,MAAM,OAAO,CAAC;AAEf,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,EAC5C,QAA2B,EAC3B,EAAE;IACF,IAAI,CAAC;QACH,MAAM,EACJ,WAAW,EACX,SAAS,EACT,eAAe,EACf,sBAAsB,EACtB,yBAAyB,EACzB,eAAe,GAChB,GAAG,MAAM,4BAA4B,CAAC,QAAQ,CAAC,CAAC;QAEjD,SAAS,CAAC,EAAE,CAAC,CAAC;QACd,OAAO,CAAC,cAAc,CAAC,CAAC;QACxB,QAAQ,CAAC;YACP,IAAI,EAAE;gBACJ,CAAC,eAAe,EAAE,SAAS,CAAC;gBAC5B,CAAC,aAAa,EAAE,GAAG,WAAW,GAAG,CAAC;gBAClC,CAAC,kBAAkB,EAAE,eAAe,CAAC;gBACrC,CAAC,kBAAkB,EAAE,eAAe,CAAC;gBACrC,CAAC,2BAA2B,EAAE,sBAAsB,CAAC;gBACrD,CAAC,wBAAwB,EAAE,QAAQ,CAAC,yBAAyB,CAAC,CAAC;aAChE;SACF,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAI,GAAG,YAAY,KAAK,EAAE,CAAC;YACzB,OAAO,CAAC,4BAA4B,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;QACrD,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { DashboardContract } from '../../contracts/index.js';
2
+ export declare const getVaultInfoByDashboard: (contract: DashboardContract) => Promise<void>;
@@ -0,0 +1,107 @@
1
+ import { formatEther } from 'viem';
2
+ import { formatBP, logInfo, logTable, logResult, showSpinner, printError, } from '../../utils/index.js';
3
+ import { getPublicClient } from '../../providers/index.js';
4
+ export const getVaultInfoByDashboard = async (contract) => {
5
+ const hideSpinner = showSpinner();
6
+ const publicClient = getPublicClient();
7
+ try {
8
+ const [steth, wsteth, eth, lidoLocator, vaultHub, vault, reserveRatioBP, forcedRebalanceThresholdBP, infraFeeBP, liquidityFeeBP, reservationFeeBP, shareLimit, liabilityShares, unsettledObligations, totalValue, locked, maxLockableValue, totalMintingCapacityShares, remainingMintingCapacityShares, withdrawableValue, nodeOperatorFeeRecipient, rewardsAdjustment, nodeOperatorDisbursableFee, nodeOperatorFeeRate, confirmExpiry, maxConfirmExpiry, minConfirmExpiry,] = await Promise.all([
9
+ contract.read.STETH(),
10
+ contract.read.WSTETH(),
11
+ contract.read.ETH(),
12
+ contract.read.LIDO_LOCATOR(),
13
+ contract.read.VAULT_HUB(),
14
+ contract.read.stakingVault(),
15
+ contract.read.reserveRatioBP(),
16
+ contract.read.forcedRebalanceThresholdBP(),
17
+ contract.read.infraFeeBP(),
18
+ contract.read.liquidityFeeBP(),
19
+ contract.read.reservationFeeBP(),
20
+ contract.read.shareLimit(),
21
+ contract.read.liabilityShares(),
22
+ contract.read.unsettledObligations(),
23
+ contract.read.totalValue(),
24
+ contract.read.locked(),
25
+ contract.read.maxLockableValue(),
26
+ contract.read.totalMintingCapacityShares(),
27
+ contract.read.remainingMintingCapacityShares([0n]),
28
+ contract.read.withdrawableValue(),
29
+ contract.read.nodeOperatorFeeRecipient(),
30
+ contract.read.rewardsAdjustment(),
31
+ contract.read.nodeOperatorDisbursableFee(),
32
+ contract.read.nodeOperatorFeeRate(),
33
+ contract.read.getConfirmExpiry(),
34
+ contract.read.MAX_CONFIRM_EXPIRY(),
35
+ contract.read.MIN_CONFIRM_EXPIRY(),
36
+ ]);
37
+ const balance = await publicClient.getBalance({
38
+ address: vault,
39
+ });
40
+ hideSpinner();
41
+ logResult({});
42
+ logInfo('Dashboard Base Info');
43
+ logTable({
44
+ data: [
45
+ ['Vault address', vault],
46
+ ['Dashboard address', contract.address],
47
+ ['Vault Hub address', vaultHub],
48
+ ['LIDO Locator address', lidoLocator],
49
+ ['stETH address', steth],
50
+ ['wstETH address', wsteth],
51
+ ['ETH address', eth],
52
+ ['Reserve Ratio, BP', reserveRatioBP],
53
+ ['Reserve Ratio, %', formatBP(reserveRatioBP)],
54
+ ['Forced Rebalance Threshold, BP', forcedRebalanceThresholdBP],
55
+ ['Forced Rebalance Threshold, %', formatBP(forcedRebalanceThresholdBP)],
56
+ ['Infra Fee, BP', infraFeeBP],
57
+ ['Infra Fee, %', formatBP(infraFeeBP)],
58
+ ['Liquidity Fee, BP', liquidityFeeBP],
59
+ ['Liquidity Fee, %', formatBP(liquidityFeeBP)],
60
+ ['Reservation Fee, BP', reservationFeeBP],
61
+ ['Reservation Fee, %', formatBP(reservationFeeBP)],
62
+ ['Share Limit, Shares', shareLimit],
63
+ ['Liability Shares, Shares', formatEther(liabilityShares)],
64
+ ['Unsettled Obligations, ETH', formatEther(unsettledObligations)],
65
+ ['Total Value, ETH', formatEther(totalValue)],
66
+ ['Locked, ETH', formatEther(locked)],
67
+ ['Max Lockable Value, ETH', formatEther(maxLockableValue)],
68
+ ['Balance, ETH', formatEther(balance)],
69
+ [
70
+ 'Total Minting Capacity, Shares',
71
+ formatEther(totalMintingCapacityShares),
72
+ ],
73
+ [
74
+ 'Remaining Minting Capacity, Shares',
75
+ formatEther(remainingMintingCapacityShares),
76
+ ],
77
+ ['Withdrawable Value, ETH', formatEther(withdrawableValue)],
78
+ ['Node Operator Fee Recipient', nodeOperatorFeeRecipient],
79
+ ['Node Operator Fee Rate, BP', nodeOperatorFeeRate],
80
+ ['Node Operator Fee Rate, %', formatBP(nodeOperatorFeeRate)],
81
+ [
82
+ 'Node Operator Disbursable Fee, ETH',
83
+ formatEther(nodeOperatorDisbursableFee),
84
+ ],
85
+ ['Rewards Adjustment amount, ETH', formatEther(rewardsAdjustment[0])],
86
+ ['Rewards Adjustment latestTimestamp', rewardsAdjustment[1]],
87
+ [
88
+ 'Confirm Expiry',
89
+ `${confirmExpiry} (${Number(confirmExpiry) / 3600} hours)`,
90
+ ],
91
+ [
92
+ 'Max Confirm Expiry',
93
+ `${maxConfirmExpiry} (${Number(maxConfirmExpiry) / 3600} hours)`,
94
+ ],
95
+ [
96
+ 'Min Confirm Expiry',
97
+ `${minConfirmExpiry} (${Number(minConfirmExpiry) / 3600} hours)`,
98
+ ],
99
+ ],
100
+ });
101
+ }
102
+ catch (err) {
103
+ hideSpinner();
104
+ printError(err, 'Error when getting base info');
105
+ }
106
+ };
107
+ //# sourceMappingURL=vault-info.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vault-info.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-info.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { DashboardContract } from '../../contracts/index.js';
2
+ export declare const getVaultOverviewByDashboard: (contract: DashboardContract) => Promise<void>;
@@ -0,0 +1,139 @@
1
+ import { formatEther } from 'viem';
2
+ import { getOperatorGridContract, getStethContract, getVaultHubContract, } from '../../contracts/index.js';
3
+ import { getPublicClient } from '../../providers/index.js';
4
+ import { fetchAndCalculateVaultHealth, formatBP, formatRatio, showSpinner, logInfo, logTable, logResult, logLiabilityBar, logVaultHealthBar, printError, calculateOverviewV2, callReadMethodSilent, } from '../../utils/index.js';
5
+ export const getVaultOverviewByDashboard = async (contract) => {
6
+ const hideSpinner = showSpinner();
7
+ const publicClient = getPublicClient();
8
+ try {
9
+ const health = await fetchAndCalculateVaultHealth(contract);
10
+ const operatorGridContract = await getOperatorGridContract();
11
+ const [vault, nodeOperatorFeeRate, reserveRatioBP, totalMintingCapacityShares, withdrawableValue, nodeOperatorDisbursableFee, totalValue, locked, shareLimit, remainingMintingCapacityShares,] = await Promise.all([
12
+ contract.read.stakingVault(),
13
+ contract.read.nodeOperatorFeeRate(),
14
+ contract.read.reserveRatioBP(),
15
+ contract.read.totalMintingCapacityShares(),
16
+ contract.read.withdrawableValue(),
17
+ contract.read.nodeOperatorDisbursableFee(),
18
+ contract.read.totalValue(),
19
+ contract.read.locked(),
20
+ contract.read.shareLimit(),
21
+ contract.read.remainingMintingCapacityShares([0n]),
22
+ ]);
23
+ const stethContract = await getStethContract();
24
+ const vaultHubContract = await getVaultHubContract();
25
+ const balance = await publicClient.getBalance({
26
+ address: vault,
27
+ });
28
+ const vaultObligation = await callReadMethodSilent(vaultHubContract, 'vaultObligations', [vault]);
29
+ const tierInfo = await callReadMethodSilent(operatorGridContract, 'vaultInfo', [vault]);
30
+ const isNoHaveGroup = tierInfo[0] === '0xFFfFfFffFFfffFFfFFfFFFFFffFFFffffFfFFFfF';
31
+ const nodeOperatorGroup = await callReadMethodSilent(operatorGridContract, 'group', [tierInfo[0]]);
32
+ const [totalMintingCapacityStethWei, shareLimitStethWei, tierShareLimitStethWei, groupShareLimitStethWei, remainingMintingCapacityStethWei,] = await Promise.all([
33
+ stethContract.read.getPooledEthBySharesRoundUp([
34
+ totalMintingCapacityShares,
35
+ ]),
36
+ stethContract.read.getPooledEthBySharesRoundUp([shareLimit]),
37
+ stethContract.read.getPooledEthBySharesRoundUp([tierInfo[2]]),
38
+ stethContract.read.getPooledEthBySharesRoundUp([
39
+ nodeOperatorGroup.shareLimit,
40
+ ]),
41
+ stethContract.read.getPooledEthBySharesRoundUp([
42
+ remainingMintingCapacityShares,
43
+ ]),
44
+ ]);
45
+ const overview = calculateOverviewV2({
46
+ totalValue,
47
+ reserveRatioBP,
48
+ liabilitySharesInStethWei: health.liabilitySharesInStethWei,
49
+ forceRebalanceThresholdBP: health.forceRebalanceThresholdBP,
50
+ withdrawableEther: withdrawableValue,
51
+ balance,
52
+ locked,
53
+ nodeOperatorDisbursableFee,
54
+ totalMintingCapacityStethWei,
55
+ unsettledLidoFees: vaultObligation.unsettledLidoFees,
56
+ });
57
+ hideSpinner();
58
+ logResult({});
59
+ logInfo('Overview');
60
+ logTable({
61
+ data: [
62
+ ['Health Factor', formatRatio(overview.healthRatio)],
63
+ ['Reserve Ratio, %', formatBP(reserveRatioBP)],
64
+ [
65
+ 'Force Rebalance Threshold',
66
+ formatBP(health.forceRebalanceThresholdBP),
67
+ ],
68
+ ['stVault Share Limit, stETH', formatEther(shareLimitStethWei)],
69
+ ['stVault Share Limit, Shares', formatEther(shareLimit)],
70
+ ['Node Operator Fee Rate, %', formatBP(nodeOperatorFeeRate)],
71
+ ['Utilization Ratio, %', formatRatio(overview.utilizationRatio)],
72
+ ['Total Value, ETH', formatEther(totalValue)],
73
+ ['Liability, stETH', formatEther(health.liabilitySharesInStethWei)],
74
+ ['Liability, Shares', formatEther(health.liabilitySharesInWei)],
75
+ [
76
+ 'Available To Withdrawal, ETH',
77
+ formatEther(overview.availableToWithdrawal),
78
+ ],
79
+ ['Idle Capital, ETH', formatEther(overview.idleCapital)],
80
+ ['Locked, ETH', formatEther(locked)],
81
+ ['Total Locked, ETH', formatEther(overview.totalLocked)],
82
+ ['Collateral, ETH', formatEther(overview.collateral)],
83
+ ['Recently Repaid, ETH', formatEther(overview.recentlyRepaid)],
84
+ [
85
+ 'Node Operator Disbursable Fee, ETH',
86
+ formatEther(nodeOperatorDisbursableFee),
87
+ ],
88
+ ['Reserved, ETH', formatEther(overview.reserved)],
89
+ [
90
+ 'Total Minting Capacity, stETH',
91
+ formatEther(overview.totalMintingCapacityStethWei),
92
+ ],
93
+ [
94
+ 'Remaining Minting Capacity, stETH',
95
+ formatEther(remainingMintingCapacityStethWei),
96
+ ],
97
+ [
98
+ 'Remaining Minting Capacity, Shares',
99
+ formatEther(remainingMintingCapacityShares),
100
+ ],
101
+ [
102
+ 'Unsettled Lido Fees, ETH',
103
+ formatEther(vaultObligation.unsettledLidoFees),
104
+ ],
105
+ [
106
+ 'Settled Lido Fees, ETH',
107
+ formatEther(vaultObligation.settledLidoFees),
108
+ ],
109
+ ['Redemptions, ETH', formatEther(vaultObligation.redemptions)],
110
+ ['Tier ID', tierInfo[1]],
111
+ ['Tier Share Limit, stETH', formatEther(tierShareLimitStethWei)],
112
+ ['Tier Share Limit, Shares', formatEther(tierInfo[2])],
113
+ [
114
+ 'Group Share Limit, stETH',
115
+ isNoHaveGroup ? 'N/A' : formatEther(groupShareLimitStethWei),
116
+ ],
117
+ [
118
+ 'Group Share Limit, Shares',
119
+ isNoHaveGroup ? 'N/A' : formatEther(nodeOperatorGroup.shareLimit),
120
+ ],
121
+ ],
122
+ });
123
+ logLiabilityBar({
124
+ totalValue: totalValue,
125
+ stETHLiability: health.liabilitySharesInStethWei,
126
+ reserveRatioBP: reserveRatioBP,
127
+ forceRebalanceThresholdBP: health.forceRebalanceThresholdBP,
128
+ stETHTotalMintingCapacity: totalMintingCapacityStethWei,
129
+ });
130
+ console.info('\n');
131
+ logVaultHealthBar(overview.healthRatio);
132
+ console.info('\n');
133
+ }
134
+ catch (err) {
135
+ // hideSpinner();
136
+ printError(err, 'Error when getting overview');
137
+ }
138
+ };
139
+ //# sourceMappingURL=vault-overview.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vault-overview.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-overview.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { Address } from 'viem';
2
+ import { DashboardContract } from '../../contracts/index.js';
3
+ type RoleName = 'DEFAULT_ADMIN_ROLE' | 'CHANGE_TIER_ROLE' | 'BURN_ROLE' | 'FUND_ROLE' | 'MINT_ROLE' | 'WITHDRAW_ROLE' | 'NODE_OPERATOR_MANAGER_ROLE' | 'NODE_OPERATOR_REWARDS_ADJUST_ROLE' | 'PAUSE_BEACON_CHAIN_DEPOSITS_ROLE' | 'RESUME_BEACON_CHAIN_DEPOSITS_ROLE' | 'PDG_COMPENSATE_PREDEPOSIT_ROLE' | 'PDG_PROVE_VALIDATOR_ROLE' | 'REBALANCE_ROLE' | 'RECOVER_ASSETS_ROLE' | 'REQUEST_VALIDATOR_EXIT_ROLE' | 'TRIGGER_VALIDATOR_WITHDRAWAL_ROLE' | 'UNGUARANTEED_BEACON_CHAIN_DEPOSIT_ROLE' | 'VOLUNTARY_DISCONNECT_ROLE';
4
+ export declare const getVaultRolesByDashboard: (contract: DashboardContract) => Promise<void>;
5
+ export declare const checkVaultRole: (contract: DashboardContract, roleName: RoleName, address: Address) => Promise<true>;
6
+ export {};
@@ -0,0 +1,62 @@
1
+ import { printError, showSpinner, logResult, logInfo, callReadMethodSilent, } from '../../utils/index.js';
2
+ export const getVaultRolesByDashboard = async (contract) => {
3
+ const hideSpinner = showSpinner();
4
+ try {
5
+ const roleKeys = [
6
+ 'DEFAULT_ADMIN_ROLE',
7
+ 'CHANGE_TIER_ROLE',
8
+ 'BURN_ROLE',
9
+ 'FUND_ROLE',
10
+ 'MINT_ROLE',
11
+ 'WITHDRAW_ROLE',
12
+ 'NODE_OPERATOR_MANAGER_ROLE',
13
+ 'NODE_OPERATOR_REWARDS_ADJUST_ROLE',
14
+ 'PAUSE_BEACON_CHAIN_DEPOSITS_ROLE',
15
+ 'RESUME_BEACON_CHAIN_DEPOSITS_ROLE',
16
+ 'PDG_COMPENSATE_PREDEPOSIT_ROLE',
17
+ 'PDG_PROVE_VALIDATOR_ROLE',
18
+ 'REBALANCE_ROLE',
19
+ 'RECOVER_ASSETS_ROLE',
20
+ 'REQUEST_VALIDATOR_EXIT_ROLE',
21
+ 'TRIGGER_VALIDATOR_WITHDRAWAL_ROLE',
22
+ 'UNGUARANTEED_BEACON_CHAIN_DEPOSIT_ROLE',
23
+ 'VOLUNTARY_DISCONNECT_ROLE',
24
+ ];
25
+ const roleValues = await Promise.all(roleKeys.map((key) => contract.read[key]()));
26
+ const roles = Object.fromEntries(roleKeys.map((key, index) => [key, roleValues[index]]));
27
+ const result = await Promise.all(roleKeys.map(async (key) => {
28
+ const accounts = await contract.read.getRoleMembers([roles[key]]);
29
+ return {
30
+ Role: key,
31
+ Keccak: roles[key],
32
+ Members: accounts.length > 0 ? accounts.join(', ') : 'None',
33
+ };
34
+ }));
35
+ hideSpinner();
36
+ logInfo('Dashboard Roles');
37
+ logResult({
38
+ data: result.map(({ Role, Keccak, Members }) => [Role, Keccak, Members]),
39
+ params: {
40
+ head: ['Role', 'Keccak', 'Members'],
41
+ },
42
+ });
43
+ }
44
+ catch (err) {
45
+ hideSpinner();
46
+ printError(err, 'Error when getting roles');
47
+ }
48
+ };
49
+ export const checkVaultRole = async (contract, roleName, address) => {
50
+ const ownerRole = await callReadMethodSilent(contract, 'DEFAULT_ADMIN_ROLE');
51
+ const ownerMembers = await contract.read.getRoleMembers([ownerRole]);
52
+ if (ownerMembers.includes(address))
53
+ return true;
54
+ const roleKeccak = await callReadMethodSilent(contract, roleName);
55
+ const roleMembers = await contract.read.getRoleMembers([roleKeccak]);
56
+ const hasRole = roleMembers.includes(address);
57
+ if (!hasRole) {
58
+ throw new Error(`Address ${address} does not have the ${roleName} role`);
59
+ }
60
+ return hasRole;
61
+ };
62
+ //# sourceMappingURL=vault-roles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vault-roles.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-roles.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export declare const getVaultsByOwner: () => Promise<readonly `0x${string}`[]>;
2
+ export declare const getVaultsByNO: () => Promise<`0x${string}`[]>;
3
+ export declare const chooseVault: () => Promise<any>;
@@ -0,0 +1,45 @@
1
+ import { getStakingVaultContract, getVaultViewerContract } from '../../contracts/index.js';
2
+ import { callReadMethodSilent, selectPrompt } from '../../utils/index.js';
3
+ import { getAccount } from '../../providers/index.js';
4
+ export const getVaultsByOwner = async () => {
5
+ const contract = getVaultViewerContract();
6
+ const account = getAccount();
7
+ const vaults = await callReadMethodSilent(contract, 'vaultsByOwner', [
8
+ account.address,
9
+ ]);
10
+ return vaults;
11
+ };
12
+ export const getVaultsByNO = async () => {
13
+ const account = getAccount();
14
+ const contract = getVaultViewerContract();
15
+ const vaults = await callReadMethodSilent(contract, 'vaultsConnected');
16
+ const nodeOperators = await Promise.all(vaults.map(async (vault) => {
17
+ const vaultContract = getStakingVaultContract(vault);
18
+ const nodeOperator = await callReadMethodSilent(vaultContract, 'nodeOperator');
19
+ return { vault, nodeOperator };
20
+ }));
21
+ const vaultsByNO = nodeOperators.filter(({ nodeOperator }) => nodeOperator === account.address);
22
+ return vaultsByNO.map(({ vault }) => vault);
23
+ };
24
+ export const chooseVault = async () => {
25
+ const [vaultsByOwner, vaultsByNO] = await Promise.all([
26
+ getVaultsByOwner(),
27
+ getVaultsByNO(),
28
+ ]);
29
+ const vaultsWithRole = [...vaultsByOwner, ...vaultsByNO].map((vault) => {
30
+ let title = vault;
31
+ const value = vault;
32
+ if (vaultsByNO.includes(vault)) {
33
+ title = `${vault} (Node Operator)`;
34
+ }
35
+ if (vaultsByOwner.includes(vault)) {
36
+ title = `${vault} (Owner)`;
37
+ }
38
+ return { title, value };
39
+ });
40
+ const vault = await selectPrompt('Choose a vault', 'address', vaultsWithRole);
41
+ if (!vault.address)
42
+ throw new Error('No vault selected');
43
+ return vault.address;
44
+ };
45
+ //# sourceMappingURL=vaults-by-role.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vaults-by-role.js","sourceRoot":"","sources":["../../../features/vault-operations/vaults-by-role.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,IAAI,EAAE;IACzC,MAAM,QAAQ,GAAG,sBAAsB,EAAE,CAAC;IAC1C,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAE7B,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,eAAe,EAAE;QACnE,OAAO,CAAC,OAAO;KAChB,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,IAAI,EAAE;IACtC,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,MAAM,QAAQ,GAAG,sBAAsB,EAAE,CAAC;IAC1C,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,iBAAiB,CAAC,CAAC;IAEvE,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,GAAG,CACrC,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QACzB,MAAM,aAAa,GAAG,uBAAuB,CAAC,KAAK,CAAC,CAAC;QACrD,MAAM,YAAY,GAAG,MAAM,oBAAoB,CAC7C,aAAa,EACb,cAAc,CACf,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;IACjC,CAAC,CAAC,CACH,CAAC;IAEF,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CACrC,CAAC,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC,YAAY,KAAK,OAAO,CAAC,OAAO,CACvD,CAAC;IAEF,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;AAC9C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,IAAI,EAAE;IACpC,MAAM,CAAC,aAAa,EAAE,UAAU,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACpD,gBAAgB,EAAE;QAClB,aAAa,EAAE;KAChB,CAAC,CAAC;IAEH,MAAM,cAAc,GAAG,CAAC,GAAG,aAAa,EAAE,GAAG,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACrE,IAAI,KAAK,GAAG,KAAK,CAAC;QAClB,MAAM,KAAK,GAAG,KAAK,CAAC;QAEpB,IAAI,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/B,KAAK,GAAG,GAAG,KAAK,kBAAkB,CAAC;QACrC,CAAC;QAED,IAAI,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;YAClC,KAAK,GAAG,GAAG,KAAK,UAAU,CAAC;QAC7B,CAAC;QAED,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;IAC1B,CAAC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,MAAM,YAAY,CAAC,gBAAgB,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;IAE9E,IAAI,CAAC,KAAK,CAAC,OAAO;QAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;IAEzD,OAAO,KAAK,CAAC,OAAO,CAAC;AACvB,CAAC,CAAC"}
@@ -8,41 +8,33 @@ export const getVaultBaseInfo = async (address) => {
8
8
  const hideSpinner = showSpinner();
9
9
  try {
10
10
  const DEPOSIT_CONTRACT = await contract.read.DEPOSIT_CONTRACT();
11
- const PUBLIC_KEY_LENGTH = await contract.read.PUBLIC_KEY_LENGTH();
12
11
  const beaconChainDepositsPaused = await contract.read.beaconChainDepositsPaused();
13
12
  const depositor = await contract.read.depositor();
14
13
  const initializedVersion = await contract.read.getInitializedVersion();
15
14
  const owner = await contract.read.owner();
15
+ const pendingOwner = await contract.read.pendingOwner();
16
16
  const version = await contract.read.version();
17
- const vaultHubAuthorized = await contract.read.vaultHubAuthorized();
18
- const vaultHub = await contract.read.vaultHub();
19
- const totalValue = await contract.read.totalValue();
20
- const inOutDelta = await contract.read.inOutDelta();
21
17
  const balance = await publicClient.getBalance({ address });
22
18
  const nodeOperator = await contract.read.nodeOperator();
23
- const locked = await contract.read.locked();
24
- const unlocked = await contract.read.unlocked();
19
+ const withdrawalCredentials = await contract.read.withdrawalCredentials();
20
+ const isOssified = await contract.read.isOssified();
25
21
  const isOwnerContract = await isContractAddress(owner);
26
22
  const CONTRACT_ADDRESS = address;
27
23
  hideSpinner();
28
24
  const payload = {
29
25
  DEPOSIT_CONTRACT,
30
- PUBLIC_KEY_LENGTH,
31
26
  CONTRACT_ADDRESS,
32
27
  owner,
28
+ pendingOwner,
33
29
  depositor,
34
30
  nodeOperator,
35
- vaultHub,
36
- vaultHubAuthorized,
37
31
  beaconChainDepositsPaused,
38
32
  initializedVersion,
39
33
  version,
40
- totalValue: `${formatEther(totalValue)} ETH`,
41
- inOutDelta: `${formatEther(inOutDelta)} ETH`,
42
34
  balance: `${formatEther(balance)} ETH`,
43
- locked: `${formatEther(locked)} ETH`,
44
- unlocked: `${formatEther(unlocked)} ETH`,
45
35
  isOwnerContract,
36
+ isOssified,
37
+ withdrawalCredentials,
46
38
  };
47
39
  logResult({
48
40
  data: Object.entries(payload).map(([key, value]) => [key, value]),