@lidofinance/lsv-cli 1.0.0-alpha.6 → 1.0.0-alpha.60
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.
- package/README.md +41 -20
- package/dist/abi/AccessControlConfirmable.d.ts +331 -0
- package/dist/abi/AccessControlConfirmable.js +430 -0
- package/dist/abi/AccessControlConfirmable.js.map +1 -0
- package/dist/abi/Dashboard.d.ts +2305 -0
- package/dist/abi/Dashboard.js +2105 -0
- package/dist/abi/Dashboard.js.map +1 -0
- package/dist/abi/LazyOracle.d.ts +604 -0
- package/dist/abi/LazyOracle.js +782 -0
- package/dist/abi/LazyOracle.js.map +1 -0
- package/dist/abi/LidoLocator.d.ts +358 -0
- package/dist/abi/LidoLocator.js +462 -0
- package/dist/abi/LidoLocator.js.map +1 -0
- package/dist/abi/OperatorGrid.d.ts +1246 -0
- package/dist/abi/OperatorGrid.js +1368 -0
- package/dist/abi/OperatorGrid.js.map +1 -0
- package/dist/abi/PredepositGuarantee.d.ts +1697 -0
- package/dist/abi/PredepositGuarantee.js +2010 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -0
- package/dist/abi/StEth.d.ts +372 -0
- package/dist/abi/StEth.js +493 -0
- package/dist/abi/StEth.js.map +1 -0
- package/dist/abi/StakingVault.d.ts +757 -0
- package/dist/abi/StakingVault.js +790 -0
- package/dist/abi/StakingVault.js.map +1 -0
- package/dist/abi/TokenManager.d.ts +577 -0
- package/dist/abi/TokenManager.js +756 -0
- package/dist/abi/TokenManager.js.map +1 -0
- package/dist/abi/VaultFactory.d.ts +739 -0
- package/dist/abi/VaultFactory.js +269 -0
- package/dist/abi/VaultFactory.js.map +1 -0
- package/dist/abi/VaultHub.d.ts +2546 -0
- package/dist/abi/VaultHub.js +2276 -509
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +530 -0
- package/dist/abi/VaultViewer.js +695 -0
- package/dist/abi/VaultViewer.js.map +1 -0
- package/dist/abi/Voting.d.ts +676 -0
- package/dist/abi/Voting.js +884 -0
- package/dist/abi/Voting.js.map +1 -0
- package/dist/abi/WstEth.d.ts +362 -0
- package/dist/abi/WstEth.js +478 -0
- package/dist/abi/WstEth.js.map +1 -0
- package/dist/abi/index.d.ts +14 -0
- package/dist/abi/index.js +15 -0
- package/dist/abi/index.js.map +1 -0
- package/dist/command/index.d.ts +2 -0
- package/dist/command/index.js +7 -5
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +34 -0
- package/dist/configs/constants.js +3 -0
- package/dist/configs/constants.js.map +1 -0
- package/dist/configs/deployed.d.ts +17 -0
- package/dist/configs/deployed.js +87 -52
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/envs.d.ts +2 -0
- package/dist/configs/envs.js +13 -37
- package/dist/configs/envs.js.map +1 -1
- package/dist/configs/index.d.ts +3 -0
- package/dist/configs/index.js +3 -18
- package/dist/configs/index.js.map +1 -1
- package/dist/configs/utils.d.ts +4 -0
- package/dist/configs/utils.js +22 -0
- package/dist/configs/utils.js.map +1 -0
- package/dist/contracts/dashboard.d.ts +4 -0
- package/dist/contracts/dashboard.js +11 -0
- package/dist/contracts/dashboard.js.map +1 -0
- package/dist/contracts/index.d.ts +12 -0
- package/dist/contracts/index.js +12 -17
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/lazy-oracle.d.ts +3 -0
- package/dist/contracts/lazy-oracle.js +18 -0
- package/dist/contracts/lazy-oracle.js.map +1 -0
- package/dist/contracts/locator.d.ts +8239 -0
- package/dist/contracts/locator.js +16 -0
- package/dist/contracts/locator.js.map +1 -0
- package/dist/contracts/operator-grid.d.ts +4 -0
- package/dist/contracts/operator-grid.js +17 -0
- package/dist/contracts/operator-grid.js.map +1 -0
- package/dist/contracts/pdg.d.ts +4 -0
- package/dist/contracts/pdg.js +17 -0
- package/dist/contracts/pdg.js.map +1 -0
- package/dist/contracts/steth.d.ts +27706 -0
- package/dist/contracts/steth.js +18 -0
- package/dist/contracts/steth.js.map +1 -0
- package/dist/contracts/token-manager.d.ts +3 -0
- package/dist/contracts/token-manager.js +13 -0
- package/dist/contracts/token-manager.js.map +1 -0
- package/dist/contracts/vault-factory.d.ts +16404 -0
- package/dist/contracts/vault-factory.js +14 -0
- package/dist/contracts/vault-factory.js.map +1 -0
- package/dist/contracts/vault-hub.d.ts +3 -0
- package/dist/contracts/vault-hub.js +14 -16
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +9075 -0
- package/dist/contracts/vault-viewer.js +23 -0
- package/dist/contracts/vault-viewer.js.map +1 -0
- package/dist/contracts/vault.d.ts +4 -0
- package/dist/contracts/vault.js +11 -0
- package/dist/contracts/vault.js.map +1 -0
- package/dist/contracts/wsteth.d.ts +24690 -0
- package/dist/contracts/wsteth.js +18 -0
- package/dist/contracts/wsteth.js.map +1 -0
- package/dist/features/dashboard.d.ts +5 -0
- package/dist/features/dashboard.js +14 -0
- package/dist/features/dashboard.js.map +1 -0
- package/dist/features/deposits/check-bls-deposits.d.ts +3 -0
- package/dist/features/deposits/check-bls-deposits.js +15 -0
- package/dist/features/deposits/check-bls-deposits.js.map +1 -0
- package/dist/features/deposits/index.d.ts +3 -0
- package/dist/features/deposits/index.js +4 -0
- package/dist/features/deposits/index.js.map +1 -0
- package/dist/features/deposits/make-pdg-proof.d.ts +3 -0
- package/dist/features/deposits/make-pdg-proof.js +52 -0
- package/dist/features/deposits/make-pdg-proof.js.map +1 -0
- package/dist/features/deposits/no-pdg.d.ts +22 -0
- package/dist/features/deposits/no-pdg.js +103 -0
- package/dist/features/deposits/no-pdg.js.map +1 -0
- package/dist/features/index.d.ts +10 -0
- package/dist/features/index.js +11 -0
- package/dist/features/index.js.map +1 -0
- package/dist/features/mint-burn/allowance.d.ts +2 -0
- package/dist/features/mint-burn/allowance.js +49 -0
- package/dist/features/mint-burn/allowance.js.map +1 -0
- package/dist/features/mint-burn/burn-shares.d.ts +3 -0
- package/dist/features/mint-burn/burn-shares.js +33 -0
- package/dist/features/mint-burn/burn-shares.js.map +1 -0
- package/dist/features/mint-burn/burn-steth.d.ts +3 -0
- package/dist/features/mint-burn/burn-steth.js +35 -0
- package/dist/features/mint-burn/burn-steth.js.map +1 -0
- package/dist/features/mint-burn/index.d.ts +5 -0
- package/dist/features/mint-burn/index.js +6 -0
- package/dist/features/mint-burn/index.js.map +1 -0
- package/dist/features/mint-burn/mint-shares.d.ts +3 -0
- package/dist/features/mint-burn/mint-shares.js +37 -0
- package/dist/features/mint-burn/mint-shares.js.map +1 -0
- package/dist/features/mint-burn/mint-steth.d.ts +3 -0
- package/dist/features/mint-burn/mint-steth.js +39 -0
- package/dist/features/mint-burn/mint-steth.js.map +1 -0
- package/dist/features/operator-grid.d.ts +2 -0
- package/dist/features/operator-grid.js +64 -0
- package/dist/features/operator-grid.js.map +1 -0
- package/dist/features/pdg.d.ts +4 -0
- package/dist/features/pdg.js +114 -0
- package/dist/features/pdg.js.map +1 -0
- package/dist/features/token-manager.d.ts +1 -0
- package/dist/features/token-manager.js +7 -0
- package/dist/features/token-manager.js.map +1 -0
- package/dist/features/utils/get-address.d.ts +2 -0
- package/dist/features/utils/get-address.js +16 -0
- package/dist/features/utils/get-address.js.map +1 -0
- package/dist/features/utils/index.d.ts +5 -0
- package/dist/features/utils/index.js +6 -0
- package/dist/features/utils/index.js.map +1 -0
- package/dist/features/utils/liability-shares.d.ts +2 -0
- package/dist/features/utils/liability-shares.js +10 -0
- package/dist/features/utils/liability-shares.js.map +1 -0
- package/dist/features/utils/minting-capacity.d.ts +2 -0
- package/dist/features/utils/minting-capacity.js +11 -0
- package/dist/features/utils/minting-capacity.js.map +1 -0
- package/dist/features/utils/quarantine.d.ts +23 -0
- package/dist/features/utils/quarantine.js +47 -0
- package/dist/features/utils/quarantine.js.map +1 -0
- package/dist/features/utils/report-fresh.d.ts +3 -0
- package/dist/features/utils/report-fresh.js +36 -0
- package/dist/features/utils/report-fresh.js.map +1 -0
- package/dist/features/vault-factory.d.ts +29 -0
- package/dist/features/vault-factory.js +99 -0
- package/dist/features/vault-factory.js.map +1 -0
- package/dist/features/vault-hub.d.ts +2 -0
- package/dist/features/vault-hub.js +88 -0
- package/dist/features/vault-hub.js.map +1 -0
- package/dist/features/vault-operations/create-vault.d.ts +2 -0
- package/dist/features/vault-operations/create-vault.js +58 -0
- package/dist/features/vault-operations/create-vault.js.map +1 -0
- package/dist/features/vault-operations/dashboard-by-vault.d.ts +11 -0
- package/dist/features/vault-operations/dashboard-by-vault.js +34 -0
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -0
- package/dist/features/vault-operations/index.d.ts +7 -0
- package/dist/features/vault-operations/index.js +8 -0
- package/dist/features/vault-operations/index.js.map +1 -0
- package/dist/features/vault-operations/vault-health.d.ts +2 -0
- package/dist/features/vault-operations/vault-health.js +27 -0
- package/dist/features/vault-operations/vault-health.js.map +1 -0
- package/dist/features/vault-operations/vault-info.d.ts +2 -0
- package/dist/features/vault-operations/vault-info.js +109 -0
- package/dist/features/vault-operations/vault-info.js.map +1 -0
- package/dist/features/vault-operations/vault-overview.d.ts +2 -0
- package/dist/features/vault-operations/vault-overview.js +141 -0
- package/dist/features/vault-operations/vault-overview.js.map +1 -0
- package/dist/features/vault-operations/vault-roles.d.ts +5 -0
- package/dist/features/vault-operations/vault-roles.js +62 -0
- package/dist/features/vault-operations/vault-roles.js.map +1 -0
- package/dist/features/vault-operations/vaults-by-role.d.ts +3 -0
- package/dist/features/vault-operations/vaults-by-role.js +46 -0
- package/dist/features/vault-operations/vaults-by-role.js.map +1 -0
- package/dist/features/vault.d.ts +2 -0
- package/dist/features/vault.js +48 -0
- package/dist/features/vault.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +23 -5
- package/dist/index.js.map +1 -1
- package/dist/programs/account/index.d.ts +3 -0
- package/dist/programs/account/index.js +4 -0
- package/dist/programs/account/index.js.map +1 -0
- package/dist/programs/account/main.d.ts +1 -0
- package/dist/programs/account/main.js +5 -0
- package/dist/programs/account/main.js.map +1 -0
- package/dist/programs/account/read.d.ts +1 -0
- package/dist/programs/account/read.js +79 -0
- package/dist/programs/account/read.js.map +1 -0
- package/dist/programs/account/write.d.ts +1 -0
- package/dist/programs/account/write.js +65 -0
- package/dist/programs/account/write.js.map +1 -0
- package/dist/programs/config.d.ts +1 -0
- package/dist/programs/config.js +31 -0
- package/dist/programs/config.js.map +1 -0
- package/dist/programs/contracts/dashboard/config.d.ts +3 -0
- package/dist/programs/contracts/dashboard/config.js +115 -0
- package/dist/programs/contracts/dashboard/config.js.map +1 -0
- package/dist/programs/contracts/dashboard/index.d.ts +3 -0
- package/dist/programs/contracts/dashboard/index.js +4 -0
- package/dist/programs/contracts/dashboard/index.js.map +1 -0
- package/dist/programs/contracts/dashboard/main.d.ts +1 -0
- package/dist/programs/contracts/dashboard/main.js +5 -0
- package/dist/programs/contracts/dashboard/main.js.map +1 -0
- package/dist/programs/contracts/dashboard/read.d.ts +1 -0
- package/dist/programs/contracts/dashboard/read.js +98 -0
- package/dist/programs/contracts/dashboard/read.js.map +1 -0
- package/dist/programs/contracts/dashboard/write.d.ts +1 -0
- package/dist/programs/contracts/dashboard/write.js +621 -0
- package/dist/programs/contracts/dashboard/write.js.map +1 -0
- package/dist/programs/contracts/hub/config.d.ts +3 -0
- package/dist/programs/contracts/hub/config.js +165 -0
- package/dist/programs/contracts/hub/config.js.map +1 -0
- package/dist/programs/contracts/hub/index.d.ts +3 -0
- package/dist/programs/contracts/hub/index.js +4 -0
- package/dist/programs/contracts/hub/index.js.map +1 -0
- package/dist/programs/contracts/hub/main.d.ts +1 -0
- package/dist/programs/contracts/hub/main.js +5 -0
- package/dist/programs/contracts/hub/main.js.map +1 -0
- package/dist/programs/contracts/hub/read.d.ts +1 -0
- package/dist/programs/contracts/hub/read.js +54 -0
- package/dist/programs/contracts/hub/read.js.map +1 -0
- package/dist/programs/contracts/hub/write.d.ts +1 -0
- package/dist/programs/contracts/hub/write.js +425 -0
- package/dist/programs/contracts/hub/write.js.map +1 -0
- package/dist/programs/contracts/index.d.ts +8 -0
- package/dist/programs/contracts/index.js +9 -0
- package/dist/programs/contracts/index.js.map +1 -0
- package/dist/programs/contracts/main.d.ts +1 -0
- package/dist/programs/contracts/main.js +6 -0
- package/dist/programs/contracts/main.js.map +1 -0
- package/dist/programs/contracts/operator-grid/config.d.ts +3 -0
- package/dist/programs/contracts/operator-grid/config.js +87 -0
- package/dist/programs/contracts/operator-grid/config.js.map +1 -0
- package/dist/programs/contracts/operator-grid/index.d.ts +3 -0
- package/dist/programs/contracts/operator-grid/index.js +4 -0
- package/dist/programs/contracts/operator-grid/index.js.map +1 -0
- package/dist/programs/contracts/operator-grid/main.d.ts +1 -0
- package/dist/programs/contracts/operator-grid/main.js +5 -0
- package/dist/programs/contracts/operator-grid/main.js.map +1 -0
- package/dist/programs/contracts/operator-grid/read.d.ts +1 -0
- package/dist/programs/contracts/operator-grid/read.js +30 -0
- package/dist/programs/contracts/operator-grid/read.js.map +1 -0
- package/dist/programs/contracts/operator-grid/write.d.ts +1 -0
- package/dist/programs/contracts/operator-grid/write.js +119 -0
- package/dist/programs/contracts/operator-grid/write.js.map +1 -0
- package/dist/programs/contracts/pdg/config.d.ts +3 -0
- package/dist/programs/contracts/pdg/config.js +160 -0
- package/dist/programs/contracts/pdg/config.js.map +1 -0
- package/dist/programs/contracts/pdg/index.d.ts +3 -0
- package/dist/programs/contracts/pdg/index.js +4 -0
- package/dist/programs/contracts/pdg/index.js.map +1 -0
- package/dist/programs/contracts/pdg/main.d.ts +1 -0
- package/dist/programs/contracts/pdg/main.js +5 -0
- package/dist/programs/contracts/pdg/main.js.map +1 -0
- package/dist/programs/contracts/pdg/read.d.ts +1 -0
- package/dist/programs/contracts/pdg/read.js +38 -0
- package/dist/programs/contracts/pdg/read.js.map +1 -0
- package/dist/programs/contracts/pdg/write.d.ts +1 -0
- package/dist/programs/contracts/pdg/write.js +388 -0
- package/dist/programs/contracts/pdg/write.js.map +1 -0
- package/dist/programs/contracts/vault/config.d.ts +3 -0
- package/dist/programs/contracts/vault/config.js +42 -0
- package/dist/programs/contracts/vault/config.js.map +1 -0
- package/dist/programs/contracts/vault/index.d.ts +3 -0
- package/dist/programs/contracts/vault/index.js +4 -0
- package/dist/programs/contracts/vault/index.js.map +1 -0
- package/dist/programs/contracts/vault/main.d.ts +1 -0
- package/dist/programs/contracts/vault/main.js +3 -0
- package/dist/programs/contracts/vault/main.js.map +1 -0
- package/dist/programs/contracts/vault/read.d.ts +1 -0
- package/dist/programs/contracts/vault/read.js +25 -0
- package/dist/programs/contracts/vault/read.js.map +1 -0
- package/dist/programs/contracts/vault/write.d.ts +1 -0
- package/dist/programs/contracts/vault/write.js +214 -0
- package/dist/programs/contracts/vault/write.js.map +1 -0
- package/dist/programs/contracts/vault-factory/config.d.ts +3 -0
- package/dist/programs/contracts/vault-factory/config.js +2 -0
- package/dist/programs/contracts/vault-factory/config.js.map +1 -0
- package/dist/programs/contracts/vault-factory/index.d.ts +3 -0
- package/dist/programs/contracts/vault-factory/index.js +4 -0
- package/dist/programs/contracts/vault-factory/index.js.map +1 -0
- package/dist/programs/contracts/vault-factory/main.d.ts +1 -0
- package/dist/programs/contracts/vault-factory/main.js +5 -0
- package/dist/programs/contracts/vault-factory/main.js.map +1 -0
- package/dist/programs/contracts/vault-factory/read.d.ts +1 -0
- package/dist/programs/contracts/vault-factory/read.js +24 -0
- package/dist/programs/contracts/vault-factory/read.js.map +1 -0
- package/dist/programs/contracts/vault-factory/write.d.ts +1 -0
- package/dist/programs/contracts/vault-factory/write.js +126 -0
- package/dist/programs/contracts/vault-factory/write.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/config.d.ts +3 -0
- package/dist/programs/contracts/vault-viewer/config.js +120 -0
- package/dist/programs/contracts/vault-viewer/config.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/index.d.ts +2 -0
- package/dist/programs/contracts/vault-viewer/index.js +3 -0
- package/dist/programs/contracts/vault-viewer/index.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/main.d.ts +1 -0
- package/dist/programs/contracts/vault-viewer/main.js +5 -0
- package/dist/programs/contracts/vault-viewer/main.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/read.d.ts +1 -0
- package/dist/programs/contracts/vault-viewer/read.js +131 -0
- package/dist/programs/contracts/vault-viewer/read.js.map +1 -0
- package/dist/programs/index.d.ts +4 -0
- package/dist/programs/index.js +4 -17
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/pdg-helpers.d.ts +1 -0
- package/dist/programs/pdg-helpers.js +257 -0
- package/dist/programs/pdg-helpers.js.map +1 -0
- package/dist/programs/use-cases/deposits/index.d.ts +3 -0
- package/dist/programs/use-cases/deposits/index.js +4 -0
- package/dist/programs/use-cases/deposits/index.js.map +1 -0
- package/dist/programs/use-cases/deposits/main.d.ts +1 -0
- package/dist/programs/use-cases/deposits/main.js +6 -0
- package/dist/programs/use-cases/deposits/main.js.map +1 -0
- package/dist/programs/use-cases/deposits/read.d.ts +1 -0
- package/dist/programs/use-cases/deposits/read.js +77 -0
- package/dist/programs/use-cases/deposits/read.js.map +1 -0
- package/dist/programs/use-cases/deposits/write.d.ts +1 -0
- package/dist/programs/use-cases/deposits/write.js +212 -0
- package/dist/programs/use-cases/deposits/write.js.map +1 -0
- package/dist/programs/use-cases/index.d.ts +4 -0
- package/dist/programs/use-cases/index.js +5 -0
- package/dist/programs/use-cases/index.js.map +1 -0
- package/dist/programs/use-cases/metrics/index.d.ts +2 -0
- package/dist/programs/use-cases/metrics/index.js +3 -0
- package/dist/programs/use-cases/metrics/index.js.map +1 -0
- package/dist/programs/use-cases/metrics/main.d.ts +1 -0
- package/dist/programs/use-cases/metrics/main.js +6 -0
- package/dist/programs/use-cases/metrics/main.js.map +1 -0
- package/dist/programs/use-cases/metrics/read.d.ts +1 -0
- package/dist/programs/use-cases/metrics/read.js +181 -0
- package/dist/programs/use-cases/metrics/read.js.map +1 -0
- package/dist/programs/use-cases/report/index.d.ts +3 -0
- package/dist/programs/use-cases/report/index.js +4 -0
- package/dist/programs/use-cases/report/index.js.map +1 -0
- package/dist/programs/use-cases/report/main.d.ts +1 -0
- package/dist/programs/use-cases/report/main.js +6 -0
- package/dist/programs/use-cases/report/main.js.map +1 -0
- package/dist/programs/use-cases/report/read.d.ts +1 -0
- package/dist/programs/use-cases/report/read.js +104 -0
- package/dist/programs/use-cases/report/read.js.map +1 -0
- package/dist/programs/use-cases/report/write.d.ts +1 -0
- package/dist/programs/use-cases/report/write.js +116 -0
- package/dist/programs/use-cases/report/write.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/create-vault.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/create-vault.js +129 -0
- package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/index.d.ts +4 -0
- package/dist/programs/use-cases/vault-operations/index.js +5 -0
- package/dist/programs/use-cases/vault-operations/index.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/main.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/main.js +6 -0
- package/dist/programs/use-cases/vault-operations/main.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/read.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/read.js +58 -0
- package/dist/programs/use-cases/vault-operations/read.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/write.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/write.js +198 -0
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -0
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.js +1 -17
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/wallet.d.ts +6897 -0
- package/dist/providers/wallet.js +44 -28
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/utils/arguments.test.d.ts +1 -0
- package/dist/tests/utils/arguments.test.js +92 -0
- package/dist/tests/utils/arguments.test.js.map +1 -0
- package/dist/tests/utils/calculate-overview.test.d.ts +1 -0
- package/dist/tests/utils/calculate-overview.test.js +30 -0
- package/dist/tests/utils/calculate-overview.test.js.map +1 -0
- package/dist/tests/utils/data-validators.test.d.ts +1 -0
- package/dist/tests/utils/data-validators.test.js +56 -0
- package/dist/tests/utils/data-validators.test.js.map +1 -0
- package/dist/tests/utils/error-handler.test.d.ts +1 -0
- package/dist/tests/utils/error-handler.test.js +43 -0
- package/dist/tests/utils/error-handler.test.js.map +1 -0
- package/dist/tests/utils/get-commands.test.d.ts +1 -0
- package/dist/tests/utils/get-commands.test.js +19 -0
- package/dist/tests/utils/get-commands.test.js.map +1 -0
- package/dist/tests/utils/get-deposit-data-root.test.d.ts +1 -0
- package/dist/tests/utils/get-deposit-data-root.test.js +31 -0
- package/dist/tests/utils/get-deposit-data-root.test.js.map +1 -0
- package/dist/tests/utils/get-value.test.d.ts +1 -0
- package/dist/tests/utils/get-value.test.js +13 -0
- package/dist/tests/utils/get-value.test.js.map +1 -0
- package/dist/tests/utils/health.test.d.ts +1 -0
- package/dist/tests/utils/health.test.js +22 -0
- package/dist/tests/utils/health.test.js.map +1 -0
- package/dist/tests/utils/interrupt-handler.test.d.ts +1 -0
- package/dist/tests/utils/interrupt-handler.test.js +15 -0
- package/dist/tests/utils/interrupt-handler.test.js.map +1 -0
- package/dist/tests/utils/ipfs.test.d.ts +1 -0
- package/dist/tests/utils/ipfs.test.js +98 -0
- package/dist/tests/utils/ipfs.test.js.map +1 -0
- package/dist/tests/utils/logging.test.d.ts +1 -0
- package/dist/tests/utils/logging.test.js +23 -0
- package/dist/tests/utils/logging.test.js.map +1 -0
- package/dist/tests/utils/resove-path.test.d.ts +1 -0
- package/dist/tests/utils/resove-path.test.js +18 -0
- package/dist/tests/utils/resove-path.test.js.map +1 -0
- package/dist/tests/utils/sleep.test.d.ts +1 -0
- package/dist/tests/utils/sleep.test.js +14 -0
- package/dist/tests/utils/sleep.test.js.map +1 -0
- package/dist/types/common.d.ts +35 -0
- package/dist/types/common.js +2 -0
- package/dist/types/common.js.map +1 -0
- package/dist/types/config.d.ts +25 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/arguments.d.ts +15 -0
- package/dist/utils/arguments.js +73 -0
- package/dist/utils/arguments.js.map +1 -0
- package/dist/utils/bls.d.ts +21 -0
- package/dist/utils/bls.js +101 -0
- package/dist/utils/bls.js.map +1 -0
- package/dist/utils/cache.d.ts +18 -0
- package/dist/utils/cache.js +109 -0
- package/dist/utils/cache.js.map +1 -0
- package/dist/utils/calculate-overview-v2.d.ts +25 -0
- package/dist/utils/calculate-overview-v2.js +59 -0
- package/dist/utils/calculate-overview-v2.js.map +1 -0
- package/dist/utils/calculate-overview.d.ts +28 -0
- package/dist/utils/calculate-overview.js +57 -0
- package/dist/utils/calculate-overview.js.map +1 -0
- package/dist/utils/charts/blessed/charts-apr.d.ts +98 -0
- package/dist/utils/charts/blessed/charts-apr.js +121 -0
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -0
- package/dist/utils/charts/blessed/charts-rewards.d.ts +74 -0
- package/dist/utils/charts/blessed/charts-rewards.js +106 -0
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/constants.d.ts +22 -0
- package/dist/utils/charts/blessed/constants.js +23 -0
- package/dist/utils/charts/blessed/constants.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.d.ts +19 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js +35 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/carry-spread.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/carry-spread.js +34 -0
- package/dist/utils/charts/blessed/datasets/carry-spread.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.js +34 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.d.ts +24 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js +40 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/index.d.ts +9 -0
- package/dist/utils/charts/blessed/datasets/index.js +10 -0
- package/dist/utils/charts/blessed/datasets/index.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.d.ts +19 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.js +35 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.js +34 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.js +34 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.d.ts +24 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js +40 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +33 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +133 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/types.d.ts +4 -0
- package/dist/utils/charts/blessed/datasets/types.js +2 -0
- package/dist/utils/charts/blessed/datasets/types.js.map +1 -0
- package/dist/utils/charts/blessed/index.d.ts +3 -0
- package/dist/utils/charts/blessed/index.js +4 -0
- package/dist/utils/charts/blessed/index.js.map +1 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.d.ts +13 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.js +19 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.js.map +1 -0
- package/dist/utils/charts/blessed/utils.d.ts +61 -0
- package/dist/utils/charts/blessed/utils.js +79 -0
- package/dist/utils/charts/blessed/utils.js.map +1 -0
- package/dist/utils/charts/index.d.ts +3 -0
- package/dist/utils/charts/index.js +4 -0
- package/dist/utils/charts/index.js.map +1 -0
- package/dist/utils/charts/metrics.d.ts +16 -0
- package/dist/utils/charts/metrics.js +160 -0
- package/dist/utils/charts/metrics.js.map +1 -0
- package/dist/utils/charts/overview.d.ts +10 -0
- package/dist/utils/charts/overview.js +89 -0
- package/dist/utils/charts/overview.js.map +1 -0
- package/dist/utils/charts/simple/index.d.ts +1 -0
- package/dist/utils/charts/simple/index.js +2 -0
- package/dist/utils/charts/simple/index.js.map +1 -0
- package/dist/utils/charts/simple/simple-charts.d.ts +7 -0
- package/dist/utils/charts/simple/simple-charts.js +78 -0
- package/dist/utils/charts/simple/simple-charts.js.map +1 -0
- package/dist/utils/commands/confirmations.d.ts +35 -0
- package/dist/utils/commands/confirmations.js +118 -0
- package/dist/utils/commands/confirmations.js.map +1 -0
- package/dist/utils/commands/index.d.ts +2 -0
- package/dist/utils/commands/index.js +3 -0
- package/dist/utils/commands/index.js.map +1 -0
- package/dist/utils/commands/report.d.ts +7 -0
- package/dist/utils/commands/report.js +42 -0
- package/dist/utils/commands/report.js.map +1 -0
- package/dist/utils/consts.d.ts +3 -0
- package/dist/utils/consts.js +4 -0
- package/dist/utils/consts.js.map +1 -0
- package/dist/utils/contract.d.ts +59 -0
- package/dist/utils/contract.js +214 -0
- package/dist/utils/contract.js.map +1 -0
- package/dist/utils/data-validators.d.ts +6 -0
- package/dist/utils/data-validators.js +54 -0
- package/dist/utils/data-validators.js.map +1 -0
- package/dist/utils/error-handler.d.ts +1 -0
- package/dist/utils/error-handler.js +13 -0
- package/dist/utils/error-handler.js.map +1 -0
- package/dist/utils/fetchCL.d.ts +36 -0
- package/dist/utils/fetchCL.js +81 -0
- package/dist/utils/fetchCL.js.map +1 -0
- package/dist/utils/get-commands.d.ts +2 -0
- package/dist/utils/get-commands.js +11 -0
- package/dist/utils/get-commands.js.map +1 -0
- package/dist/utils/get-deposit-data-root.d.ts +7 -0
- package/dist/utils/get-deposit-data-root.js +37 -0
- package/dist/utils/get-deposit-data-root.js.map +1 -0
- package/dist/utils/get-value.d.ts +1 -0
- package/dist/utils/get-value.js +5 -11
- package/dist/utils/get-value.js.map +1 -1
- package/dist/utils/health/calculate-health.d.ts +10 -0
- package/dist/utils/health/calculate-health.js +22 -0
- package/dist/utils/health/calculate-health.js.map +1 -0
- package/dist/utils/health/health-utils.d.ts +27743 -0
- package/dist/utils/health/health-utils.js +74 -0
- package/dist/utils/health/health-utils.js.map +1 -0
- package/dist/utils/health/index.d.ts +2 -0
- package/dist/utils/health/index.js +3 -0
- package/dist/utils/health/index.js.map +1 -0
- package/dist/utils/index.d.ts +33 -0
- package/dist/utils/index.js +33 -17
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/interrupt-handler.d.ts +3 -0
- package/dist/utils/interrupt-handler.js +28 -0
- package/dist/utils/interrupt-handler.js.map +1 -0
- package/dist/utils/ipfs.d.ts +17 -0
- package/dist/utils/ipfs.js +100 -0
- package/dist/utils/ipfs.js.map +1 -0
- package/dist/utils/lido-apr.d.ts +2 -0
- package/dist/utils/lido-apr.js +8 -0
- package/dist/utils/lido-apr.js.map +1 -0
- package/dist/utils/logging/console.d.ts +15 -0
- package/dist/utils/logging/console.js +36 -0
- package/dist/utils/logging/console.js.map +1 -0
- package/dist/utils/logging/constants.d.ts +4 -0
- package/dist/utils/logging/constants.js +18 -0
- package/dist/utils/logging/constants.js.map +1 -0
- package/dist/utils/logging/index.d.ts +1 -0
- package/dist/utils/logging/index.js +2 -0
- package/dist/utils/logging/index.js.map +1 -0
- package/dist/utils/prompts/confirmations.d.ts +2 -0
- package/dist/utils/prompts/confirmations.js +18 -0
- package/dist/utils/prompts/confirmations.js.map +1 -0
- package/dist/utils/prompts/default.d.ts +6 -0
- package/dist/utils/prompts/default.js +27 -0
- package/dist/utils/prompts/default.js.map +1 -0
- package/dist/utils/prompts/index.d.ts +6 -0
- package/dist/utils/prompts/index.js +7 -0
- package/dist/utils/prompts/index.js.map +1 -0
- package/dist/utils/prompts/mint-burn/confirm-burn.d.ts +17 -0
- package/dist/utils/prompts/mint-burn/confirm-burn.js +23 -0
- package/dist/utils/prompts/mint-burn/confirm-burn.js.map +1 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.d.ts +18 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.js +23 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.js.map +1 -0
- package/dist/utils/prompts/mint-burn/constants.d.ts +2 -0
- package/dist/utils/prompts/mint-burn/constants.js +6 -0
- package/dist/utils/prompts/mint-burn/constants.js.map +1 -0
- package/dist/utils/prompts/mint-burn/index.d.ts +2 -0
- package/dist/utils/prompts/mint-burn/index.js +3 -0
- package/dist/utils/prompts/mint-burn/index.js.map +1 -0
- package/dist/utils/prompts/operations.d.ts +9 -0
- package/dist/utils/prompts/operations.js +52 -0
- package/dist/utils/prompts/operations.js.map +1 -0
- package/dist/utils/prompts/predeposit-guarantee.d.ts +3 -0
- package/dist/utils/prompts/predeposit-guarantee.js +23 -0
- package/dist/utils/prompts/predeposit-guarantee.js.map +1 -0
- package/dist/utils/prompts/vault.d.ts +2 -0
- package/dist/utils/prompts/vault.js +14 -0
- package/dist/utils/prompts/vault.js.map +1 -0
- package/dist/utils/proof/create-proof.d.ts +15 -0
- package/dist/utils/proof/create-proof.js +40 -0
- package/dist/utils/proof/create-proof.js.map +1 -0
- package/dist/utils/proof/first-validator-gindex.d.ts +1 -0
- package/dist/utils/proof/first-validator-gindex.js +32 -0
- package/dist/utils/proof/first-validator-gindex.js.map +1 -0
- package/dist/utils/proof/index.d.ts +3 -0
- package/dist/utils/proof/index.js +4 -0
- package/dist/utils/proof/index.js.map +1 -0
- package/dist/utils/proof/merkle-utils.d.ts +55 -0
- package/dist/utils/proof/merkle-utils.js +173 -0
- package/dist/utils/proof/merkle-utils.js.map +1 -0
- package/dist/utils/proof/proofs.d.ts +30 -0
- package/dist/utils/proof/proofs.js +52 -0
- package/dist/utils/proof/proofs.js.map +1 -0
- package/dist/utils/read-programs-by-abi.d.ts +27 -0
- package/dist/utils/read-programs-by-abi.js +92 -0
- package/dist/utils/read-programs-by-abi.js.map +1 -0
- package/dist/utils/rebase-rewards.d.ts +7 -0
- package/dist/utils/rebase-rewards.js +6 -0
- package/dist/utils/rebase-rewards.js.map +1 -0
- package/dist/utils/report/index.d.ts +4 -0
- package/dist/utils/report/index.js +5 -0
- package/dist/utils/report/index.js.map +1 -0
- package/dist/utils/report/report-proof.d.ts +36 -0
- package/dist/utils/report/report-proof.js +38 -0
- package/dist/utils/report/report-proof.js.map +1 -0
- package/dist/utils/report/report.d.ts +19 -0
- package/dist/utils/report/report.js +132 -0
- package/dist/utils/report/report.js.map +1 -0
- package/dist/utils/report/statistic-data.d.ts +32 -0
- package/dist/utils/report/statistic-data.js +28 -0
- package/dist/utils/report/statistic-data.js.map +1 -0
- package/dist/utils/report/types.d.ts +51 -0
- package/dist/utils/report/types.js +2 -0
- package/dist/utils/report/types.js.map +1 -0
- package/dist/utils/resolve-path.d.ts +1 -0
- package/dist/utils/resolve-path.js +10 -0
- package/dist/utils/resolve-path.js.map +1 -0
- package/dist/utils/share-rate.d.ts +1 -0
- package/dist/utils/share-rate.js +16 -0
- package/dist/utils/share-rate.js.map +1 -0
- package/dist/utils/sleep.d.ts +1 -0
- package/dist/utils/sleep.js +4 -0
- package/dist/utils/sleep.js.map +1 -0
- package/dist/utils/snake-to-camel.d.ts +6 -0
- package/dist/utils/snake-to-camel.js +9 -0
- package/dist/utils/snake-to-camel.js.map +1 -0
- package/dist/utils/spinner/constants.d.ts +6 -0
- package/dist/utils/spinner/constants.js +120 -0
- package/dist/utils/spinner/constants.js.map +1 -0
- package/dist/utils/spinner/index.d.ts +1 -0
- package/dist/utils/spinner/index.js +2 -0
- package/dist/utils/spinner/index.js.map +1 -0
- package/dist/utils/spinner/spinners.d.ts +7 -0
- package/dist/utils/spinner/spinners.js +16 -0
- package/dist/utils/spinner/spinners.js.map +1 -0
- package/dist/utils/statistic/index.d.ts +1 -0
- package/dist/utils/statistic/index.js +2 -0
- package/dist/utils/statistic/index.js.map +1 -0
- package/dist/utils/statistic/report-statistic.d.ts +51 -0
- package/dist/utils/statistic/report-statistic.js +125 -0
- package/dist/utils/statistic/report-statistic.js.map +1 -0
- package/dist/utils/timestamp.d.ts +1 -0
- package/dist/utils/timestamp.js +10 -0
- package/dist/utils/timestamp.js.map +1 -0
- package/dist/version/index.d.ts +1 -0
- package/dist/version/index.js +1 -0
- package/dist/version/index.js.map +1 -0
- package/package.json +77 -19
- package/dist/programs/vault-hub.js +0 -137
- package/dist/programs/vault-hub.js.map +0 -1
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { printError, showSpinner, logResult } from '../utils/index.js';
|
|
2
|
+
import { getVaultHubContract } from '../contracts/index.js';
|
|
3
|
+
import { formatEther } from 'viem';
|
|
4
|
+
export const getVaultHubBaseInfo = async () => {
|
|
5
|
+
const hideSpinner = showSpinner();
|
|
6
|
+
try {
|
|
7
|
+
const contract = await getVaultHubContract();
|
|
8
|
+
const CONNECT_DEPOSIT = await contract.read.CONNECT_DEPOSIT();
|
|
9
|
+
const DEFAULT_ADMIN_ROLE = await contract.read.DEFAULT_ADMIN_ROLE();
|
|
10
|
+
const LIDO = await contract.read.LIDO();
|
|
11
|
+
const LIDO_LOCATOR = await contract.read.LIDO_LOCATOR();
|
|
12
|
+
const PAUSE_INFINITELY = await contract.read.PAUSE_INFINITELY();
|
|
13
|
+
const PAUSE_ROLE = await contract.read.PAUSE_ROLE();
|
|
14
|
+
const REPORT_FRESHNESS_DELTA = await contract.read.REPORT_FRESHNESS_DELTA();
|
|
15
|
+
const RESUME_ROLE = await contract.read.RESUME_ROLE();
|
|
16
|
+
const VAULT_MASTER_ROLE = await contract.read.VAULT_MASTER_ROLE();
|
|
17
|
+
const VAULT_CODEHASH_SET_ROLE = await contract.read.VAULT_CODEHASH_SET_ROLE();
|
|
18
|
+
const MAX_RELATIVE_SHARE_LIMIT_BP = await contract.read.MAX_RELATIVE_SHARE_LIMIT_BP();
|
|
19
|
+
const resumeSinceTimestamp = await contract.read.getResumeSinceTimestamp();
|
|
20
|
+
const isPaused = await contract.read.isPaused();
|
|
21
|
+
const vaultsCount = await contract.read.vaultsCount();
|
|
22
|
+
const CONTRACT_ADDRESS = contract.address;
|
|
23
|
+
hideSpinner();
|
|
24
|
+
const payload = {
|
|
25
|
+
CONTRACT_ADDRESS,
|
|
26
|
+
DEFAULT_ADMIN_ROLE,
|
|
27
|
+
LIDO,
|
|
28
|
+
LIDO_LOCATOR,
|
|
29
|
+
PAUSE_INFINITELY,
|
|
30
|
+
PAUSE_ROLE,
|
|
31
|
+
RESUME_ROLE,
|
|
32
|
+
VAULT_MASTER_ROLE,
|
|
33
|
+
VAULT_CODEHASH_SET_ROLE,
|
|
34
|
+
MAX_RELATIVE_SHARE_LIMIT_BP,
|
|
35
|
+
CONNECT_DEPOSIT: `${formatEther(CONNECT_DEPOSIT)} ETH`,
|
|
36
|
+
REPORT_FRESHNESS_DELTA,
|
|
37
|
+
reportFreshnessDeltaHours: `${Number(REPORT_FRESHNESS_DELTA) / 60 / 60} hours`,
|
|
38
|
+
resumeSinceTimestamp,
|
|
39
|
+
isPaused,
|
|
40
|
+
vaultsCount,
|
|
41
|
+
};
|
|
42
|
+
logResult({
|
|
43
|
+
data: Object.entries(payload).map(([key, value]) => [key, value]),
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
catch (err) {
|
|
47
|
+
hideSpinner();
|
|
48
|
+
printError(err, 'Error when getting base info');
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
export const getVaultHubRoles = async () => {
|
|
52
|
+
const hideSpinner = showSpinner();
|
|
53
|
+
try {
|
|
54
|
+
const contract = await getVaultHubContract();
|
|
55
|
+
const DEFAULT_ADMIN_ROLE = await contract.read.DEFAULT_ADMIN_ROLE();
|
|
56
|
+
const PAUSE_ROLE = await contract.read.PAUSE_ROLE();
|
|
57
|
+
const RESUME_ROLE = await contract.read.RESUME_ROLE();
|
|
58
|
+
const VAULT_MASTER_ROLE = await contract.read.VAULT_MASTER_ROLE();
|
|
59
|
+
const VAULT_CODEHASH_SET_ROLE = await contract.read.VAULT_CODEHASH_SET_ROLE();
|
|
60
|
+
const roles = {
|
|
61
|
+
DEFAULT_ADMIN_ROLE,
|
|
62
|
+
PAUSE_ROLE,
|
|
63
|
+
RESUME_ROLE,
|
|
64
|
+
VAULT_MASTER_ROLE,
|
|
65
|
+
VAULT_CODEHASH_SET_ROLE,
|
|
66
|
+
};
|
|
67
|
+
const result = await Promise.all(Object.entries(roles).map(async ([key, value]) => {
|
|
68
|
+
const accounts = await contract.read.getRoleMembers([value]);
|
|
69
|
+
return {
|
|
70
|
+
Role: key,
|
|
71
|
+
Keccak: value,
|
|
72
|
+
Members: accounts.length > 0 ? accounts.join(', ') : 'None',
|
|
73
|
+
};
|
|
74
|
+
}));
|
|
75
|
+
hideSpinner();
|
|
76
|
+
logResult({
|
|
77
|
+
data: result.map(({ Role, Keccak, Members }) => [Role, Keccak, Members]),
|
|
78
|
+
params: {
|
|
79
|
+
head: ['Role', 'Keccak', 'Members'],
|
|
80
|
+
},
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
catch (err) {
|
|
84
|
+
hideSpinner();
|
|
85
|
+
printError(err, 'Error when getting roles');
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
//# sourceMappingURL=vault-hub.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vault-hub.js","sourceRoot":"","sources":["../../features/vault-hub.ts"],"names":[],"mappings":"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"}
|
|
@@ -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,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,27 @@
|
|
|
1
|
+
import { reportFreshWarning } from '../index.js';
|
|
2
|
+
import { logTable, logInfo, logResult, formatBP, fetchAndCalculateVaultHealth, callReadMethodSilent, } from '../../utils/index.js';
|
|
3
|
+
export const getVaultHealthByDashboard = async (contract) => {
|
|
4
|
+
try {
|
|
5
|
+
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
6
|
+
await reportFreshWarning(vault);
|
|
7
|
+
const { healthRatio, isHealthy, totalValueInEth, liabilitySharesInSteth, forceRebalanceThresholdBP, liabilityShares, } = await fetchAndCalculateVaultHealth(contract);
|
|
8
|
+
logResult({});
|
|
9
|
+
logInfo('Vault Health');
|
|
10
|
+
logTable({
|
|
11
|
+
data: [
|
|
12
|
+
['Vault Healthy', isHealthy],
|
|
13
|
+
['Health Rate', `${healthRatio}%`],
|
|
14
|
+
['Total Value, ETH', totalValueInEth],
|
|
15
|
+
['Liability Shares', liabilityShares],
|
|
16
|
+
['Liability Shares in stETH', liabilitySharesInSteth],
|
|
17
|
+
['Rebalance Threshold, %', formatBP(forceRebalanceThresholdBP)],
|
|
18
|
+
],
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
catch (err) {
|
|
22
|
+
if (err instanceof Error) {
|
|
23
|
+
logInfo('Error when getting info:\n', err.message);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
//# 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,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAC9C,OAAO,EACL,QAAQ,EACR,OAAO,EACP,SAAS,EACT,QAAQ,EACR,4BAA4B,EAC5B,oBAAoB,GACrB,MAAM,OAAO,CAAC;AAEf,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,EAC5C,QAA2B,EAC3B,EAAE;IACF,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;QACnE,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEhC,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,109 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
import { formatBP, logInfo, logTable, logResult, showSpinner, printError, callReadMethodSilent, } from '../../utils/index.js';
|
|
3
|
+
import { getPublicClient } from '../../providers/index.js';
|
|
4
|
+
import { reportFreshWarning } from '../index.js';
|
|
5
|
+
export const getVaultInfoByDashboard = async (contract) => {
|
|
6
|
+
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
7
|
+
await reportFreshWarning(vault);
|
|
8
|
+
const hideSpinner = showSpinner();
|
|
9
|
+
const publicClient = getPublicClient();
|
|
10
|
+
try {
|
|
11
|
+
const [steth, wsteth, eth, lidoLocator, vaultHub, reserveRatioBP, forcedRebalanceThresholdBP, infraFeeBP, liquidityFeeBP, reservationFeeBP, shareLimit, liabilityShares, unsettledObligations, totalValue, locked, maxLockableValue, totalMintingCapacityShares, remainingMintingCapacityShares, withdrawableValue, nodeOperatorFeeRecipient, rewardsAdjustment, nodeOperatorDisbursableFee, nodeOperatorFeeRate, confirmExpiry, maxConfirmExpiry, minConfirmExpiry,] = await Promise.all([
|
|
12
|
+
contract.read.STETH(),
|
|
13
|
+
contract.read.WSTETH(),
|
|
14
|
+
contract.read.ETH(),
|
|
15
|
+
contract.read.LIDO_LOCATOR(),
|
|
16
|
+
contract.read.VAULT_HUB(),
|
|
17
|
+
contract.read.reserveRatioBP(),
|
|
18
|
+
contract.read.forcedRebalanceThresholdBP(),
|
|
19
|
+
contract.read.infraFeeBP(),
|
|
20
|
+
contract.read.liquidityFeeBP(),
|
|
21
|
+
contract.read.reservationFeeBP(),
|
|
22
|
+
contract.read.shareLimit(),
|
|
23
|
+
contract.read.liabilityShares(),
|
|
24
|
+
contract.read.unsettledObligations(),
|
|
25
|
+
contract.read.totalValue(),
|
|
26
|
+
contract.read.locked(),
|
|
27
|
+
contract.read.maxLockableValue(),
|
|
28
|
+
contract.read.totalMintingCapacityShares(),
|
|
29
|
+
contract.read.remainingMintingCapacityShares([0n]),
|
|
30
|
+
contract.read.withdrawableValue(),
|
|
31
|
+
contract.read.nodeOperatorFeeRecipient(),
|
|
32
|
+
contract.read.rewardsAdjustment(),
|
|
33
|
+
contract.read.nodeOperatorDisbursableFee(),
|
|
34
|
+
contract.read.nodeOperatorFeeRate(),
|
|
35
|
+
contract.read.getConfirmExpiry(),
|
|
36
|
+
contract.read.MAX_CONFIRM_EXPIRY(),
|
|
37
|
+
contract.read.MIN_CONFIRM_EXPIRY(),
|
|
38
|
+
]);
|
|
39
|
+
const balance = await publicClient.getBalance({
|
|
40
|
+
address: vault,
|
|
41
|
+
});
|
|
42
|
+
hideSpinner();
|
|
43
|
+
logResult({});
|
|
44
|
+
logInfo('Dashboard Base Info');
|
|
45
|
+
logTable({
|
|
46
|
+
data: [
|
|
47
|
+
['Vault address', vault],
|
|
48
|
+
['Dashboard address', contract.address],
|
|
49
|
+
['Vault Hub address', vaultHub],
|
|
50
|
+
['LIDO Locator address', lidoLocator],
|
|
51
|
+
['stETH address', steth],
|
|
52
|
+
['wstETH address', wsteth],
|
|
53
|
+
['ETH address', eth],
|
|
54
|
+
['Reserve Ratio, BP', reserveRatioBP],
|
|
55
|
+
['Reserve Ratio, %', formatBP(reserveRatioBP)],
|
|
56
|
+
['Forced Rebalance Threshold, BP', forcedRebalanceThresholdBP],
|
|
57
|
+
['Forced Rebalance Threshold, %', formatBP(forcedRebalanceThresholdBP)],
|
|
58
|
+
['Infra Fee, BP', infraFeeBP],
|
|
59
|
+
['Infra Fee, %', formatBP(infraFeeBP)],
|
|
60
|
+
['Liquidity Fee, BP', liquidityFeeBP],
|
|
61
|
+
['Liquidity Fee, %', formatBP(liquidityFeeBP)],
|
|
62
|
+
['Reservation Fee, BP', reservationFeeBP],
|
|
63
|
+
['Reservation Fee, %', formatBP(reservationFeeBP)],
|
|
64
|
+
['Share Limit, Shares', shareLimit],
|
|
65
|
+
['Liability Shares, Shares', formatEther(liabilityShares)],
|
|
66
|
+
['Unsettled Obligations, ETH', formatEther(unsettledObligations)],
|
|
67
|
+
['Total Value, ETH', formatEther(totalValue)],
|
|
68
|
+
['Locked, ETH', formatEther(locked)],
|
|
69
|
+
['Max Lockable Value, ETH', formatEther(maxLockableValue)],
|
|
70
|
+
['Balance, ETH', formatEther(balance)],
|
|
71
|
+
[
|
|
72
|
+
'Total Minting Capacity, Shares',
|
|
73
|
+
formatEther(totalMintingCapacityShares),
|
|
74
|
+
],
|
|
75
|
+
[
|
|
76
|
+
'Remaining Minting Capacity, Shares',
|
|
77
|
+
formatEther(remainingMintingCapacityShares),
|
|
78
|
+
],
|
|
79
|
+
['Withdrawable Value, ETH', formatEther(withdrawableValue)],
|
|
80
|
+
['Node Operator Fee Recipient', nodeOperatorFeeRecipient],
|
|
81
|
+
['Node Operator Fee Rate, BP', nodeOperatorFeeRate],
|
|
82
|
+
['Node Operator Fee Rate, %', formatBP(nodeOperatorFeeRate)],
|
|
83
|
+
[
|
|
84
|
+
'Node Operator Disbursable Fee, ETH',
|
|
85
|
+
formatEther(nodeOperatorDisbursableFee),
|
|
86
|
+
],
|
|
87
|
+
['Rewards Adjustment amount, ETH', formatEther(rewardsAdjustment[0])],
|
|
88
|
+
['Rewards Adjustment latestTimestamp', rewardsAdjustment[1]],
|
|
89
|
+
[
|
|
90
|
+
'Confirm Expiry',
|
|
91
|
+
`${confirmExpiry} (${Number(confirmExpiry) / 3600} hours)`,
|
|
92
|
+
],
|
|
93
|
+
[
|
|
94
|
+
'Max Confirm Expiry',
|
|
95
|
+
`${maxConfirmExpiry} (${Number(maxConfirmExpiry) / 3600} hours)`,
|
|
96
|
+
],
|
|
97
|
+
[
|
|
98
|
+
'Min Confirm Expiry',
|
|
99
|
+
`${minConfirmExpiry} (${Number(minConfirmExpiry) / 3600} hours)`,
|
|
100
|
+
],
|
|
101
|
+
],
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
catch (err) {
|
|
105
|
+
hideSpinner();
|
|
106
|
+
printError(err, 'Error when getting base info');
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
//# 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,141 @@
|
|
|
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
|
+
import { reportFreshWarning } from '../index.js';
|
|
6
|
+
export const getVaultOverviewByDashboard = async (contract) => {
|
|
7
|
+
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
8
|
+
await reportFreshWarning(vault);
|
|
9
|
+
const hideSpinner = showSpinner();
|
|
10
|
+
const publicClient = getPublicClient();
|
|
11
|
+
try {
|
|
12
|
+
const health = await fetchAndCalculateVaultHealth(contract);
|
|
13
|
+
const operatorGridContract = await getOperatorGridContract();
|
|
14
|
+
const [nodeOperatorFeeRate, reserveRatioBP, totalMintingCapacityShares, withdrawableValue, nodeOperatorDisbursableFee, totalValue, locked, shareLimit, remainingMintingCapacityShares,] = await Promise.all([
|
|
15
|
+
contract.read.nodeOperatorFeeRate(),
|
|
16
|
+
contract.read.reserveRatioBP(),
|
|
17
|
+
contract.read.totalMintingCapacityShares(),
|
|
18
|
+
contract.read.withdrawableValue(),
|
|
19
|
+
contract.read.nodeOperatorDisbursableFee(),
|
|
20
|
+
contract.read.totalValue(),
|
|
21
|
+
contract.read.locked(),
|
|
22
|
+
contract.read.shareLimit(),
|
|
23
|
+
contract.read.remainingMintingCapacityShares([0n]),
|
|
24
|
+
]);
|
|
25
|
+
const stethContract = await getStethContract();
|
|
26
|
+
const vaultHubContract = await getVaultHubContract();
|
|
27
|
+
const balance = await publicClient.getBalance({
|
|
28
|
+
address: vault,
|
|
29
|
+
});
|
|
30
|
+
const vaultObligation = await callReadMethodSilent(vaultHubContract, 'vaultObligations', [vault]);
|
|
31
|
+
const tierInfo = await callReadMethodSilent(operatorGridContract, 'vaultInfo', [vault]);
|
|
32
|
+
const isNoHaveGroup = tierInfo[0] === '0xFFfFfFffFFfffFFfFFfFFFFFffFFFffffFfFFFfF';
|
|
33
|
+
const nodeOperatorGroup = await callReadMethodSilent(operatorGridContract, 'group', [tierInfo[0]]);
|
|
34
|
+
const [totalMintingCapacityStethWei, shareLimitStethWei, tierShareLimitStethWei, groupShareLimitStethWei, remainingMintingCapacityStethWei,] = await Promise.all([
|
|
35
|
+
stethContract.read.getPooledEthBySharesRoundUp([
|
|
36
|
+
totalMintingCapacityShares,
|
|
37
|
+
]),
|
|
38
|
+
stethContract.read.getPooledEthBySharesRoundUp([shareLimit]),
|
|
39
|
+
stethContract.read.getPooledEthBySharesRoundUp([tierInfo[2]]),
|
|
40
|
+
stethContract.read.getPooledEthBySharesRoundUp([
|
|
41
|
+
nodeOperatorGroup.shareLimit,
|
|
42
|
+
]),
|
|
43
|
+
stethContract.read.getPooledEthBySharesRoundUp([
|
|
44
|
+
remainingMintingCapacityShares,
|
|
45
|
+
]),
|
|
46
|
+
]);
|
|
47
|
+
const overview = calculateOverviewV2({
|
|
48
|
+
totalValue,
|
|
49
|
+
reserveRatioBP,
|
|
50
|
+
liabilitySharesInStethWei: health.liabilitySharesInStethWei,
|
|
51
|
+
forceRebalanceThresholdBP: health.forceRebalanceThresholdBP,
|
|
52
|
+
withdrawableEther: withdrawableValue,
|
|
53
|
+
balance,
|
|
54
|
+
locked,
|
|
55
|
+
nodeOperatorDisbursableFee,
|
|
56
|
+
totalMintingCapacityStethWei,
|
|
57
|
+
unsettledLidoFees: vaultObligation.unsettledLidoFees,
|
|
58
|
+
});
|
|
59
|
+
hideSpinner();
|
|
60
|
+
logResult({});
|
|
61
|
+
logInfo('Overview');
|
|
62
|
+
logTable({
|
|
63
|
+
data: [
|
|
64
|
+
['Health Factor', formatRatio(overview.healthRatio)],
|
|
65
|
+
['Reserve Ratio, %', formatBP(reserveRatioBP)],
|
|
66
|
+
[
|
|
67
|
+
'Force Rebalance Threshold',
|
|
68
|
+
formatBP(health.forceRebalanceThresholdBP),
|
|
69
|
+
],
|
|
70
|
+
['stVault Share Limit, stETH', formatEther(shareLimitStethWei)],
|
|
71
|
+
['stVault Share Limit, Shares', formatEther(shareLimit)],
|
|
72
|
+
['Node Operator Fee Rate, %', formatBP(nodeOperatorFeeRate)],
|
|
73
|
+
['Utilization Ratio, %', formatRatio(overview.utilizationRatio)],
|
|
74
|
+
['Total Value, ETH', formatEther(totalValue)],
|
|
75
|
+
['Liability, stETH', formatEther(health.liabilitySharesInStethWei)],
|
|
76
|
+
['Liability, Shares', formatEther(health.liabilitySharesInWei)],
|
|
77
|
+
[
|
|
78
|
+
'Available To Withdrawal, ETH',
|
|
79
|
+
formatEther(overview.availableToWithdrawal),
|
|
80
|
+
],
|
|
81
|
+
['Idle Capital, ETH', formatEther(overview.idleCapital)],
|
|
82
|
+
['Locked, ETH', formatEther(locked)],
|
|
83
|
+
['Total Locked, ETH', formatEther(overview.totalLocked)],
|
|
84
|
+
['Collateral, ETH', formatEther(overview.collateral)],
|
|
85
|
+
['Recently Repaid, ETH', formatEther(overview.recentlyRepaid)],
|
|
86
|
+
[
|
|
87
|
+
'Node Operator Disbursable Fee, ETH',
|
|
88
|
+
formatEther(nodeOperatorDisbursableFee),
|
|
89
|
+
],
|
|
90
|
+
['Reserved, ETH', formatEther(overview.reserved)],
|
|
91
|
+
[
|
|
92
|
+
'Total Minting Capacity, stETH',
|
|
93
|
+
formatEther(overview.totalMintingCapacityStethWei),
|
|
94
|
+
],
|
|
95
|
+
[
|
|
96
|
+
'Remaining Minting Capacity, stETH',
|
|
97
|
+
formatEther(remainingMintingCapacityStethWei),
|
|
98
|
+
],
|
|
99
|
+
[
|
|
100
|
+
'Remaining Minting Capacity, Shares',
|
|
101
|
+
formatEther(remainingMintingCapacityShares),
|
|
102
|
+
],
|
|
103
|
+
[
|
|
104
|
+
'Unsettled Lido Fees, ETH',
|
|
105
|
+
formatEther(vaultObligation.unsettledLidoFees),
|
|
106
|
+
],
|
|
107
|
+
[
|
|
108
|
+
'Settled Lido Fees, ETH',
|
|
109
|
+
formatEther(vaultObligation.settledLidoFees),
|
|
110
|
+
],
|
|
111
|
+
['Redemptions, ETH', formatEther(vaultObligation.redemptions)],
|
|
112
|
+
['Tier ID', tierInfo[1]],
|
|
113
|
+
['Tier Share Limit, stETH', formatEther(tierShareLimitStethWei)],
|
|
114
|
+
['Tier Share Limit, Shares', formatEther(tierInfo[2])],
|
|
115
|
+
[
|
|
116
|
+
'Group Share Limit, stETH',
|
|
117
|
+
isNoHaveGroup ? 'N/A' : formatEther(groupShareLimitStethWei),
|
|
118
|
+
],
|
|
119
|
+
[
|
|
120
|
+
'Group Share Limit, Shares',
|
|
121
|
+
isNoHaveGroup ? 'N/A' : formatEther(nodeOperatorGroup.shareLimit),
|
|
122
|
+
],
|
|
123
|
+
],
|
|
124
|
+
});
|
|
125
|
+
logLiabilityBar({
|
|
126
|
+
totalValue: totalValue,
|
|
127
|
+
stETHLiability: health.liabilitySharesInStethWei,
|
|
128
|
+
reserveRatioBP: reserveRatioBP,
|
|
129
|
+
forceRebalanceThresholdBP: health.forceRebalanceThresholdBP,
|
|
130
|
+
stETHTotalMintingCapacity: totalMintingCapacityStethWei,
|
|
131
|
+
});
|
|
132
|
+
console.info('\n');
|
|
133
|
+
logVaultHealthBar(overview.healthRatio);
|
|
134
|
+
console.info('\n');
|
|
135
|
+
}
|
|
136
|
+
catch (err) {
|
|
137
|
+
// hideSpinner();
|
|
138
|
+
printError(err, 'Error when getting overview');
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
//# 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,5 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
import { DashboardContract } from '../../contracts/index.js';
|
|
3
|
+
export 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>;
|
|
@@ -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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"}
|