@lidofinance/lsv-cli 1.0.0-alpha.62 → 1.0.0-alpha.63
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/LICENSE +1 -1
- package/dist/abi/AccessControlConfirmable.d.ts +4 -3
- package/dist/abi/AccessControlConfirmable.js +4 -2
- package/dist/abi/AccessControlConfirmable.js.map +1 -1
- package/dist/abi/Dashboard.d.ts +121 -88
- package/dist/abi/Dashboard.js +67 -78
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.d.ts +44 -3
- package/dist/abi/LazyOracle.js +57 -3
- package/dist/abi/LazyOracle.js.map +1 -1
- package/dist/abi/OperatorGrid.d.ts +615 -1
- package/dist/abi/OperatorGrid.js +50 -1
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/PredepositGuarantee.d.ts +33 -34
- package/dist/abi/PredepositGuarantee.js +6 -37
- package/dist/abi/PredepositGuarantee.js.map +1 -1
- package/dist/abi/StakingVault.d.ts +57 -9
- package/dist/abi/StakingVault.js +3 -6
- package/dist/abi/StakingVault.js.map +1 -1
- package/dist/abi/VaultFactory.d.ts +78 -24
- package/dist/abi/VaultFactory.js +19 -1
- package/dist/abi/VaultFactory.js.map +1 -1
- package/dist/abi/VaultHub.d.ts +38 -4
- package/dist/abi/VaultHub.js +13 -0
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +130 -196
- package/dist/abi/VaultViewer.js +169 -257
- package/dist/abi/VaultViewer.js.map +1 -1
- package/dist/abi/defi-wrapper/Distributor.d.ts +486 -0
- package/dist/abi/defi-wrapper/Distributor.js +633 -0
- package/dist/abi/defi-wrapper/Distributor.js.map +1 -0
- package/dist/abi/defi-wrapper/Factory.d.ts +1184 -0
- package/dist/abi/defi-wrapper/Factory.js +932 -0
- package/dist/abi/defi-wrapper/Factory.js.map +1 -0
- package/dist/abi/defi-wrapper/StvPool.d.ts +1079 -0
- package/dist/abi/defi-wrapper/StvPool.js +1410 -0
- package/dist/abi/defi-wrapper/StvPool.js.map +1 -0
- package/dist/abi/defi-wrapper/StvStETHPool.d.ts +1772 -0
- package/dist/abi/defi-wrapper/StvStETHPool.js +2316 -0
- package/dist/abi/defi-wrapper/StvStETHPool.js.map +1 -0
- package/dist/abi/defi-wrapper/WithdrawalQueue.d.ts +1265 -0
- package/dist/abi/defi-wrapper/WithdrawalQueue.js +1647 -0
- package/dist/abi/defi-wrapper/WithdrawalQueue.js.map +1 -0
- package/dist/abi/defi-wrapper/index.d.ts +5 -0
- package/dist/abi/defi-wrapper/index.js +6 -0
- package/dist/abi/defi-wrapper/index.js.map +1 -0
- package/dist/configs/constants.d.ts +44 -2
- package/dist/configs/constants.js +2 -2
- package/dist/configs/constants.js.map +1 -1
- package/dist/configs/deployed.d.ts +2 -2
- package/dist/configs/deployed.js +48 -6
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/utils.d.ts +1 -0
- package/dist/configs/utils.js +4 -0
- package/dist/configs/utils.js.map +1 -1
- package/dist/contracts/dashboard-impl.d.ts +4 -0
- package/dist/contracts/dashboard-impl.js +17 -0
- package/dist/contracts/dashboard-impl.js.map +1 -0
- package/dist/contracts/dashboard.d.ts +2 -2
- package/dist/contracts/dashboard.js +3 -2
- package/dist/contracts/dashboard.js.map +1 -1
- package/dist/contracts/defi-wrapper/distributor.d.ts +4 -0
- package/dist/contracts/defi-wrapper/distributor.js +12 -0
- package/dist/contracts/defi-wrapper/distributor.js.map +1 -0
- package/dist/contracts/defi-wrapper/factory.d.ts +4 -0
- package/dist/contracts/defi-wrapper/factory.js +12 -0
- package/dist/contracts/defi-wrapper/factory.js.map +1 -0
- package/dist/contracts/defi-wrapper/index.d.ts +5 -0
- package/dist/contracts/defi-wrapper/index.js +6 -0
- package/dist/contracts/defi-wrapper/index.js.map +1 -0
- package/dist/contracts/defi-wrapper/stv-pool.d.ts +4 -0
- package/dist/contracts/defi-wrapper/stv-pool.js +12 -0
- package/dist/contracts/defi-wrapper/stv-pool.js.map +1 -0
- package/dist/contracts/defi-wrapper/stv-steth-pool.d.ts +4 -0
- package/dist/contracts/defi-wrapper/stv-steth-pool.js +12 -0
- package/dist/contracts/defi-wrapper/stv-steth-pool.js.map +1 -0
- package/dist/contracts/defi-wrapper/withdrawal-queue.d.ts +4 -0
- package/dist/contracts/defi-wrapper/withdrawal-queue.js +12 -0
- package/dist/contracts/defi-wrapper/withdrawal-queue.js.map +1 -0
- package/dist/contracts/index.d.ts +1 -0
- package/dist/contracts/index.js +1 -0
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/lazy-oracle.js +3 -2
- package/dist/contracts/lazy-oracle.js.map +1 -1
- package/dist/contracts/locator.d.ts +3 -9655
- package/dist/contracts/locator.js +4 -3
- package/dist/contracts/locator.js.map +1 -1
- package/dist/contracts/operator-grid.d.ts +1 -1
- package/dist/contracts/operator-grid.js +3 -2
- package/dist/contracts/operator-grid.js.map +1 -1
- package/dist/contracts/pdg.js +3 -2
- package/dist/contracts/pdg.js.map +1 -1
- package/dist/contracts/steth.d.ts +54 -54
- package/dist/contracts/steth.js +3 -2
- package/dist/contracts/steth.js.map +1 -1
- package/dist/contracts/vault-factory.d.ts +3 -26297
- package/dist/contracts/vault-factory.js +4 -3
- package/dist/contracts/vault-factory.js.map +1 -1
- package/dist/contracts/vault-hub.js +3 -2
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +3 -11789
- package/dist/contracts/vault-viewer.js +9 -7
- package/dist/contracts/vault-viewer.js.map +1 -1
- package/dist/contracts/vault.d.ts +2 -2
- package/dist/contracts/vault.js +3 -2
- package/dist/contracts/vault.js.map +1 -1
- package/dist/contracts/wsteth.d.ts +3 -24690
- package/dist/contracts/wsteth.js +4 -3
- package/dist/contracts/wsteth.js.map +1 -1
- package/dist/features/defi-wrapper/create-vault.d.ts +17 -0
- package/dist/features/defi-wrapper/create-vault.js +137 -0
- package/dist/features/defi-wrapper/create-vault.js.map +1 -0
- package/dist/features/defi-wrapper/defi-wrapper-factory.d.ts +112 -0
- package/dist/features/defi-wrapper/defi-wrapper-factory.js +228 -0
- package/dist/features/defi-wrapper/defi-wrapper-factory.js.map +1 -0
- package/dist/features/defi-wrapper/index.d.ts +3 -0
- package/dist/features/defi-wrapper/index.js +4 -0
- package/dist/features/defi-wrapper/index.js.map +1 -0
- package/dist/features/defi-wrapper/pool-info.d.ts +35 -0
- package/dist/features/defi-wrapper/pool-info.js +97 -0
- package/dist/features/defi-wrapper/pool-info.js.map +1 -0
- package/dist/features/deposits/check-bls-deposits.d.ts +2 -1
- package/dist/features/deposits/check-bls-deposits.js +11 -2
- package/dist/features/deposits/check-bls-deposits.js.map +1 -1
- package/dist/features/deposits/make-pdg-proof.d.ts +8 -0
- package/dist/features/deposits/make-pdg-proof.js +17 -1
- package/dist/features/deposits/make-pdg-proof.js.map +1 -1
- package/dist/features/deposits/no-pdg.d.ts +1 -1
- package/dist/features/deposits/no-pdg.js +6 -3
- package/dist/features/deposits/no-pdg.js.map +1 -1
- package/dist/features/dev-tools/impersonate.d.ts +14 -0
- package/dist/features/dev-tools/impersonate.js +64 -0
- package/dist/features/dev-tools/impersonate.js.map +1 -0
- package/dist/features/dev-tools/index.d.ts +1 -0
- package/dist/features/dev-tools/index.js +2 -0
- package/dist/features/dev-tools/index.js.map +1 -0
- package/dist/features/index.d.ts +2 -0
- package/dist/features/index.js +2 -0
- package/dist/features/index.js.map +1 -1
- package/dist/features/mint-burn/allowance.js +1 -1
- package/dist/features/mint-burn/allowance.js.map +1 -1
- package/dist/features/pdg.d.ts +7 -0
- package/dist/features/pdg.js +5 -5
- package/dist/features/pdg.js.map +1 -1
- package/dist/features/utils/get-boolean.d.ts +1 -0
- package/dist/features/utils/get-boolean.js +13 -0
- package/dist/features/utils/get-boolean.js.map +1 -0
- package/dist/features/utils/index.d.ts +2 -0
- package/dist/features/utils/index.js +2 -0
- package/dist/features/utils/index.js.map +1 -1
- package/dist/features/utils/quarantine.d.ts +2 -0
- package/dist/features/utils/quarantine.js +2 -0
- package/dist/features/utils/quarantine.js.map +1 -1
- package/dist/features/utils/report-fresh.js +17 -1
- package/dist/features/utils/report-fresh.js.map +1 -1
- package/dist/features/utils/settled-growth.d.ts +1 -0
- package/dist/features/utils/settled-growth.js +16 -0
- package/dist/features/utils/settled-growth.js.map +1 -0
- package/dist/features/vault-factory.d.ts +2 -2
- package/dist/features/vault-factory.js +8 -3
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-operations/create-vault.d.ts +4 -2
- package/dist/features/vault-operations/create-vault.js +13 -5
- package/dist/features/vault-operations/create-vault.js.map +1 -1
- package/dist/features/vault-operations/dashboard-by-vault.js +4 -4
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -1
- package/dist/features/vault-operations/vault-info.js +5 -3
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +13 -13
- package/dist/features/vault-operations/vault-overview.js.map +1 -1
- package/dist/features/vault-operations/vault-roles.d.ts +2 -1
- package/dist/features/vault-operations/vault-roles.js +22 -23
- package/dist/features/vault-operations/vault-roles.js.map +1 -1
- package/dist/features/vault-operations/vaults-by-role.d.ts +5 -0
- package/dist/features/vault-operations/vaults-by-role.js +123 -36
- package/dist/features/vault-operations/vaults-by-role.js.map +1 -1
- package/dist/features/vault.js +4 -2
- package/dist/features/vault.js.map +1 -1
- package/dist/index.js +17 -10
- package/dist/index.js.map +1 -1
- package/dist/programs/account/read.js +1 -1
- package/dist/programs/account/read.js.map +1 -1
- package/dist/programs/account/write.js +14 -0
- package/dist/programs/account/write.js.map +1 -1
- package/dist/programs/contracts/dashboard/config.js +4 -4
- package/dist/programs/contracts/dashboard/config.js.map +1 -1
- package/dist/programs/contracts/dashboard/read.js +9 -9
- package/dist/programs/contracts/dashboard/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/write.js +118 -46
- package/dist/programs/contracts/dashboard/write.js.map +1 -1
- package/dist/programs/contracts/hub/config.js +0 -10
- package/dist/programs/contracts/hub/config.js.map +1 -1
- package/dist/programs/contracts/hub/read.js +63 -2
- package/dist/programs/contracts/hub/read.js.map +1 -1
- package/dist/programs/contracts/hub/write.js +1 -1
- package/dist/programs/contracts/hub/write.js.map +1 -1
- package/dist/programs/contracts/lazy-oracle/config.js +33 -0
- package/dist/programs/contracts/lazy-oracle/config.js.map +1 -1
- package/dist/programs/contracts/operator-grid/write.js +2 -75
- package/dist/programs/contracts/operator-grid/write.js.map +1 -1
- package/dist/programs/contracts/pdg/read.js +2 -5
- package/dist/programs/contracts/pdg/read.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +41 -9
- package/dist/programs/contracts/pdg/write.js.map +1 -1
- package/dist/programs/contracts/vault/write.js +34 -23
- package/dist/programs/contracts/vault/write.js.map +1 -1
- package/dist/programs/contracts/vault-factory/config.js +14 -1
- package/dist/programs/contracts/vault-factory/config.js.map +1 -1
- package/dist/programs/contracts/vault-factory/write.js +25 -15
- package/dist/programs/contracts/vault-factory/write.js.map +1 -1
- package/dist/programs/contracts/vault-viewer/config.js +102 -59
- package/dist/programs/contracts/vault-viewer/config.js.map +1 -1
- package/dist/programs/contracts/vault-viewer/read.js +22 -76
- package/dist/programs/contracts/vault-viewer/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/config.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/distributor/config.js +44 -0
- package/dist/programs/defi-wrapper/contracts/distributor/config.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/distributor/index.js +4 -0
- package/dist/programs/defi-wrapper/contracts/distributor/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/main.js +5 -0
- package/dist/programs/defi-wrapper/contracts/distributor/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/read.js +40 -0
- package/dist/programs/defi-wrapper/contracts/distributor/read.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/distributor/write.js +70 -0
- package/dist/programs/defi-wrapper/contracts/distributor/write.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/config.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/factory/config.js +2 -0
- package/dist/programs/defi-wrapper/contracts/factory/config.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/factory/index.js +4 -0
- package/dist/programs/defi-wrapper/contracts/factory/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/main.js +6 -0
- package/dist/programs/defi-wrapper/contracts/factory/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/read.js +50 -0
- package/dist/programs/defi-wrapper/contracts/factory/read.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/factory/write.js +144 -0
- package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/index.d.ts +6 -0
- package/dist/programs/defi-wrapper/contracts/index.js +7 -0
- package/dist/programs/defi-wrapper/contracts/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/main.js +6 -0
- package/dist/programs/defi-wrapper/contracts/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.js +73 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/index.js +4 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/main.js +6 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +70 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.js +138 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.js +120 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/index.js +4 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/main.js +6 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js +70 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js +173 -0
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js +66 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/index.js +4 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/main.js +6 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +65 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +171 -0
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js.map +1 -0
- package/dist/programs/defi-wrapper/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/index.js +4 -0
- package/dist/programs/defi-wrapper/index.js.map +1 -0
- package/dist/programs/defi-wrapper/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/main.js +6 -0
- package/dist/programs/defi-wrapper/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/health/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/health/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/health/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/read.js +338 -0
- package/dist/programs/defi-wrapper/use-cases/health/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/utils.d.ts +56 -0
- package/dist/programs/defi-wrapper/use-cases/health/utils.js +389 -0
- package/dist/programs/defi-wrapper/use-cases/health/utils.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/write.js +254 -0
- package/dist/programs/defi-wrapper/use-cases/health/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.js +143 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.js +5 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js +130 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js +13 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js.map +1 -0
- package/dist/programs/dev-tools/anvil/index.d.ts +2 -0
- package/dist/programs/dev-tools/anvil/index.js +3 -0
- package/dist/programs/dev-tools/anvil/index.js.map +1 -0
- package/dist/programs/dev-tools/anvil/main.d.ts +1 -0
- package/dist/programs/dev-tools/anvil/main.js +5 -0
- package/dist/programs/dev-tools/anvil/main.js.map +1 -0
- package/dist/programs/dev-tools/anvil/write.d.ts +1 -0
- package/dist/programs/dev-tools/anvil/write.js +122 -0
- package/dist/programs/dev-tools/anvil/write.js.map +1 -0
- package/dist/programs/dev-tools/defi-wrapper/index.d.ts +2 -0
- package/dist/programs/dev-tools/defi-wrapper/index.js +3 -0
- package/dist/programs/dev-tools/defi-wrapper/index.js.map +1 -0
- package/dist/programs/dev-tools/defi-wrapper/main.d.ts +1 -0
- package/dist/programs/dev-tools/defi-wrapper/main.js +6 -0
- package/dist/programs/dev-tools/defi-wrapper/main.js.map +1 -0
- package/dist/programs/dev-tools/defi-wrapper/write.d.ts +1 -0
- package/dist/programs/dev-tools/defi-wrapper/write.js +77 -0
- package/dist/programs/dev-tools/defi-wrapper/write.js.map +1 -0
- package/dist/programs/dev-tools/index.d.ts +3 -0
- package/dist/programs/dev-tools/index.js +4 -0
- package/dist/programs/dev-tools/index.js.map +1 -0
- package/dist/programs/dev-tools/main.d.ts +1 -0
- package/dist/programs/dev-tools/main.js +6 -0
- package/dist/programs/dev-tools/main.js.map +1 -0
- package/dist/programs/index.d.ts +2 -0
- package/dist/programs/index.js +2 -0
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/pdg-helpers.js +5 -5
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/use-cases/deposits/read.js +4 -4
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/write.js +111 -16
- package/dist/programs/use-cases/deposits/write.js.map +1 -1
- package/dist/programs/use-cases/metrics/read.js +29 -13
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/report/write.js +3 -0
- package/dist/programs/use-cases/report/write.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/create-vault.js +13 -7
- package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +5 -0
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/wallet.d.ts +6981 -166
- package/dist/providers/wallet.js +15 -5
- package/dist/providers/wallet.js.map +1 -1
- package/dist/utils/arguments.d.ts +5 -0
- package/dist/utils/arguments.js +24 -3
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/bls.d.ts +2 -2
- package/dist/utils/bls.js +8 -7
- package/dist/utils/bls.js.map +1 -1
- package/dist/utils/cache.d.ts +26 -0
- package/dist/utils/cache.js +88 -3
- package/dist/utils/cache.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +1 -1
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/simple/simple-charts.js +1 -1
- package/dist/utils/charts/simple/simple-charts.js.map +1 -1
- package/dist/utils/commands/confirmations.d.ts +1 -1
- package/dist/utils/commands/confirmations.js +5 -5
- package/dist/utils/commands/confirmations.js.map +1 -1
- package/dist/utils/fetchCL.d.ts +1 -5
- package/dist/utils/fetchCL.js +5 -7
- package/dist/utils/fetchCL.js.map +1 -1
- package/dist/utils/health/health-utils.d.ts +54 -54
- package/dist/utils/health/health-utils.js +1 -1
- package/dist/utils/health/health-utils.js.map +1 -1
- package/dist/utils/prompts/confirmations.js +1 -1
- package/dist/utils/prompts/confirmations.js.map +1 -1
- package/dist/utils/proof/constants.d.ts +6 -0
- package/dist/utils/proof/constants.js +7 -0
- package/dist/utils/proof/constants.js.map +1 -0
- package/dist/utils/proof/first-validator-gindex.js +0 -4
- package/dist/utils/proof/first-validator-gindex.js.map +1 -1
- package/dist/utils/proof/proofs.d.ts +7 -8
- package/dist/utils/proof/proofs.js +36 -28
- package/dist/utils/proof/proofs.js.map +1 -1
- package/dist/utils/read-programs-by-abi.d.ts +1 -1
- package/dist/utils/read-programs-by-abi.js +4 -18
- package/dist/utils/read-programs-by-abi.js.map +1 -1
- package/dist/utils/report/report.js +1 -1
- package/dist/utils/report/report.js.map +1 -1
- package/dist/utils/report/statistic-data.js +1 -1
- package/dist/utils/report/statistic-data.js.map +1 -1
- package/dist/utils/transactions/tx-private-key.d.ts +2 -2
- package/dist/utils/transactions/tx-private-key.js +6 -6
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +29 -1
- package/dist/utils/transactions/tx-wc.js +43 -26
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/wallet-connect.d.ts +4 -7664
- package/dist/utils/wallet-connect.js +17 -5
- package/dist/utils/wallet-connect.js.map +1 -1
- package/dist/version/index.js +1 -1
- package/package.json +5 -6
|
@@ -14,7 +14,7 @@ export declare const prepareCreateVaultPayload: (args: {
|
|
|
14
14
|
otherRoles: RoleAssignment[];
|
|
15
15
|
} | undefined;
|
|
16
16
|
export declare const createVault: (payload: VaultWithDashboard, otherRoles?: RoleAssignment[], methodName?: "createVaultWithDashboard" | "createVaultWithDashboardWithoutConnectingToVaultHub") => Promise<{
|
|
17
|
-
tx: `0x${string}
|
|
17
|
+
tx: `0x${string}` | undefined;
|
|
18
18
|
vault?: undefined;
|
|
19
19
|
dashboard?: undefined;
|
|
20
20
|
owner?: undefined;
|
|
@@ -23,7 +23,7 @@ export declare const createVault: (payload: VaultWithDashboard, otherRoles?: Rol
|
|
|
23
23
|
vault: `0x${string}` | undefined;
|
|
24
24
|
dashboard: `0x${string}` | undefined;
|
|
25
25
|
owner: `0x${string}` | undefined;
|
|
26
|
-
tx: `0x${string}
|
|
26
|
+
tx: `0x${string}` | undefined;
|
|
27
27
|
blockNumber: bigint;
|
|
28
28
|
} | undefined>;
|
|
29
29
|
export declare const getVaultFactoryInfo: () => Promise<void>;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { parseEventLogs, parseEther } from 'viem';
|
|
2
2
|
import { getVaultFactoryContract } from '../contracts/index.js';
|
|
3
3
|
import { VaultFactoryAbi } from '../abi/index.js';
|
|
4
|
-
import { callWriteMethodWithReceipt, logResult, printError, showSpinner, logError, transformAddressesToArray, validateAddressesMap, validateAddressMap, } from '../utils/index.js';
|
|
4
|
+
import { callWriteMethodWithReceipt, logResult, printError, showSpinner, logError, transformAddressesToArray, validateAddressesMap, validateAddressMap, logInfo, } from '../utils/index.js';
|
|
5
5
|
import { program } from '../command/index.js';
|
|
6
6
|
export const prepareCreateVaultPayload = (args) => {
|
|
7
7
|
const { defaultAdmin, nodeOperator, nodeOperatorManager, nodeOperatorFeeRate, confirmExpiry, quantity, roles, } = args;
|
|
@@ -37,7 +37,7 @@ export const prepareCreateVaultPayload = (args) => {
|
|
|
37
37
|
};
|
|
38
38
|
};
|
|
39
39
|
export const createVault = async (payload, otherRoles = [], methodName = 'createVaultWithDashboard') => {
|
|
40
|
-
const contract = getVaultFactoryContract();
|
|
40
|
+
const contract = await getVaultFactoryContract();
|
|
41
41
|
const { defaultAdmin, nodeOperator, nodeOperatorManager, nodeOperatorFeeRate, confirmExpiry, } = payload;
|
|
42
42
|
const isNeedValue = methodName === 'createVaultWithDashboard';
|
|
43
43
|
const result = await callWriteMethodWithReceipt({
|
|
@@ -59,6 +59,11 @@ export const createVault = async (payload, otherRoles = [], methodName = 'create
|
|
|
59
59
|
return { tx: result.tx };
|
|
60
60
|
}
|
|
61
61
|
const { receipt, tx } = result;
|
|
62
|
+
// Gnosis safe case
|
|
63
|
+
if (!receipt) {
|
|
64
|
+
logInfo('Transaction has been sent');
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
62
67
|
const events = parseEventLogs({
|
|
63
68
|
abi: VaultFactoryAbi,
|
|
64
69
|
logs: receipt.logs,
|
|
@@ -77,7 +82,7 @@ export const createVault = async (payload, otherRoles = [], methodName = 'create
|
|
|
77
82
|
};
|
|
78
83
|
};
|
|
79
84
|
export const getVaultFactoryInfo = async () => {
|
|
80
|
-
const contract = getVaultFactoryContract();
|
|
85
|
+
const contract = await getVaultFactoryContract();
|
|
81
86
|
const hideSpinner = showSpinner();
|
|
82
87
|
try {
|
|
83
88
|
const BEACON = await contract.read.BEACON();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-factory.js","sourceRoot":"","sources":["../../features/vault-factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,cAAc,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAG3D,OAAO,EAAE,uBAAuB,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,EACL,0BAA0B,EAC1B,SAAS,EACT,UAAU,EACV,WAAW,EACX,QAAQ,EACR,yBAAyB,EACzB,oBAAoB,EACpB,kBAAkB,
|
|
1
|
+
{"version":3,"file":"vault-factory.js","sourceRoot":"","sources":["../../features/vault-factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,4 @@
|
|
|
1
|
-
export declare const getConfirmExpiry: (confirmExpiry
|
|
2
|
-
|
|
1
|
+
export declare const getConfirmExpiry: ({ confirmExpiry, }: {
|
|
2
|
+
confirmExpiry?: number;
|
|
3
|
+
}) => Promise<number>;
|
|
4
|
+
export declare const getNodeOperatorFeeRate: (nodeOperatorFeeRate?: number) => Promise<number>;
|
|
@@ -1,6 +1,9 @@
|
|
|
1
|
+
import { hoodi } from 'viem/chains';
|
|
2
|
+
import { getChain } from '../../configs/index.js';
|
|
1
3
|
import { numberPrompt, selectPrompt } from '../../utils/index.js';
|
|
2
|
-
const MIN_CONFIRM_EXPIRY = 24 * 60 * 60;
|
|
3
|
-
const
|
|
4
|
+
const MIN_CONFIRM_EXPIRY = 24 * 60 * 60; // 24 hours
|
|
5
|
+
const MIN_CONFIRM_EXPIRY_TESTNET = 1 * 60 * 60; // 1 hour
|
|
6
|
+
const MAX_CONFIRM_EXPIRY = 24 * 60 * 60 * 30; // 30 days
|
|
4
7
|
const validateConfirmExpiry = (confirmExpiry) => {
|
|
5
8
|
const minInHours = MIN_CONFIRM_EXPIRY / 3600;
|
|
6
9
|
const maxInHours = MAX_CONFIRM_EXPIRY / 3600;
|
|
@@ -23,9 +26,14 @@ const validateNodeOperatorFeeRate = (nodeOperatorFeeRate, type) => {
|
|
|
23
26
|
if (type === 'percentage' && nodeOperatorFeeRate % 1 !== 0)
|
|
24
27
|
throw new Error(`Node operator fee rate must be a whole number. Current value: ${nodeOperatorFeeRate}`);
|
|
25
28
|
};
|
|
26
|
-
export const getConfirmExpiry = async (confirmExpiry) => {
|
|
29
|
+
export const getConfirmExpiry = async ({ confirmExpiry, }) => {
|
|
30
|
+
const chain = await getChain();
|
|
31
|
+
const isTestnet = chain.id === hoodi.id;
|
|
32
|
+
const minConfirmExpiry = isTestnet
|
|
33
|
+
? MIN_CONFIRM_EXPIRY_TESTNET
|
|
34
|
+
: MIN_CONFIRM_EXPIRY;
|
|
27
35
|
if (!confirmExpiry) {
|
|
28
|
-
const confirmExpiryValue = await numberPrompt(
|
|
36
|
+
const confirmExpiryValue = await numberPrompt(`Enter the confirm expiry (in hours) (min: ${minConfirmExpiry / 3600} hours, max: ${MAX_CONFIRM_EXPIRY / 3600} hours)`, 'value');
|
|
29
37
|
if (!confirmExpiryValue.value)
|
|
30
38
|
throw new Error('Invalid confirm expiry');
|
|
31
39
|
validateConfirmExpiry(confirmExpiryValue.value);
|
|
@@ -42,7 +50,7 @@ export const getNodeOperatorFeeRate = async (nodeOperatorFeeRate) => {
|
|
|
42
50
|
]);
|
|
43
51
|
if (!chooseFeeType.feeType)
|
|
44
52
|
throw new Error('Invalid fee type');
|
|
45
|
-
const nodeOperatorFeeRateValue = await numberPrompt(`Enter the node operator fee rate (in ${chooseFeeType.feeType})`, 'value');
|
|
53
|
+
const nodeOperatorFeeRateValue = await numberPrompt(`Enter the node operator fee rate (in ${chooseFeeType.feeType}) (max: ${chooseFeeType.feeType === 'basis points' ? 10000 : 100})`, 'value');
|
|
46
54
|
if (!nodeOperatorFeeRateValue.value)
|
|
47
55
|
throw new Error('Invalid node operator fee rate');
|
|
48
56
|
if (chooseFeeType.feeType === 'basis points') {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/create-vault.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAEnD,MAAM,kBAAkB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"create-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/create-vault.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,8 +6,8 @@ export const getDashboardByVault = async (vault) => {
|
|
|
6
6
|
const vaultHub = await getVaultHubContract();
|
|
7
7
|
const vaultConnection = await callReadMethodSilent(vaultHub, 'vaultConnection', [vault]);
|
|
8
8
|
const vaultOwner = vaultConnection.owner;
|
|
9
|
-
const dashboard = getDashboardContract(vaultOwner);
|
|
10
|
-
const publicClient = getPublicClient();
|
|
9
|
+
const dashboard = await getDashboardContract(vaultOwner);
|
|
10
|
+
const publicClient = await getPublicClient();
|
|
11
11
|
const bytecode = await publicClient.getCode({ address: vaultOwner });
|
|
12
12
|
if (!bytecode || bytecode === '0x') {
|
|
13
13
|
throw new Error(`Owner ${vaultOwner} is not a contract (probably EOA)`);
|
|
@@ -24,8 +24,8 @@ export const chooseVaultAndGetDashboard = async (args) => {
|
|
|
24
24
|
chosenVault = vault ?? (await chooseVault());
|
|
25
25
|
}
|
|
26
26
|
const dashboard = await getDashboardByVault(chosenVault);
|
|
27
|
-
const dashboardContract = getDashboardContract(dashboard);
|
|
28
|
-
const vaultContract = getStakingVaultContract(chosenVault);
|
|
27
|
+
const dashboardContract = await getDashboardContract(dashboard);
|
|
28
|
+
const vaultContract = await getStakingVaultContract(chosenVault);
|
|
29
29
|
return {
|
|
30
30
|
address: dashboard,
|
|
31
31
|
contract: dashboardContract,
|
|
@@ -1 +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,uBAAuB,EAEvB,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;
|
|
1
|
+
{"version":3,"file":"dashboard-by-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/dashboard-by-vault.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,oBAAoB,EACpB,uBAAuB,EAEvB,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,MAAM,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEzD,MAAM,YAAY,GAAG,MAAM,eAAe,EAAE,CAAC;IAC7C,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,EAKE,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,MAAM,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAChE,MAAM,aAAa,GAAG,MAAM,uBAAuB,CAAC,WAAW,CAAC,CAAC;IAEjE,OAAO;QACL,OAAO,EAAE,SAAS;QAClB,QAAQ,EAAE,iBAAiB;QAC3B,aAAa;QACb,KAAK,EAAE,WAAW;KACnB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -6,9 +6,9 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
6
6
|
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
7
7
|
await reportFreshWarning(vault);
|
|
8
8
|
const hideSpinner = showSpinner();
|
|
9
|
-
const publicClient = getPublicClient();
|
|
9
|
+
const publicClient = await getPublicClient();
|
|
10
10
|
try {
|
|
11
|
-
const [steth, wsteth, lidoLocator, vaultHub, vaultConnection, liabilityShares, obligations, totalValue, locked, maxLockableValue, totalMintingCapacityShares, remainingMintingCapacityShares, withdrawableValue, feeRecipient, nodeOperatorAccruedFee, feeRate, confirmExpiry, maxConfirmExpiry, minConfirmExpiry,] = await Promise.all([
|
|
11
|
+
const [steth, wsteth, lidoLocator, vaultHub, vaultConnection, liabilityShares, obligations, totalValue, locked, maxLockableValue, totalMintingCapacityShares, remainingMintingCapacityShares, withdrawableValue, settledGrowth, feeRecipient, nodeOperatorAccruedFee, feeRate, confirmExpiry, maxConfirmExpiry, minConfirmExpiry,] = await Promise.all([
|
|
12
12
|
contract.read.STETH(),
|
|
13
13
|
contract.read.WSTETH(),
|
|
14
14
|
contract.read.LIDO_LOCATOR(),
|
|
@@ -22,6 +22,7 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
22
22
|
contract.read.totalMintingCapacityShares(),
|
|
23
23
|
contract.read.remainingMintingCapacityShares([0n]),
|
|
24
24
|
contract.read.withdrawableValue(),
|
|
25
|
+
contract.read.settledGrowth(),
|
|
25
26
|
contract.read.feeRecipient(),
|
|
26
27
|
contract.read.accruedFee(),
|
|
27
28
|
contract.read.feeRate(),
|
|
@@ -59,7 +60,7 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
59
60
|
['Liquidity Fee, %', formatBP(vaultConnection.liquidityFeeBP)],
|
|
60
61
|
['Reservation Fee, BP', vaultConnection.reservationFeeBP],
|
|
61
62
|
['Reservation Fee, %', formatBP(vaultConnection.reservationFeeBP)],
|
|
62
|
-
['Share Limit, Shares', vaultConnection.shareLimit],
|
|
63
|
+
['Share Limit, Shares', formatEther(vaultConnection.shareLimit)],
|
|
63
64
|
['Liability Shares, Shares', formatEther(liabilityShares)],
|
|
64
65
|
['Obligations (sharesToBurn), Shares', formatEther(obligations[0])],
|
|
65
66
|
['Obligations (feesToSettle), ETH', formatEther(obligations[1])],
|
|
@@ -67,6 +68,7 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
67
68
|
['Locked, ETH', formatEther(locked)],
|
|
68
69
|
['Max Lockable Value, ETH', formatEther(maxLockableValue)],
|
|
69
70
|
['Balance, ETH', formatEther(balance)],
|
|
71
|
+
['Settled Growth, ETH', formatEther(settledGrowth)],
|
|
70
72
|
[
|
|
71
73
|
'Total Minting Capacity, Shares',
|
|
72
74
|
formatEther(totalMintingCapacityShares),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-info.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAGnC,OAAO,EACL,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,SAAS,EACT,WAAW,EACX,UAAU,EACV,oBAAoB,GACrB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAE9C,MAAM,CAAC,MAAM,uBAAuB,GAAG,KAAK,EAAE,QAA2B,EAAE,EAAE;IAC3E,MAAM,KAAK,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;IACnE,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAEhC,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"vault-info.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-info.ts"],"names":[],"mappings":"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"}
|
|
@@ -7,7 +7,7 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
7
7
|
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
8
8
|
await reportFreshWarning(vault);
|
|
9
9
|
const hideSpinner = showSpinner();
|
|
10
|
-
const publicClient = getPublicClient();
|
|
10
|
+
const publicClient = await getPublicClient();
|
|
11
11
|
let report = null;
|
|
12
12
|
try {
|
|
13
13
|
const lazyOracleContract = await getLazyOracleContract();
|
|
@@ -20,7 +20,7 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
20
20
|
try {
|
|
21
21
|
const health = await fetchAndCalculateVaultHealth(contract);
|
|
22
22
|
const operatorGridContract = await getOperatorGridContract();
|
|
23
|
-
const [vaultConnection, totalMintingCapacityShares, withdrawableValue, totalValue, locked, remainingMintingCapacityShares, minimalReserve, nodeOperatorFeeRate, nodeOperatorAccruedFee,] = await Promise.all([
|
|
23
|
+
const [vaultConnection, totalMintingCapacityShares, withdrawableValue, totalValue, locked, remainingMintingCapacityShares, minimalReserve, nodeOperatorFeeRate, nodeOperatorAccruedFee, settledGrowth,] = await Promise.all([
|
|
24
24
|
contract.read.vaultConnection(),
|
|
25
25
|
contract.read.totalMintingCapacityShares(),
|
|
26
26
|
contract.read.withdrawableValue(),
|
|
@@ -30,6 +30,7 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
30
30
|
contract.read.minimalReserve(),
|
|
31
31
|
contract.read.feeRate(),
|
|
32
32
|
contract.read.accruedFee(),
|
|
33
|
+
contract.read.settledGrowth(),
|
|
33
34
|
]);
|
|
34
35
|
const { reserveRatioBP, shareLimit } = vaultConnection;
|
|
35
36
|
const stethContract = await getStethContract();
|
|
@@ -42,17 +43,11 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
42
43
|
const isNoHaveGroup = tierInfo[0] === '0xFFfFfFffFFfffFFfFFfFFFFFffFFFffffFfFFFfF';
|
|
43
44
|
const nodeOperatorGroup = await callReadMethodSilent(operatorGridContract, 'group', [tierInfo[0]]);
|
|
44
45
|
const [totalMintingCapacityStethWei, shareLimitStethWei, tierShareLimitStethWei, groupShareLimitStethWei, remainingMintingCapacityStethWei, lastReportLiabilityInStethWei,] = await Promise.all([
|
|
45
|
-
stethContract.read.
|
|
46
|
-
|
|
47
|
-
]),
|
|
48
|
-
stethContract.read.
|
|
49
|
-
stethContract.read.
|
|
50
|
-
stethContract.read.getPooledEthBySharesRoundUp([
|
|
51
|
-
nodeOperatorGroup.shareLimit,
|
|
52
|
-
]),
|
|
53
|
-
stethContract.read.getPooledEthBySharesRoundUp([
|
|
54
|
-
remainingMintingCapacityShares,
|
|
55
|
-
]),
|
|
46
|
+
stethContract.read.getPooledEthByShares([totalMintingCapacityShares]),
|
|
47
|
+
stethContract.read.getPooledEthByShares([shareLimit]),
|
|
48
|
+
stethContract.read.getPooledEthByShares([tierInfo[2]]),
|
|
49
|
+
stethContract.read.getPooledEthByShares([nodeOperatorGroup.shareLimit]),
|
|
50
|
+
stethContract.read.getPooledEthByShares([remainingMintingCapacityShares]),
|
|
56
51
|
report
|
|
57
52
|
? stethContract.read.getPooledEthBySharesRoundUp([
|
|
58
53
|
BigInt(report.data.liabilityShares),
|
|
@@ -102,6 +97,11 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
102
97
|
['Recently Repaid, ETH', formatEther(overview.recentlyRepaid)],
|
|
103
98
|
['Node Operator Accrued Fee, ETH', formatEther(nodeOperatorAccruedFee)],
|
|
104
99
|
['Reserved, ETH', formatEther(overview.reserved)],
|
|
100
|
+
['Settled Growth, ETH', formatEther(settledGrowth)],
|
|
101
|
+
[
|
|
102
|
+
'Total Minting Capacity, Shares',
|
|
103
|
+
formatEther(totalMintingCapacityShares),
|
|
104
|
+
],
|
|
105
105
|
[
|
|
106
106
|
'Total Minting Capacity, stETH',
|
|
107
107
|
formatEther(overview.totalMintingCapacityStethWei),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-overview.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-overview.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAEnC,OAAO,EAEL,qBAAqB,EACrB,uBAAuB,EACvB,gBAAgB,EAChB,mBAAmB,GACpB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EACL,4BAA4B,EAC5B,QAAQ,EACR,WAAW,EACX,WAAW,EACX,OAAO,EACP,QAAQ,EACR,SAAS,EACT,eAAe,EACf,iBAAiB,EACjB,UAAU,EACV,mBAAmB,EACnB,cAAc,EACd,oBAAoB,GAErB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAE9C,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,QAA2B,EAC3B,EAAE;IACF,MAAM,KAAK,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;IACnE,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAEhC,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"vault-overview.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-overview.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Address } from 'viem';
|
|
2
2
|
import { DashboardContract } from '../../contracts/index.js';
|
|
3
|
-
export type RoleName = 'DEFAULT_ADMIN_ROLE' | 'BURN_ROLE' | 'FUND_ROLE' | 'MINT_ROLE' | 'WITHDRAW_ROLE' | 'NODE_OPERATOR_MANAGER_ROLE' | 'PAUSE_BEACON_CHAIN_DEPOSITS_ROLE' | 'RESUME_BEACON_CHAIN_DEPOSITS_ROLE' | 'REBALANCE_ROLE' | 'REQUEST_VALIDATOR_EXIT_ROLE' | 'TRIGGER_VALIDATOR_WITHDRAWAL_ROLE' | 'VOLUNTARY_DISCONNECT_ROLE' | 'VAULT_CONFIGURATION_ROLE' | 'COLLECT_VAULT_ERC20_ROLE' | 'NODE_OPERATOR_FEE_EXEMPT_ROLE' | 'NODE_OPERATOR_PROVE_UNKNOWN_VALIDATOR_ROLE' | 'NODE_OPERATOR_UNGUARANTEED_DEPOSIT_ROLE'
|
|
3
|
+
export type RoleName = 'DEFAULT_ADMIN_ROLE' | 'BURN_ROLE' | 'FUND_ROLE' | 'MINT_ROLE' | 'WITHDRAW_ROLE' | 'NODE_OPERATOR_MANAGER_ROLE' | 'PAUSE_BEACON_CHAIN_DEPOSITS_ROLE' | 'RESUME_BEACON_CHAIN_DEPOSITS_ROLE' | 'REBALANCE_ROLE' | 'REQUEST_VALIDATOR_EXIT_ROLE' | 'TRIGGER_VALIDATOR_WITHDRAWAL_ROLE' | 'VOLUNTARY_DISCONNECT_ROLE' | 'VAULT_CONFIGURATION_ROLE' | 'COLLECT_VAULT_ERC20_ROLE' | 'NODE_OPERATOR_FEE_EXEMPT_ROLE' | 'NODE_OPERATOR_PROVE_UNKNOWN_VALIDATOR_ROLE' | 'NODE_OPERATOR_UNGUARANTEED_DEPOSIT_ROLE';
|
|
4
|
+
export declare const DASHBOARD_ROLES_KEYS: RoleName[];
|
|
4
5
|
export declare const getVaultRolesByDashboard: (contract: DashboardContract) => Promise<void>;
|
|
5
6
|
export declare const checkVaultRole: (contract: DashboardContract, roleName: RoleName, address: Address) => Promise<true>;
|
|
@@ -1,30 +1,29 @@
|
|
|
1
1
|
import { printError, showSpinner, logResult, logInfo, callReadMethodSilent, } from '../../utils/index.js';
|
|
2
|
+
export const DASHBOARD_ROLES_KEYS = [
|
|
3
|
+
'DEFAULT_ADMIN_ROLE',
|
|
4
|
+
'BURN_ROLE',
|
|
5
|
+
'FUND_ROLE',
|
|
6
|
+
'MINT_ROLE',
|
|
7
|
+
'WITHDRAW_ROLE',
|
|
8
|
+
'NODE_OPERATOR_MANAGER_ROLE',
|
|
9
|
+
'PAUSE_BEACON_CHAIN_DEPOSITS_ROLE',
|
|
10
|
+
'RESUME_BEACON_CHAIN_DEPOSITS_ROLE',
|
|
11
|
+
'REBALANCE_ROLE',
|
|
12
|
+
'REQUEST_VALIDATOR_EXIT_ROLE',
|
|
13
|
+
'TRIGGER_VALIDATOR_WITHDRAWAL_ROLE',
|
|
14
|
+
'VOLUNTARY_DISCONNECT_ROLE',
|
|
15
|
+
'VAULT_CONFIGURATION_ROLE',
|
|
16
|
+
'COLLECT_VAULT_ERC20_ROLE',
|
|
17
|
+
'NODE_OPERATOR_FEE_EXEMPT_ROLE',
|
|
18
|
+
'NODE_OPERATOR_PROVE_UNKNOWN_VALIDATOR_ROLE',
|
|
19
|
+
'NODE_OPERATOR_UNGUARANTEED_DEPOSIT_ROLE',
|
|
20
|
+
];
|
|
2
21
|
export const getVaultRolesByDashboard = async (contract) => {
|
|
3
22
|
const hideSpinner = showSpinner();
|
|
4
23
|
try {
|
|
5
|
-
const
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
'FUND_ROLE',
|
|
9
|
-
'MINT_ROLE',
|
|
10
|
-
'WITHDRAW_ROLE',
|
|
11
|
-
'NODE_OPERATOR_MANAGER_ROLE',
|
|
12
|
-
'PAUSE_BEACON_CHAIN_DEPOSITS_ROLE',
|
|
13
|
-
'RESUME_BEACON_CHAIN_DEPOSITS_ROLE',
|
|
14
|
-
'REBALANCE_ROLE',
|
|
15
|
-
'REQUEST_VALIDATOR_EXIT_ROLE',
|
|
16
|
-
'TRIGGER_VALIDATOR_WITHDRAWAL_ROLE',
|
|
17
|
-
'VOLUNTARY_DISCONNECT_ROLE',
|
|
18
|
-
'VAULT_CONFIGURATION_ROLE',
|
|
19
|
-
'COLLECT_VAULT_ERC20_ROLE',
|
|
20
|
-
'NODE_OPERATOR_FEE_EXEMPT_ROLE',
|
|
21
|
-
'NODE_OPERATOR_PROVE_UNKNOWN_VALIDATOR_ROLE',
|
|
22
|
-
'NODE_OPERATOR_UNGUARANTEED_DEPOSIT_ROLE',
|
|
23
|
-
'PAUSE_BEACON_CHAIN_DEPOSITS_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) => {
|
|
24
|
+
const roleValues = await Promise.all(DASHBOARD_ROLES_KEYS.map((key) => contract.read[key]()));
|
|
25
|
+
const roles = Object.fromEntries(DASHBOARD_ROLES_KEYS.map((key, index) => [key, roleValues[index]]));
|
|
26
|
+
const result = await Promise.all(DASHBOARD_ROLES_KEYS.map(async (key) => {
|
|
28
27
|
const accounts = await contract.read.getRoleMembers([roles[key]]);
|
|
29
28
|
return {
|
|
30
29
|
Role: key,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-roles.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-roles.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,UAAU,EACV,WAAW,EACX,SAAS,EACT,OAAO,EACP,oBAAoB,GACrB,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"vault-roles.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-roles.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1,6 @@
|
|
|
1
|
+
import { Address, Hex } from 'viem';
|
|
2
|
+
export declare const getAllVaults: () => Promise<`0x${string}`[]>;
|
|
3
|
+
export declare const getVaultsByAddress: (address: Address) => Promise<Record<Address, string[]>>;
|
|
4
|
+
export declare const getVaultsByRoleMember: (role: Hex, member: Address) => Promise<`0x${string}`[]>;
|
|
5
|
+
export declare const getVaultsByOwner: (address: Address) => Promise<`0x${string}`[]>;
|
|
1
6
|
export declare const chooseVault: () => Promise<any>;
|
|
@@ -1,48 +1,135 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { callReadMethodSilent, selectPrompt } from '../../utils/index.js';
|
|
1
|
+
import { getVaultViewerContract, getDashboardImplContract, getPredepositGuaranteeContract, } from '../../contracts/index.js';
|
|
2
|
+
import { callReadMethodSilent, printError, selectPrompt, showSpinner, } from '../../utils/index.js';
|
|
3
3
|
import { getAccount } from '../../providers/index.js';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
4
|
+
import { DASHBOARD_ROLES_KEYS } from './vault-roles.js';
|
|
5
|
+
const LIMIT = 100n;
|
|
6
|
+
export const getAllVaults = async () => {
|
|
7
|
+
const hideSpinner = showSpinner({
|
|
8
|
+
message: 'Getting vaults...',
|
|
9
|
+
});
|
|
10
|
+
try {
|
|
11
|
+
const contract = await getVaultViewerContract();
|
|
12
|
+
const totalVaults = await callReadMethodSilent(contract, 'vaultsCount');
|
|
13
|
+
const vaultsByOwner = [];
|
|
14
|
+
for (let i = 0n; i < totalVaults; i += LIMIT) {
|
|
15
|
+
const vaults = await callReadMethodSilent(contract, 'vaultAddressesBatch', [i, LIMIT]);
|
|
16
|
+
vaultsByOwner.push(...vaults);
|
|
17
|
+
}
|
|
18
|
+
return vaultsByOwner;
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
hideSpinner();
|
|
22
|
+
printError(err, 'Error when getting vaults');
|
|
23
|
+
throw err;
|
|
24
|
+
}
|
|
25
|
+
finally {
|
|
26
|
+
hideSpinner();
|
|
27
|
+
}
|
|
10
28
|
};
|
|
11
|
-
const
|
|
12
|
-
const contract =
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
29
|
+
export const getVaultsByAddress = async (address) => {
|
|
30
|
+
const [contract, dashboardImpl, vaults, pdg] = await Promise.all([
|
|
31
|
+
getVaultViewerContract(),
|
|
32
|
+
getDashboardImplContract(),
|
|
33
|
+
getAllVaults(),
|
|
34
|
+
getPredepositGuaranteeContract(),
|
|
35
|
+
]);
|
|
36
|
+
const vaultsWithMembers = [];
|
|
37
|
+
const addressLower = address.toLowerCase();
|
|
38
|
+
const vaultsByRole = {};
|
|
39
|
+
// Get roles from dashboard impl
|
|
40
|
+
const hideSpinner = showSpinner({
|
|
41
|
+
message: 'Getting roles...',
|
|
42
|
+
});
|
|
43
|
+
const rolesValues = await Promise.all(DASHBOARD_ROLES_KEYS.map((key) => dashboardImpl.read[key]()));
|
|
44
|
+
hideSpinner();
|
|
45
|
+
// Get roles and members from vaults (dashboard)
|
|
46
|
+
for (let i = 0; i < vaults.length; i += Number(LIMIT)) {
|
|
47
|
+
const batch = await callReadMethodSilent(contract, 'roleMembersBatch', [
|
|
48
|
+
vaults.slice(i, i + Number(LIMIT)),
|
|
49
|
+
rolesValues,
|
|
50
|
+
]);
|
|
51
|
+
vaultsWithMembers.push(...batch);
|
|
52
|
+
}
|
|
53
|
+
// Get depositors from pdg for node operators in vaults
|
|
54
|
+
const nodeOperatorsAndVault = vaultsWithMembers.map(({ nodeOperator, vault }) => ({ nodeOperator, vault }));
|
|
55
|
+
const depositorsWithVault = await Promise.all(nodeOperatorsAndVault.map(async ({ nodeOperator, vault }) => {
|
|
56
|
+
const depositor = await callReadMethodSilent(pdg, 'nodeOperatorDepositor', [nodeOperator]);
|
|
57
|
+
return { depositor, vault };
|
|
18
58
|
}));
|
|
19
|
-
const
|
|
20
|
-
|
|
59
|
+
for (const { depositor, vault } of depositorsWithVault) {
|
|
60
|
+
if (depositor.toLowerCase() === addressLower) {
|
|
61
|
+
vaultsByRole[vault] = ['Depositor'];
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
// Map roles and members from vaults (dashboard)
|
|
65
|
+
for (const { vault, owner, nodeOperator, members } of vaultsWithMembers) {
|
|
66
|
+
const roles = [];
|
|
67
|
+
if (owner.toLowerCase() === addressLower) {
|
|
68
|
+
roles.push('Owner');
|
|
69
|
+
}
|
|
70
|
+
if (nodeOperator.toLowerCase() === addressLower) {
|
|
71
|
+
roles.push('Node Operator');
|
|
72
|
+
}
|
|
73
|
+
const membersLength = Math.min(members.length, DASHBOARD_ROLES_KEYS.length);
|
|
74
|
+
for (let i = 0; i < membersLength; i++) {
|
|
75
|
+
const roleMembers = members[i];
|
|
76
|
+
const roleName = DASHBOARD_ROLES_KEYS[i];
|
|
77
|
+
const isHasRole = roleMembers &&
|
|
78
|
+
roleMembers.some((member) => member.toLowerCase() === addressLower);
|
|
79
|
+
if (isHasRole && roleName)
|
|
80
|
+
roles.push(roleName);
|
|
81
|
+
}
|
|
82
|
+
if (roles.length > 0)
|
|
83
|
+
vaultsByRole[vault] = vaultsByRole[vault]
|
|
84
|
+
? [...vaultsByRole[vault], ...roles]
|
|
85
|
+
: roles;
|
|
86
|
+
}
|
|
87
|
+
return vaultsByRole;
|
|
88
|
+
};
|
|
89
|
+
export const getVaultsByRoleMember = async (role, member) => {
|
|
90
|
+
const contract = await getVaultViewerContract();
|
|
91
|
+
const vaults = await getAllVaults();
|
|
92
|
+
const vaultsByRole = [];
|
|
93
|
+
for (let i = 0; i < vaults.length; i += Number(LIMIT)) {
|
|
94
|
+
const vaults = await callReadMethodSilent(contract, 'vaultsByRoleBatch', [
|
|
95
|
+
role,
|
|
96
|
+
member,
|
|
97
|
+
BigInt(i),
|
|
98
|
+
BigInt(LIMIT),
|
|
99
|
+
]);
|
|
100
|
+
vaultsByRole.push(...vaults);
|
|
101
|
+
}
|
|
102
|
+
return vaultsByRole;
|
|
103
|
+
};
|
|
104
|
+
export const getVaultsByOwner = async (address) => {
|
|
105
|
+
const contract = await getVaultViewerContract();
|
|
106
|
+
const totalVaults = await callReadMethodSilent(contract, 'vaultsCount');
|
|
107
|
+
const vaultsByOwner = [];
|
|
108
|
+
for (let i = 0n; i < totalVaults; i += LIMIT) {
|
|
109
|
+
const vaults = await callReadMethodSilent(contract, 'vaultsByOwnerBatch', [
|
|
110
|
+
address,
|
|
111
|
+
i,
|
|
112
|
+
LIMIT,
|
|
113
|
+
]);
|
|
114
|
+
vaultsByOwner.push(...vaults);
|
|
115
|
+
}
|
|
116
|
+
return vaultsByOwner;
|
|
21
117
|
};
|
|
22
118
|
export const chooseVault = async () => {
|
|
23
119
|
const account = await getAccount();
|
|
24
|
-
const
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
let title = '';
|
|
34
|
-
if (vaultsByNO.includes(vault)) {
|
|
35
|
-
title = `Node Operator`;
|
|
36
|
-
}
|
|
37
|
-
if (vaultsByOwner.includes(vault)) {
|
|
38
|
-
const separator = title.length > 0 ? ', ' : '';
|
|
39
|
-
title = `${title}${separator}Owner`;
|
|
40
|
-
}
|
|
41
|
-
return { title: `${vault} (${title})`, value: vault };
|
|
120
|
+
const vaultsByAddress = await getVaultsByAddress(account.address);
|
|
121
|
+
if (Object.keys(vaultsByAddress).length === 0) {
|
|
122
|
+
printError(new Error(`No vaults found for account ${account.address}`), 'No vaults found for account. Please check your account address and try again.');
|
|
123
|
+
}
|
|
124
|
+
const vaultsWithRole = Object.entries(vaultsByAddress).map(([vault, roles]) => {
|
|
125
|
+
return {
|
|
126
|
+
title: `${vault} (${roles.join(', ')})`,
|
|
127
|
+
value: vault,
|
|
128
|
+
};
|
|
42
129
|
});
|
|
43
130
|
const vault = await selectPrompt('Choose a vault', 'address', vaultsWithRole);
|
|
44
131
|
if (!vault.address)
|
|
45
|
-
|
|
132
|
+
printError(new Error('No vault selected'), 'No vault selected. Please select a vault or use the --vault flag');
|
|
46
133
|
return vault.address;
|
|
47
134
|
};
|
|
48
135
|
//# sourceMappingURL=vaults-by-role.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vaults-by-role.js","sourceRoot":"","sources":["../../../features/vault-operations/vaults-by-role.ts"],"names":[],"mappings":"AAEA,OAAO,
|
|
1
|
+
{"version":3,"file":"vaults-by-role.js","sourceRoot":"","sources":["../../../features/vault-operations/vaults-by-role.ts"],"names":[],"mappings":"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"}
|