@lidofinance/lsv-cli 1.1.0 → 1.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +58 -0
- package/dist/abi/Dashboard.d.ts +291 -3
- package/dist/abi/Dashboard.js +10 -3
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.d.ts +364 -0
- package/dist/abi/LazyOracle.js +2 -0
- package/dist/abi/LazyOracle.js.map +1 -1
- package/dist/abi/OperatorGrid.d.ts +24 -0
- package/dist/abi/OperatorGrid.js +16 -0
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/PredepositGuarantee.d.ts +357 -88
- package/dist/abi/PredepositGuarantee.js +31 -28
- package/dist/abi/PredepositGuarantee.js.map +1 -1
- package/dist/abi/ValidatorConsolidationRequests.d.ts +121 -0
- package/dist/abi/ValidatorConsolidationRequests.js +159 -0
- package/dist/abi/ValidatorConsolidationRequests.js.map +1 -0
- package/dist/abi/VaultFactory.d.ts +16 -0
- package/dist/abi/VaultViewer.d.ts +8 -14
- package/dist/abi/VaultViewer.js +10 -19
- package/dist/abi/VaultViewer.js.map +1 -1
- package/dist/abi/defi-wrapper/Distributor.d.ts +40 -2
- package/dist/abi/defi-wrapper/Distributor.js +52 -2
- package/dist/abi/defi-wrapper/Distributor.js.map +1 -1
- package/dist/abi/defi-wrapper/Factory.d.ts +973 -550
- package/dist/abi/defi-wrapper/Factory.js +720 -763
- package/dist/abi/defi-wrapper/Factory.js.map +1 -1
- package/dist/abi/defi-wrapper/StvPool.d.ts +121 -325
- package/dist/abi/defi-wrapper/StvPool.js +143 -413
- package/dist/abi/defi-wrapper/StvPool.js.map +1 -1
- package/dist/abi/defi-wrapper/StvStETHPool.d.ts +398 -381
- package/dist/abi/defi-wrapper/StvStETHPool.js +448 -433
- package/dist/abi/defi-wrapper/StvStETHPool.js.map +1 -1
- package/dist/abi/defi-wrapper/WithdrawalQueue.d.ts +309 -175
- package/dist/abi/defi-wrapper/WithdrawalQueue.js +381 -206
- package/dist/abi/defi-wrapper/WithdrawalQueue.js.map +1 -1
- package/dist/abi/defi-wrapper/index.d.ts +0 -1
- package/dist/abi/defi-wrapper/index.js +0 -1
- package/dist/abi/defi-wrapper/index.js.map +1 -1
- package/dist/abi/index.d.ts +1 -0
- package/dist/abi/index.js +1 -0
- package/dist/abi/index.js.map +1 -1
- package/dist/command/index.js +1 -0
- package/dist/command/index.js.map +1 -1
- 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 +67 -6
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/index.d.ts +4 -3
- package/dist/configs/index.js +4 -3
- package/dist/configs/index.js.map +1 -1
- package/dist/configs/utils.d.ts +1 -0
- package/dist/configs/utils.js +8 -0
- package/dist/configs/utils.js.map +1 -1
- package/dist/contracts/dashboard-impl.d.ts +2 -2
- package/dist/contracts/dashboard-impl.js +3 -2
- package/dist/contracts/dashboard-impl.js.map +1 -1
- 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 +1 -1
- package/dist/contracts/defi-wrapper/distributor.js +3 -2
- package/dist/contracts/defi-wrapper/distributor.js.map +1 -1
- package/dist/contracts/defi-wrapper/factory.d.ts +1 -1
- package/dist/contracts/defi-wrapper/factory.js +3 -2
- package/dist/contracts/defi-wrapper/factory.js.map +1 -1
- package/dist/contracts/defi-wrapper/index.d.ts +0 -1
- package/dist/contracts/defi-wrapper/index.js +0 -1
- package/dist/contracts/defi-wrapper/index.js.map +1 -1
- package/dist/contracts/defi-wrapper/stv-pool.d.ts +2 -2
- package/dist/contracts/defi-wrapper/stv-pool.js +3 -2
- package/dist/contracts/defi-wrapper/stv-pool.js.map +1 -1
- package/dist/contracts/defi-wrapper/stv-steth-pool.d.ts +1 -1
- package/dist/contracts/defi-wrapper/stv-steth-pool.js +3 -2
- package/dist/contracts/defi-wrapper/stv-steth-pool.js.map +1 -1
- package/dist/contracts/defi-wrapper/withdrawal-queue.d.ts +1 -1
- package/dist/contracts/defi-wrapper/withdrawal-queue.js +3 -2
- package/dist/contracts/defi-wrapper/withdrawal-queue.js.map +1 -1
- 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/validator-consolidation-requests.d.ts +5 -0
- package/dist/contracts/validator-consolidation-requests.js +13 -0
- package/dist/contracts/validator-consolidation-requests.js.map +1 -0
- package/dist/contracts/vault-factory.d.ts +3 -28346
- 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 -9661
- 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/consolidation.d.ts +18 -0
- package/dist/features/consolidation.js +199 -0
- package/dist/features/consolidation.js.map +1 -0
- 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 +111 -0
- package/dist/features/defi-wrapper/defi-wrapper-factory.js +231 -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.js +2 -2
- package/dist/features/deposits/check-bls-deposits.js.map +1 -1
- package/dist/features/deposits/index.d.ts +2 -0
- package/dist/features/deposits/index.js +2 -0
- package/dist/features/deposits/index.js.map +1 -1
- package/dist/features/deposits/make-pdg-proof.js +1 -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/deposits/pdg.d.ts +2 -0
- package/dist/features/deposits/pdg.js +18 -0
- package/dist/features/deposits/pdg.js.map +1 -0
- package/dist/features/deposits/validators.d.ts +12 -0
- package/dist/features/deposits/validators.js +31 -0
- package/dist/features/deposits/validators.js.map +1 -0
- 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 +5 -1
- package/dist/features/index.js +5 -1
- package/dist/features/index.js.map +1 -1
- package/dist/features/lazy-oracle.js +2 -2
- package/dist/features/lazy-oracle.js.map +1 -1
- package/dist/features/metrics.d.ts +4 -0
- package/dist/features/metrics.js +48 -0
- package/dist/features/metrics.js.map +1 -0
- package/dist/features/mint-burn/allowance.d.ts +7 -1
- package/dist/features/mint-burn/allowance.js +8 -9
- package/dist/features/mint-burn/allowance.js.map +1 -1
- package/dist/features/mint-burn/burn-shares.d.ts +2 -1
- package/dist/features/mint-burn/burn-shares.js +4 -3
- package/dist/features/mint-burn/burn-shares.js.map +1 -1
- package/dist/features/mint-burn/burn-steth.d.ts +2 -1
- package/dist/features/mint-burn/burn-steth.js +4 -3
- package/dist/features/mint-burn/burn-steth.js.map +1 -1
- package/dist/features/mint-burn/mint-shares.js +4 -6
- package/dist/features/mint-burn/mint-shares.js.map +1 -1
- package/dist/features/mint-burn/mint-steth.js +4 -6
- package/dist/features/mint-burn/mint-steth.js.map +1 -1
- package/dist/features/pdg.js +4 -0
- package/dist/features/pdg.js.map +1 -1
- package/dist/features/utils/connection.d.ts +2 -0
- package/dist/features/utils/connection.js +14 -0
- package/dist/features/utils/connection.js.map +1 -0
- 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/liability-shares.js +2 -1
- package/dist/features/utils/liability-shares.js.map +1 -1
- package/dist/features/utils/quarantine.js +2 -0
- package/dist/features/utils/quarantine.js.map +1 -1
- package/dist/features/utils/report-fresh.d.ts +11 -1
- package/dist/features/utils/report-fresh.js +17 -15
- package/dist/features/utils/report-fresh.js.map +1 -1
- package/dist/features/vault-factory.d.ts +13 -14
- package/dist/features/vault-factory.js +32 -10
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-operations/connect-vault.d.ts +4 -0
- package/dist/features/vault-operations/connect-vault.js +21 -0
- package/dist/features/vault-operations/connect-vault.js.map +1 -0
- package/dist/features/vault-operations/create-vault.d.ts +4 -2
- package/dist/features/vault-operations/create-vault.js +17 -7
- package/dist/features/vault-operations/create-vault.js.map +1 -1
- package/dist/features/vault-operations/dashboard-by-vault.js +21 -8
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -1
- package/dist/features/vault-operations/index.d.ts +2 -0
- package/dist/features/vault-operations/index.js +2 -0
- package/dist/features/vault-operations/index.js.map +1 -1
- package/dist/features/vault-operations/roles.d.ts +5 -0
- package/dist/features/vault-operations/roles.js +65 -0
- package/dist/features/vault-operations/roles.js.map +1 -0
- package/dist/features/vault-operations/vault-info.js +10 -4
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +6 -8
- package/dist/features/vault-operations/vault-overview.js.map +1 -1
- package/dist/features/vault-operations/vault-roles.js +4 -1
- package/dist/features/vault-operations/vault-roles.js.map +1 -1
- package/dist/features/vault-operations/vaults-by-role.js +29 -10
- 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/features/with-report.d.ts +6 -0
- package/dist/features/with-report.js +18 -0
- package/dist/features/with-report.js.map +1 -0
- package/dist/index.js +38 -11
- 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/read.js +7 -7
- package/dist/programs/contracts/dashboard/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/write.js +80 -61
- 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 +6 -2
- package/dist/programs/contracts/hub/write.js.map +1 -1
- package/dist/programs/contracts/operator-grid/write.js +1 -1
- package/dist/programs/contracts/operator-grid/write.js.map +1 -1
- package/dist/programs/contracts/pdg/read.js +2 -1
- package/dist/programs/contracts/pdg/read.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +37 -3
- package/dist/programs/contracts/pdg/write.js.map +1 -1
- package/dist/programs/contracts/vault/write.js +16 -16
- package/dist/programs/contracts/vault/write.js.map +1 -1
- package/dist/programs/contracts/vault-factory/write.js +39 -25
- package/dist/programs/contracts/vault-factory/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/read.js +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/write.js +3 -3
- package/dist/programs/defi-wrapper/contracts/distributor/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/read.js +2 -8
- package/dist/programs/defi-wrapper/contracts/factory/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/write.js +91 -276
- package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/index.d.ts +0 -1
- package/dist/programs/defi-wrapper/contracts/index.js +0 -1
- package/dist/programs/defi-wrapper/contracts/index.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.js +22 -32
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +17 -24
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.js +25 -174
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.js +0 -90
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js +16 -23
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js +34 -231
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js +1 -91
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +8 -27
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +55 -24
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js.map +1 -1
- package/dist/programs/defi-wrapper/index.d.ts +1 -0
- package/dist/programs/defi-wrapper/index.js +1 -0
- package/dist/programs/defi-wrapper/index.js.map +1 -1
- 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.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.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 +180 -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 +1 -0
- package/dist/programs/index.js +1 -0
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/pdg-helpers.js +32 -24
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/use-cases/consolidation/index.d.ts +2 -0
- package/dist/programs/use-cases/consolidation/index.js +3 -0
- package/dist/programs/use-cases/consolidation/index.js.map +1 -0
- package/dist/programs/use-cases/consolidation/main.d.ts +1 -0
- package/dist/programs/use-cases/consolidation/main.js +5 -0
- package/dist/programs/use-cases/consolidation/main.js.map +1 -0
- package/dist/programs/use-cases/consolidation/write.d.ts +1 -0
- package/dist/programs/use-cases/consolidation/write.js +78 -0
- package/dist/programs/use-cases/consolidation/write.js.map +1 -0
- package/dist/programs/use-cases/deposits/read.js +4 -0
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/write.js +41 -11
- package/dist/programs/use-cases/deposits/write.js.map +1 -1
- package/dist/programs/use-cases/index.d.ts +1 -0
- package/dist/programs/use-cases/index.js +1 -0
- package/dist/programs/use-cases/index.js.map +1 -1
- package/dist/programs/use-cases/metrics/read.js +9 -20
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/create-vault.js +65 -29
- package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +124 -26
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/wallet.d.ts +14539 -63
- package/dist/providers/wallet.js +14 -4
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/integration/deposits.test.d.ts +1 -0
- package/dist/tests/integration/deposits.test.js +67 -0
- package/dist/tests/integration/deposits.test.js.map +1 -0
- package/dist/tests/integration/globalSetup.d.ts +1 -0
- package/dist/tests/integration/globalSetup.js +55 -0
- package/dist/tests/integration/globalSetup.js.map +1 -0
- package/dist/tests/integration/helpers/index.d.ts +3 -0
- package/dist/tests/integration/helpers/index.js +4 -0
- package/dist/tests/integration/helpers/index.js.map +1 -0
- package/dist/tests/integration/helpers/test-assertions.d.ts +32 -0
- package/dist/tests/integration/helpers/test-assertions.js +92 -0
- package/dist/tests/integration/helpers/test-assertions.js.map +1 -0
- package/dist/tests/integration/helpers/test-client.d.ts +14530 -0
- package/dist/tests/integration/helpers/test-client.js +73 -0
- package/dist/tests/integration/helpers/test-client.js.map +1 -0
- package/dist/tests/integration/helpers/test-config.d.ts +14 -0
- package/dist/tests/integration/helpers/test-config.js +62 -0
- package/dist/tests/integration/helpers/test-config.js.map +1 -0
- package/dist/tests/integration/helpers/test-setup.d.ts +12 -0
- package/dist/tests/integration/helpers/test-setup.js +40 -0
- package/dist/tests/integration/helpers/test-setup.js.map +1 -0
- package/dist/tests/integration/lazy-oracle.test.d.ts +1 -0
- package/dist/tests/integration/lazy-oracle.test.js +31 -0
- package/dist/tests/integration/lazy-oracle.test.js.map +1 -0
- package/dist/tests/integration/metrics.test.d.ts +1 -0
- package/dist/tests/integration/metrics.test.js +95 -0
- package/dist/tests/integration/metrics.test.js.map +1 -0
- package/dist/tests/integration/mint-burn.test.d.ts +1 -0
- package/dist/tests/integration/mint-burn.test.js +149 -0
- package/dist/tests/integration/mint-burn.test.js.map +1 -0
- package/dist/tests/integration/operator-grid.test.d.ts +1 -0
- package/dist/tests/integration/operator-grid.test.js +41 -0
- package/dist/tests/integration/operator-grid.test.js.map +1 -0
- package/dist/tests/integration/pdg.test.d.ts +1 -0
- package/dist/tests/integration/pdg.test.js +47 -0
- package/dist/tests/integration/pdg.test.js.map +1 -0
- package/dist/tests/integration/utils.test.d.ts +1 -0
- package/dist/tests/integration/utils.test.js +70 -0
- package/dist/tests/integration/utils.test.js.map +1 -0
- package/dist/tests/integration/vault-factory.test.d.ts +1 -0
- package/dist/tests/integration/vault-factory.test.js +29 -0
- package/dist/tests/integration/vault-factory.test.js.map +1 -0
- package/dist/tests/integration/vault-hub.test.d.ts +1 -0
- package/dist/tests/integration/vault-hub.test.js +71 -0
- package/dist/tests/integration/vault-hub.test.js.map +1 -0
- package/dist/tests/integration/vault-operations.test.d.ts +1 -0
- package/dist/tests/integration/vault-operations.test.js +151 -0
- package/dist/tests/integration/vault-operations.test.js.map +1 -0
- package/dist/tests/integration/vault-roles.test.d.ts +1 -0
- package/dist/tests/integration/vault-roles.test.js +44 -0
- package/dist/tests/integration/vault-roles.test.js.map +1 -0
- package/dist/tests/integration/vault.test.d.ts +1 -0
- package/dist/tests/integration/vault.test.js +44 -0
- package/dist/tests/integration/vault.test.js.map +1 -0
- package/dist/tests/utils/arguments.test.js +85 -4
- package/dist/tests/utils/arguments.test.js.map +1 -1
- package/dist/tests/utils/bigInt.test.d.ts +1 -0
- package/dist/tests/utils/bigInt.test.js +61 -0
- package/dist/tests/utils/bigInt.test.js.map +1 -0
- package/dist/tests/utils/calculate-health.test.d.ts +1 -0
- package/dist/tests/utils/calculate-health.test.js +140 -0
- package/dist/tests/utils/calculate-health.test.js.map +1 -0
- package/dist/tests/utils/calculate-overview-v2.test.d.ts +1 -0
- package/dist/tests/utils/calculate-overview-v2.test.js +181 -0
- package/dist/tests/utils/calculate-overview-v2.test.js.map +1 -0
- package/dist/tests/utils/calculate-overview.test.js +2 -1
- package/dist/tests/utils/calculate-overview.test.js.map +1 -1
- package/dist/tests/utils/csv-file.test.d.ts +1 -0
- package/dist/tests/utils/csv-file.test.js +111 -0
- package/dist/tests/utils/csv-file.test.js.map +1 -0
- package/dist/tests/utils/data-validators.test.js +1 -1
- package/dist/tests/utils/data-validators.test.js.map +1 -1
- package/dist/tests/utils/error-handler.test.js +7 -16
- package/dist/tests/utils/error-handler.test.js.map +1 -1
- package/dist/tests/utils/get-commands.test.js +1 -1
- package/dist/tests/utils/get-commands.test.js.map +1 -1
- package/dist/tests/utils/get-deposit-data-root.test.js +1 -2
- package/dist/tests/utils/get-deposit-data-root.test.js.map +1 -1
- package/dist/tests/utils/get-value.test.js +1 -1
- package/dist/tests/utils/get-value.test.js.map +1 -1
- package/dist/tests/utils/health.test.js +1 -1
- package/dist/tests/utils/health.test.js.map +1 -1
- package/dist/tests/utils/interrupt-handler.test.js +2 -5
- package/dist/tests/utils/interrupt-handler.test.js.map +1 -1
- package/dist/tests/utils/ipfs.test.js +37 -24
- package/dist/tests/utils/ipfs.test.js.map +1 -1
- package/dist/tests/utils/lido-apr.test.d.ts +1 -0
- package/dist/tests/utils/lido-apr.test.js +95 -0
- package/dist/tests/utils/lido-apr.test.js.map +1 -0
- package/dist/tests/utils/logging.test.js +135 -15
- package/dist/tests/utils/logging.test.js.map +1 -1
- package/dist/tests/utils/merkle-utils.test.d.ts +1 -0
- package/dist/tests/utils/merkle-utils.test.js +231 -0
- package/dist/tests/utils/merkle-utils.test.js.map +1 -0
- package/dist/tests/utils/rebase-rewards.test.d.ts +1 -0
- package/dist/tests/utils/rebase-rewards.test.js +114 -0
- package/dist/tests/utils/rebase-rewards.test.js.map +1 -0
- package/dist/tests/utils/resove-path.test.js +1 -1
- package/dist/tests/utils/resove-path.test.js.map +1 -1
- package/dist/tests/utils/sleep.test.js +5 -5
- package/dist/tests/utils/sleep.test.js.map +1 -1
- package/dist/tests/utils/snake-to-camel.test.d.ts +1 -0
- package/dist/tests/utils/snake-to-camel.test.js +37 -0
- package/dist/tests/utils/snake-to-camel.test.js.map +1 -0
- package/dist/tests/utils/timestamp.test.d.ts +1 -0
- package/dist/tests/utils/timestamp.test.js +51 -0
- package/dist/tests/utils/timestamp.test.js.map +1 -0
- package/dist/types/config.d.ts +1 -0
- package/dist/utils/arguments.d.ts +6 -1
- package/dist/utils/arguments.js +46 -1
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/bigInt.d.ts +2 -0
- package/dist/utils/bigInt.js +3 -0
- package/dist/utils/bigInt.js.map +1 -0
- 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 +30 -0
- package/dist/utils/cache.js +140 -3
- package/dist/utils/cache.js.map +1 -1
- package/dist/utils/calculate-overview-v2.d.ts +1 -2
- package/dist/utils/calculate-overview-v2.js +4 -8
- package/dist/utils/calculate-overview-v2.js.map +1 -1
- package/dist/utils/calculate-overview.d.ts +1 -0
- package/dist/utils/calculate-overview.js +2 -2
- package/dist/utils/calculate-overview.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +8 -18
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +7 -17
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +5 -5
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +11 -11
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
- package/dist/utils/charts/simple/simple-charts.js +8 -18
- package/dist/utils/charts/simple/simple-charts.js.map +1 -1
- package/dist/utils/commands/confirmations.js +1 -1
- package/dist/utils/commands/confirmations.js.map +1 -1
- package/dist/utils/commands/report.d.ts +6 -1
- package/dist/utils/commands/report.js +6 -4
- package/dist/utils/commands/report.js.map +1 -1
- package/dist/utils/consolidation/checks.d.ts +7 -0
- package/dist/utils/consolidation/checks.js +40 -0
- package/dist/utils/consolidation/checks.js.map +1 -0
- package/dist/utils/consolidation/confirms.d.ts +4 -0
- package/dist/utils/consolidation/confirms.js +41 -0
- package/dist/utils/consolidation/confirms.js.map +1 -0
- package/dist/utils/consolidation/index.d.ts +6 -0
- package/dist/utils/consolidation/index.js +7 -0
- package/dist/utils/consolidation/index.js.map +1 -0
- package/dist/utils/consolidation/logs.d.ts +3 -0
- package/dist/utils/consolidation/logs.js +43 -0
- package/dist/utils/consolidation/logs.js.map +1 -0
- package/dist/utils/consolidation/pubkeys.d.ts +8 -0
- package/dist/utils/consolidation/pubkeys.js +42 -0
- package/dist/utils/consolidation/pubkeys.js.map +1 -0
- package/dist/utils/consolidation/types.d.ts +12 -0
- package/dist/utils/consolidation/types.js +2 -0
- package/dist/utils/consolidation/types.js.map +1 -0
- package/dist/utils/consolidation/validator-info.d.ts +4 -0
- package/dist/utils/consolidation/validator-info.js +36 -0
- package/dist/utils/consolidation/validator-info.js.map +1 -0
- package/dist/utils/consolidation/validators-checks.d.ts +10 -0
- package/dist/utils/consolidation/validators-checks.js +58 -0
- package/dist/utils/consolidation/validators-checks.js.map +1 -0
- package/dist/utils/error-handler.js +2 -9
- package/dist/utils/error-handler.js.map +1 -1
- package/dist/utils/fetchCL.d.ts +35 -14
- package/dist/utils/fetchCL.js +78 -5
- package/dist/utils/fetchCL.js.map +1 -1
- package/dist/utils/health/health-utils.d.ts +54 -54
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/interrupt-handler.js +8 -2
- package/dist/utils/interrupt-handler.js.map +1 -1
- package/dist/utils/logging/console.js +41 -3
- package/dist/utils/logging/console.js.map +1 -1
- package/dist/utils/prompts/mint-burn/confirm-mint.js +1 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.js.map +1 -1
- package/dist/utils/prompts/operations.js +4 -1
- package/dist/utils/prompts/operations.js.map +1 -1
- package/dist/utils/proof/create-proof.d.ts +5 -0
- package/dist/utils/proof/create-proof.js +5 -0
- package/dist/utils/proof/create-proof.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 +3 -3
- package/dist/utils/report/statistic-data.js.map +1 -1
- package/dist/utils/statistic/report-statistic.d.ts +6 -5
- package/dist/utils/statistic/report-statistic.js +15 -16
- package/dist/utils/statistic/report-statistic.js.map +1 -1
- package/dist/utils/transactions/tx-private-key.d.ts +4 -0
- package/dist/utils/transactions/tx-private-key.js +65 -32
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +6 -3
- package/dist/utils/transactions/tx-wc.js +28 -26
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/transactions/types.d.ts +5 -2
- package/dist/utils/transactions/utils.d.ts +3 -0
- package/dist/utils/transactions/utils.js +33 -0
- package/dist/utils/transactions/utils.js.map +1 -0
- package/dist/utils/wallet-connect.js +6 -4
- package/dist/utils/wallet-connect.js.map +1 -1
- package/dist/version/index.js +1 -1
- package/dist/vitest.config.d.ts +2 -0
- package/dist/vitest.config.js +29 -0
- package/dist/vitest.config.js.map +1 -0
- package/dist/vitest.integration.config.d.ts +2 -0
- package/dist/vitest.integration.config.js +39 -0
- package/dist/vitest.integration.config.js.map +1 -0
- package/package.json +15 -10
- package/dist/abi/defi-wrapper/StvStrategyPool.d.ts +0 -1769
- package/dist/abi/defi-wrapper/StvStrategyPool.js +0 -2319
- package/dist/abi/defi-wrapper/StvStrategyPool.js.map +0 -1
- package/dist/contracts/defi-wrapper/stv-strategy-pool.d.ts +0 -4
- package/dist/contracts/defi-wrapper/stv-strategy-pool.js +0 -11
- package/dist/contracts/defi-wrapper/stv-strategy-pool.js.map +0 -1
- package/dist/features/defi-wrapper-factory.d.ts +0 -18
- package/dist/features/defi-wrapper-factory.js +0 -28
- package/dist/features/defi-wrapper-factory.js.map +0 -1
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/config.d.ts +0 -3
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/config.js +0 -214
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/config.js.map +0 -1
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/index.js.map +0 -1
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/main.d.ts +0 -1
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/main.js +0 -6
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/main.js.map +0 -1
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/read.js +0 -77
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/read.js.map +0 -1
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/write.js +0 -370
- package/dist/programs/defi-wrapper/contracts/stv-strategy-pool/write.js.map +0 -1
- /package/dist/programs/defi-wrapper/{contracts/stv-strategy-pool → use-cases/health}/index.d.ts +0 -0
- /package/dist/programs/defi-wrapper/{contracts/stv-strategy-pool → use-cases/health}/index.js +0 -0
- /package/dist/programs/defi-wrapper/{contracts/stv-strategy-pool → use-cases/health}/read.d.ts +0 -0
- /package/dist/programs/defi-wrapper/{contracts/stv-strategy-pool → use-cases/health}/write.d.ts +0 -0
|
@@ -1,3 +1,13 @@
|
|
|
1
1
|
import { Address } from 'viem';
|
|
2
|
-
|
|
2
|
+
import { PopulatedTx } from '../../utils/index.js';
|
|
3
|
+
export declare const checkIsReportFreshThrowError: ({ vault, }: {
|
|
4
|
+
vault: Address;
|
|
5
|
+
}) => Promise<void>;
|
|
6
|
+
export declare const checkIsReportFresh: ({ vault, populateTx, }: {
|
|
7
|
+
vault: Address;
|
|
8
|
+
populateTx?: boolean;
|
|
9
|
+
}) => Promise<{
|
|
10
|
+
isFresh: boolean;
|
|
11
|
+
data?: PopulatedTx;
|
|
12
|
+
}>;
|
|
3
13
|
export declare const reportFreshWarning: (vault: Address) => Promise<boolean>;
|
|
@@ -1,34 +1,36 @@
|
|
|
1
1
|
import { getVaultHubContract } from '../../contracts/index.js';
|
|
2
|
-
import { callReadMethodSilent, confirmOperation, submitReport, logInfo, } from '../../utils/index.js';
|
|
3
|
-
|
|
2
|
+
import { callReadMethodSilent, confirmOperation, submitReport, logInfo, logError, } from '../../utils/index.js';
|
|
3
|
+
import { checkIsDisconnected } from './connection.js';
|
|
4
|
+
export const checkIsReportFreshThrowError = async ({ vault, }) => {
|
|
4
5
|
const vaultHubContract = await getVaultHubContract();
|
|
5
|
-
const
|
|
6
|
-
const isDisconnected = connection.owner === '0x0000000000000000000000000000000000000000' ||
|
|
7
|
-
connection.vaultIndex === 0n;
|
|
6
|
+
const isDisconnected = await checkIsDisconnected(vault);
|
|
8
7
|
if (isDisconnected) {
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
logError('The vault is disconnected');
|
|
9
|
+
throw new Error(`The vault ${vault} is disconnected`);
|
|
10
|
+
}
|
|
11
|
+
const isReportFresh = await callReadMethodSilent(vaultHubContract, 'isReportFresh', [vault]);
|
|
12
|
+
if (!isReportFresh) {
|
|
13
|
+
logError('The report is not fresh. Submit a fresh report to update the vault data by command: report w submit');
|
|
14
|
+
throw new Error(`The report for vault ${vault} is not fresh`);
|
|
11
15
|
}
|
|
12
|
-
return false;
|
|
13
16
|
};
|
|
14
|
-
export const checkIsReportFresh = async (vault) => {
|
|
17
|
+
export const checkIsReportFresh = async ({ vault, populateTx = false, }) => {
|
|
15
18
|
const vaultHubContract = await getVaultHubContract();
|
|
16
19
|
const isDisconnected = await checkIsDisconnected(vault);
|
|
17
20
|
if (isDisconnected)
|
|
18
|
-
return true;
|
|
21
|
+
return { isFresh: true, data: undefined };
|
|
19
22
|
const isReportFresh = await callReadMethodSilent(vaultHubContract, 'isReportFresh', [vault]);
|
|
20
23
|
if (!isReportFresh) {
|
|
21
24
|
logInfo('The report is not fresh');
|
|
22
25
|
const confirm = await confirmOperation('Do you want to submit a fresh report?');
|
|
23
26
|
if (!confirm)
|
|
24
|
-
return false;
|
|
25
|
-
await submitReport({ vault });
|
|
26
|
-
return
|
|
27
|
+
return { isFresh: false, data: undefined };
|
|
28
|
+
const result = await submitReport({ vault, populateTx });
|
|
29
|
+
return result;
|
|
27
30
|
}
|
|
28
31
|
logInfo('The report is fresh');
|
|
29
|
-
return
|
|
32
|
+
return { isFresh: true, data: undefined };
|
|
30
33
|
};
|
|
31
|
-
``;
|
|
32
34
|
export const reportFreshWarning = async (vault) => {
|
|
33
35
|
const vaultHubContract = await getVaultHubContract();
|
|
34
36
|
const isDisconnected = await checkIsDisconnected(vault);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"report-fresh.js","sourceRoot":"","sources":["../../../features/utils/report-fresh.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,YAAY,EACZ,OAAO,
|
|
1
|
+
{"version":3,"file":"report-fresh.js","sourceRoot":"","sources":["../../../features/utils/report-fresh.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,15 @@
|
|
|
1
|
-
import { Address } from 'viem';
|
|
1
|
+
import { Address, Hex, TransactionReceipt } from 'viem';
|
|
2
2
|
import { RoleAssignment, VaultWithDashboard } from '../types/index.js';
|
|
3
|
+
export type CreateVaultResult = {
|
|
4
|
+
vault: Address;
|
|
5
|
+
dashboard: Address;
|
|
6
|
+
owner: Address;
|
|
7
|
+
nodeOperator: Address;
|
|
8
|
+
nodeOperatorManager: readonly Address[];
|
|
9
|
+
tx: Hex;
|
|
10
|
+
blockNumber: bigint;
|
|
11
|
+
};
|
|
12
|
+
export declare const isCreateVaultResult: (result: Pick<CreateVaultResult, "tx"> | CreateVaultResult | undefined) => result is CreateVaultResult;
|
|
3
13
|
export declare const prepareCreateVaultPayload: (args: {
|
|
4
14
|
defaultAdmin: Address;
|
|
5
15
|
nodeOperator: Address;
|
|
@@ -13,17 +23,6 @@ export declare const prepareCreateVaultPayload: (args: {
|
|
|
13
23
|
list: number[];
|
|
14
24
|
otherRoles: RoleAssignment[];
|
|
15
25
|
} | undefined;
|
|
16
|
-
export declare const createVault: (payload: VaultWithDashboard, otherRoles?: RoleAssignment[], methodName?: "createVaultWithDashboard" | "createVaultWithDashboardWithoutConnectingToVaultHub") => Promise<
|
|
17
|
-
|
|
18
|
-
vault?: undefined;
|
|
19
|
-
dashboard?: undefined;
|
|
20
|
-
owner?: undefined;
|
|
21
|
-
blockNumber?: undefined;
|
|
22
|
-
} | {
|
|
23
|
-
vault: `0x${string}` | undefined;
|
|
24
|
-
dashboard: `0x${string}` | undefined;
|
|
25
|
-
owner: `0x${string}` | undefined;
|
|
26
|
-
tx: `0x${string}` | undefined;
|
|
27
|
-
blockNumber: bigint;
|
|
28
|
-
} | undefined>;
|
|
26
|
+
export declare const createVault: (payload: VaultWithDashboard, otherRoles?: RoleAssignment[], methodName?: "createVaultWithDashboard" | "createVaultWithDashboardWithoutConnectingToVaultHub") => Promise<Pick<CreateVaultResult, "tx"> | CreateVaultResult | undefined>;
|
|
27
|
+
export declare const getCreateVaultEventData: (receipt: TransactionReceipt, tx: Hex) => Promise<CreateVaultResult>;
|
|
29
28
|
export declare const getVaultFactoryInfo: () => Promise<void>;
|
|
@@ -1,8 +1,11 @@
|
|
|
1
|
-
import { parseEventLogs, parseEther } from 'viem';
|
|
2
|
-
import { getVaultFactoryContract } from '../contracts/index.js';
|
|
1
|
+
import { parseEventLogs, parseEther, } from 'viem';
|
|
2
|
+
import { getDashboardContract, getStakingVaultContract, getVaultFactoryContract, } from '../contracts/index.js';
|
|
3
3
|
import { VaultFactoryAbi } from '../abi/index.js';
|
|
4
|
-
import { callWriteMethodWithReceipt, logResult, printError, showSpinner, logError, transformAddressesToArray, validateAddressesMap, validateAddressMap, logInfo, } from '../utils/index.js';
|
|
4
|
+
import { callWriteMethodWithReceipt, logResult, printError, showSpinner, logError, transformAddressesToArray, validateAddressesMap, validateAddressMap, logInfo, callReadMethodSilent, } from '../utils/index.js';
|
|
5
5
|
import { program } from '../command/index.js';
|
|
6
|
+
export const isCreateVaultResult = (result) => {
|
|
7
|
+
return result !== undefined && 'vault' in result;
|
|
8
|
+
};
|
|
6
9
|
export const prepareCreateVaultPayload = (args) => {
|
|
7
10
|
const { defaultAdmin, nodeOperator, nodeOperatorManager, nodeOperatorFeeRate, confirmExpiry, quantity, roles, } = args;
|
|
8
11
|
const qnt = parseInt(quantity);
|
|
@@ -37,7 +40,7 @@ export const prepareCreateVaultPayload = (args) => {
|
|
|
37
40
|
};
|
|
38
41
|
};
|
|
39
42
|
export const createVault = async (payload, otherRoles = [], methodName = 'createVaultWithDashboard') => {
|
|
40
|
-
const contract = getVaultFactoryContract();
|
|
43
|
+
const contract = await getVaultFactoryContract();
|
|
41
44
|
const { defaultAdmin, nodeOperator, nodeOperatorManager, nodeOperatorFeeRate, confirmExpiry, } = payload;
|
|
42
45
|
const isNeedValue = methodName === 'createVaultWithDashboard';
|
|
43
46
|
const result = await callWriteMethodWithReceipt({
|
|
@@ -53,17 +56,22 @@ export const createVault = async (payload, otherRoles = [], methodName = 'create
|
|
|
53
56
|
],
|
|
54
57
|
value: isNeedValue ? parseEther('1') : undefined,
|
|
55
58
|
});
|
|
56
|
-
if (!result)
|
|
57
|
-
|
|
58
|
-
|
|
59
|
+
if (!result) {
|
|
60
|
+
throw new Error('Transaction failed');
|
|
61
|
+
}
|
|
62
|
+
if (program.opts().populateTx && result.tx) {
|
|
59
63
|
return { tx: result.tx };
|
|
60
64
|
}
|
|
61
65
|
const { receipt, tx } = result;
|
|
62
66
|
// Gnosis safe case
|
|
63
|
-
if (!receipt) {
|
|
64
|
-
logInfo('Transaction has been sent');
|
|
67
|
+
if (!receipt || !tx) {
|
|
68
|
+
logInfo('Transaction has been sent. Use "vault-operations write create-vault log-creating-vault-data" command to get the Vault data after the transaction is signed and executed');
|
|
65
69
|
return;
|
|
66
70
|
}
|
|
71
|
+
const eventData = await getCreateVaultEventData(receipt, tx);
|
|
72
|
+
return eventData;
|
|
73
|
+
};
|
|
74
|
+
export const getCreateVaultEventData = async (receipt, tx) => {
|
|
67
75
|
const events = parseEventLogs({
|
|
68
76
|
abi: VaultFactoryAbi,
|
|
69
77
|
logs: receipt.logs,
|
|
@@ -73,21 +81,35 @@ export const createVault = async (payload, otherRoles = [], methodName = 'create
|
|
|
73
81
|
const dashboardEvent = events.find((event) => event.eventName === 'DashboardCreated');
|
|
74
82
|
const dashboard = dashboardEvent?.args.dashboard;
|
|
75
83
|
const owner = dashboardEvent?.args.admin;
|
|
84
|
+
if (!vault || !dashboard || !owner) {
|
|
85
|
+
throw new Error('Vault, dashboard or owner not found');
|
|
86
|
+
}
|
|
87
|
+
const dashboardContract = await getDashboardContract(dashboard);
|
|
88
|
+
const vaultContract = await getStakingVaultContract(vault);
|
|
89
|
+
const [nodeOperator, nodeOperatorManagerRole] = await Promise.all([
|
|
90
|
+
callReadMethodSilent(vaultContract, 'nodeOperator'),
|
|
91
|
+
callReadMethodSilent(dashboardContract, 'NODE_OPERATOR_MANAGER_ROLE'),
|
|
92
|
+
]);
|
|
93
|
+
const nodeOperatorManager = await callReadMethodSilent(dashboardContract, 'getRoleMembers', [nodeOperatorManagerRole]);
|
|
76
94
|
return {
|
|
77
95
|
vault,
|
|
78
96
|
dashboard,
|
|
79
97
|
owner,
|
|
98
|
+
nodeOperator,
|
|
99
|
+
nodeOperatorManager,
|
|
80
100
|
tx,
|
|
81
101
|
blockNumber: receipt.blockNumber,
|
|
82
102
|
};
|
|
83
103
|
};
|
|
84
104
|
export const getVaultFactoryInfo = async () => {
|
|
85
|
-
const contract = getVaultFactoryContract();
|
|
105
|
+
const contract = await getVaultFactoryContract();
|
|
86
106
|
const hideSpinner = showSpinner();
|
|
87
107
|
try {
|
|
88
108
|
const BEACON = await contract.read.BEACON();
|
|
89
109
|
const LIDO_LOCATOR = await contract.read.LIDO_LOCATOR();
|
|
110
|
+
const CONTRACT_ADDRESS = contract.address;
|
|
90
111
|
const payload = {
|
|
112
|
+
CONTRACT_ADDRESS,
|
|
91
113
|
BEACON,
|
|
92
114
|
LIDO_LOCATOR,
|
|
93
115
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-factory.js","sourceRoot":"","sources":["../../features/vault-factory.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"vault-factory.js","sourceRoot":"","sources":["../../features/vault-factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,cAAc,EACd,UAAU,GAGX,MAAM,MAAM,CAAC;AAGd,OAAO,EACL,oBAAoB,EACpB,uBAAuB,EACvB,uBAAuB,GACxB,MAAM,WAAW,CAAC;AACnB,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,EAClB,OAAO,EACP,oBAAoB,GACrB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAYlC,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,MAAqE,EACxC,EAAE;IAC/B,OAAO,MAAM,KAAK,SAAS,IAAI,OAAO,IAAI,MAAM,CAAC;AACnD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,IAQzC,EAAE,EAAE;IACH,MAAM,EACJ,YAAY,EACZ,YAAY,EACZ,mBAAmB,EACnB,mBAAmB,EACnB,aAAa,EACb,QAAQ,EACR,KAAK,GACN,GAAG,IAAI,CAAC;IAET,MAAM,GAAG,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC/B,MAAM,UAAU,GAAG,KAAK,IAAI,EAAE,CAAC;IAE/B,IAAI,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;QACf,QAAQ,CAAC,2BAA2B,CAAC,CAAC;QACtC,OAAO;IACT,CAAC;IAED,MAAM,SAAS,GAAG,yBAAyB,CAAC,UAAU,CAAC,CAAC;IAExD,MAAM,mBAAmB,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAC5D,MAAM,UAAU,GAAG;QACjB,GAAG,mBAAmB;QACtB,GAAG,kBAAkB,CAAC,CAAC,YAAY,EAAE,YAAY,EAAE,mBAAmB,CAAC,CAAC;KACzE,CAAC;IACF,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1B,UAAU,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QACpD,OAAO;IACT,CAAC;IAED,oDAAoD;IACpD,MAAM,IAAI,GAAa,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;IAC9C,MAAM,OAAO,GAAG;QACd,YAAY;QACZ,YAAY;QACZ,mBAAmB;QACnB,aAAa,EAAE,MAAM,CAAC,aAAa,CAAC;QACpC,mBAAmB,EAAE,MAAM,CAAC,mBAAmB,CAAC;KAC3B,CAAC;IAExB,OAAO;QACL,OAAO;QACP,IAAI;QACJ,UAAU;KACX,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,KAAK,EAC9B,OAA2B,EAC3B,aAA+B,EAAE,EACjC,aAE4D,0BAA0B,EACd,EAAE;IAC1E,MAAM,QAAQ,GAAG,MAAM,uBAAuB,EAAE,CAAC;IAEjD,MAAM,EACJ,YAAY,EACZ,YAAY,EACZ,mBAAmB,EACnB,mBAAmB,EACnB,aAAa,GACd,GAAG,OAAO,CAAC;IAEZ,MAAM,WAAW,GAAG,UAAU,KAAK,0BAA0B,CAAC;IAE9D,MAAM,MAAM,GAAG,MAAM,0BAA0B,CAAC;QAC9C,QAAQ;QACR,UAAU;QACV,OAAO,EAAE;YACP,YAAY;YACZ,YAAY;YACZ,mBAAmB;YACnB,mBAAmB;YACnB,aAAa;YACb,UAAU;SACX;QACD,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS;KACjD,CAAC,CAAC;IACH,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACxC,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,UAAU,IAAI,MAAM,CAAC,EAAE,EAAE,CAAC;QAC3C,OAAO,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,EAAE,CAAC;IAC3B,CAAC;IACD,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,GAAG,MAAM,CAAC;IAE/B,mBAAmB;IACnB,IAAI,CAAC,OAAO,IAAI,CAAC,EAAE,EAAE,CAAC;QACpB,OAAO,CACL,yKAAyK,CAC1K,CAAC;QACF,OAAO;IACT,CAAC;IAED,MAAM,SAAS,GAAG,MAAM,uBAAuB,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAE7D,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,KAAK,EAC1C,OAA2B,EAC3B,EAAO,EACqB,EAAE;IAC9B,MAAM,MAAM,GAAG,cAAc,CAAC;QAC5B,GAAG,EAAE,eAAe;QACpB,IAAI,EAAE,OAAO,CAAC,IAAI;KACnB,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,cAAc,CAAC,CAAC;IAC9E,MAAM,KAAK,GAAG,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC;IAErC,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAChC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,kBAAkB,CAClD,CAAC;IACF,MAAM,SAAS,GAAG,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC;IACjD,MAAM,KAAK,GAAG,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC;IAEzC,IAAI,CAAC,KAAK,IAAI,CAAC,SAAS,IAAI,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;IACzD,CAAC;IAED,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAChE,MAAM,aAAa,GAAG,MAAM,uBAAuB,CAAC,KAAK,CAAC,CAAC;IAC3D,MAAM,CAAC,YAAY,EAAE,uBAAuB,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QAChE,oBAAoB,CAAC,aAAa,EAAE,cAAc,CAAC;QACnD,oBAAoB,CAAC,iBAAiB,EAAE,4BAA4B,CAAC;KACtE,CAAC,CAAC;IACH,MAAM,mBAAmB,GAAG,MAAM,oBAAoB,CACpD,iBAAiB,EACjB,gBAAgB,EAChB,CAAC,uBAAuB,CAAC,CAC1B,CAAC;IAEF,OAAO;QACL,KAAK;QACL,SAAS;QACT,KAAK;QACL,YAAY;QACZ,mBAAmB;QACnB,EAAE;QACF,WAAW,EAAE,OAAO,CAAC,WAAW;KACjC,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,IAAI,EAAE;IAC5C,MAAM,QAAQ,GAAG,MAAM,uBAAuB,EAAE,CAAC;IACjD,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QAC5C,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QACxD,MAAM,gBAAgB,GAAG,QAAQ,CAAC,OAAO,CAAC;QAE1C,MAAM,OAAO,GAAG;YACd,gBAAgB;YAChB,MAAM;YACN,YAAY;SACb,CAAC;QAEF,WAAW,EAAE,CAAC;QAEd,SAAS,CAAC;YACR,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SAClE,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,WAAW,EAAE,CAAC;QACd,UAAU,CAAC,GAAG,EAAE,8BAA8B,CAAC,CAAC;IAClD,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
import { callReadMethodSilent, confirmOperation, logInfo } from '../../utils/index.js';
|
|
3
|
+
import { getStakingVaultContract, getVaultHubContract } from '../../contracts/index.js';
|
|
4
|
+
export const checkVaultAvailableBalance = async (vault) => {
|
|
5
|
+
const vaultHub = await getVaultHubContract();
|
|
6
|
+
const connectDeposit = await callReadMethodSilent(vaultHub, 'CONNECT_DEPOSIT');
|
|
7
|
+
const vaultContract = await getStakingVaultContract(vault);
|
|
8
|
+
const availableBalance = await callReadMethodSilent(vaultContract, 'availableBalance');
|
|
9
|
+
if (availableBalance < connectDeposit) {
|
|
10
|
+
logInfo(`⚠️ Vault available balance is less than connect deposit:
|
|
11
|
+
Available balance: ${formatEther(availableBalance)} ETH
|
|
12
|
+
Connect deposit: ${formatEther(connectDeposit)} ETH`);
|
|
13
|
+
const confirm = await confirmOperation(`Do you want to fund the vault with ${formatEther(connectDeposit)} ETH?`);
|
|
14
|
+
if (!confirm) {
|
|
15
|
+
throw new Error('Vault available balance is less than connect deposit');
|
|
16
|
+
}
|
|
17
|
+
return { isFundConfirmed: true };
|
|
18
|
+
}
|
|
19
|
+
return { isFundConfirmed: false };
|
|
20
|
+
};
|
|
21
|
+
//# sourceMappingURL=connect-vault.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connect-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/connect-vault.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACxE,OAAO,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAEzE,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,EAC7C,KAAc,EACyB,EAAE;IACzC,MAAM,QAAQ,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC7C,MAAM,cAAc,GAAG,MAAM,oBAAoB,CAC/C,QAAQ,EACR,iBAAiB,CAClB,CAAC;IAEF,MAAM,aAAa,GAAG,MAAM,uBAAuB,CAAC,KAAK,CAAC,CAAC;IAC3D,MAAM,gBAAgB,GAAG,MAAM,oBAAoB,CACjD,aAAa,EACb,kBAAkB,CACnB,CAAC;IAEF,IAAI,gBAAgB,GAAG,cAAc,EAAE,CAAC;QACtC,OAAO,CACL;6BACuB,WAAW,CAAC,gBAAgB,CAAC;2BAC/B,WAAW,CAAC,cAAc,CAAC,MAAM,CACvD,CAAC;QACF,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,sCAAsC,WAAW,CAAC,cAAc,CAAC,OAAO,CACzE,CAAC;QACF,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QAED,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;IACnC,CAAC;IAED,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC;AACpC,CAAC,CAAC"}
|
|
@@ -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,8 +1,13 @@
|
|
|
1
|
+
import { hoodi } from 'viem/chains';
|
|
2
|
+
import { getChain } from '../../configs/index.js';
|
|
1
3
|
import { numberPrompt, selectPrompt } from '../../utils/index.js';
|
|
2
4
|
const MIN_CONFIRM_EXPIRY = 24 * 60 * 60; // 24 hours
|
|
5
|
+
const MIN_CONFIRM_EXPIRY_TESTNET = 1 * 60 * 60; // 1 hour
|
|
3
6
|
const MAX_CONFIRM_EXPIRY = 24 * 60 * 60 * 30; // 30 days
|
|
4
|
-
const validateConfirmExpiry = (confirmExpiry) => {
|
|
5
|
-
const minInHours =
|
|
7
|
+
const validateConfirmExpiry = (confirmExpiry, isTestnet = false) => {
|
|
8
|
+
const minInHours = isTestnet
|
|
9
|
+
? MIN_CONFIRM_EXPIRY_TESTNET / 3600
|
|
10
|
+
: MIN_CONFIRM_EXPIRY / 3600;
|
|
6
11
|
const maxInHours = MAX_CONFIRM_EXPIRY / 3600;
|
|
7
12
|
if (confirmExpiry < minInHours)
|
|
8
13
|
throw new Error(`Confirm expiry must be greater than ${minInHours} hours. Current value: ${confirmExpiry} hours (${confirmExpiry * 3600} seconds)`);
|
|
@@ -23,15 +28,20 @@ const validateNodeOperatorFeeRate = (nodeOperatorFeeRate, type) => {
|
|
|
23
28
|
if (type === 'percentage' && nodeOperatorFeeRate % 1 !== 0)
|
|
24
29
|
throw new Error(`Node operator fee rate must be a whole number. Current value: ${nodeOperatorFeeRate}`);
|
|
25
30
|
};
|
|
26
|
-
export const getConfirmExpiry = async (confirmExpiry) => {
|
|
31
|
+
export const getConfirmExpiry = async ({ confirmExpiry, }) => {
|
|
32
|
+
const chain = await getChain();
|
|
33
|
+
const isTestnet = chain.id === hoodi.id;
|
|
34
|
+
const minConfirmExpiry = isTestnet
|
|
35
|
+
? MIN_CONFIRM_EXPIRY_TESTNET
|
|
36
|
+
: MIN_CONFIRM_EXPIRY;
|
|
27
37
|
if (!confirmExpiry) {
|
|
28
|
-
const confirmExpiryValue = await numberPrompt(
|
|
38
|
+
const confirmExpiryValue = await numberPrompt(`Enter the confirm expiry (in hours) (min: ${minConfirmExpiry / 3600} hours, max: ${MAX_CONFIRM_EXPIRY / 3600} hours)`, 'value');
|
|
29
39
|
if (!confirmExpiryValue.value)
|
|
30
40
|
throw new Error('Invalid confirm expiry');
|
|
31
|
-
validateConfirmExpiry(confirmExpiryValue.value);
|
|
41
|
+
validateConfirmExpiry(confirmExpiryValue.value, isTestnet);
|
|
32
42
|
return confirmExpiryValue.value * 3600;
|
|
33
43
|
}
|
|
34
|
-
validateConfirmExpiry(confirmExpiry / 3600);
|
|
44
|
+
validateConfirmExpiry(confirmExpiry / 3600, isTestnet);
|
|
35
45
|
return confirmExpiry;
|
|
36
46
|
};
|
|
37
47
|
export const getNodeOperatorFeeRate = async (nodeOperatorFeeRate) => {
|
|
@@ -42,7 +52,7 @@ export const getNodeOperatorFeeRate = async (nodeOperatorFeeRate) => {
|
|
|
42
52
|
]);
|
|
43
53
|
if (!chooseFeeType.feeType)
|
|
44
54
|
throw new Error('Invalid fee type');
|
|
45
|
-
const nodeOperatorFeeRateValue = await numberPrompt(`Enter the node operator fee rate (in ${chooseFeeType.feeType})`, 'value');
|
|
55
|
+
const nodeOperatorFeeRateValue = await numberPrompt(`Enter the node operator fee rate (in ${chooseFeeType.feeType}) (max: ${chooseFeeType.feeType === 'basis points' ? 10000 : 100})`, 'value');
|
|
46
56
|
if (!nodeOperatorFeeRateValue.value)
|
|
47
57
|
throw new Error('Invalid node operator fee rate');
|
|
48
58
|
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,CAAC,WAAW;AACpD,MAAM,kBAAkB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,UAAU;AAExD,MAAM,qBAAqB,GAAG,CAAC,aAAqB,EAAE,EAAE;
|
|
1
|
+
{"version":3,"file":"create-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/create-vault.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,26 @@
|
|
|
1
1
|
import { getDashboardContract, getStakingVaultContract, getVaultHubContract, } from '../../contracts/index.js';
|
|
2
2
|
import { getPublicClient } from '../../providers/index.js';
|
|
3
|
-
import { callReadMethodSilent, enterContractAddress } from '../../utils/index.js';
|
|
3
|
+
import { callReadMethodSilent, confirmOperation, enterContractAddress, } from '../../utils/index.js';
|
|
4
|
+
import { checkIsDisconnected } from '../index.js';
|
|
4
5
|
import { chooseVault } from './vaults-by-role.js';
|
|
5
6
|
export const getDashboardByVault = async (vault) => {
|
|
6
|
-
const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
7
|
+
const isDisconnected = await checkIsDisconnected(vault);
|
|
8
|
+
let vaultOwner;
|
|
9
|
+
if (isDisconnected) {
|
|
10
|
+
const confirm = await confirmOperation('Vault is not connected to VaultHub. Do you want to continue executing the command?');
|
|
11
|
+
if (!confirm) {
|
|
12
|
+
throw new Error('Vault is not connected to VaultHub');
|
|
13
|
+
}
|
|
14
|
+
const vaultContract = await getStakingVaultContract(vault);
|
|
15
|
+
vaultOwner = await callReadMethodSilent(vaultContract, 'owner');
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
const vaultHub = await getVaultHubContract();
|
|
19
|
+
const vaultConnection = await callReadMethodSilent(vaultHub, 'vaultConnection', [vault]);
|
|
20
|
+
vaultOwner = vaultConnection.owner;
|
|
21
|
+
}
|
|
22
|
+
const dashboard = await getDashboardContract(vaultOwner);
|
|
23
|
+
const publicClient = await getPublicClient();
|
|
11
24
|
const bytecode = await publicClient.getCode({ address: vaultOwner });
|
|
12
25
|
if (!bytecode || bytecode === '0x') {
|
|
13
26
|
throw new Error(`Owner ${vaultOwner} is not a contract (probably EOA)`);
|
|
@@ -24,8 +37,8 @@ export const chooseVaultAndGetDashboard = async (args) => {
|
|
|
24
37
|
chosenVault = vault ?? (await chooseVault());
|
|
25
38
|
}
|
|
26
39
|
const dashboard = await getDashboardByVault(chosenVault);
|
|
27
|
-
const dashboardContract = getDashboardContract(dashboard);
|
|
28
|
-
const vaultContract = getStakingVaultContract(chosenVault);
|
|
40
|
+
const dashboardContract = await getDashboardContract(dashboard);
|
|
41
|
+
const vaultContract = await getStakingVaultContract(chosenVault);
|
|
29
42
|
return {
|
|
30
43
|
address: dashboard,
|
|
31
44
|
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,
|
|
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,EACL,oBAAoB,EACpB,gBAAgB,EAChB,oBAAoB,GACrB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAE/C,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EAAE,KAAc,EAAE,EAAE;IAC1D,MAAM,cAAc,GAAG,MAAM,mBAAmB,CAAC,KAAK,CAAC,CAAC;IACxD,IAAI,UAAmB,CAAC;IAExB,IAAI,cAAc,EAAE,CAAC;QACnB,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oFAAoF,CACrF,CAAC;QACF,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAC;QACxD,CAAC;QAED,MAAM,aAAa,GAAG,MAAM,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAC3D,UAAU,GAAG,MAAM,oBAAoB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAClE,CAAC;SAAM,CAAC;QACN,MAAM,QAAQ,GAAG,MAAM,mBAAmB,EAAE,CAAC;QAC7C,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAChD,QAAQ,EACR,iBAAiB,EACjB,CAAC,KAAK,CAAC,CACR,CAAC;QAEF,UAAU,GAAG,eAAe,CAAC,KAAK,CAAC;IACrC,CAAC;IAED,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"}
|
|
@@ -1 +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"}
|
|
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;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { DashboardContract } from '../../contracts/index.js';
|
|
2
|
+
import { RoleName } from './vault-roles.js';
|
|
3
|
+
import { RoleAssignment } from '../../types/index.js';
|
|
4
|
+
export declare const logRolesOperations: (contract: DashboardContract, roleAssignment: RoleAssignment[], operation: "grant" | "revoke") => Promise<boolean>;
|
|
5
|
+
export declare const askRoleOperationInfo: (contract: DashboardContract, operation: "grant" | "revoke", rolesOverride?: RoleName[]) => Promise<RoleAssignment[]>;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { DASHBOARD_ROLES_KEYS } from './vault-roles.js';
|
|
2
|
+
import { addressPrompt, callReadMethodSilent, confirmOperation, confirmPrompt, selectPrompt, } from '../../utils/index.js';
|
|
3
|
+
const getRoleNameByKeccak = async (contract, rolesKeccak) => {
|
|
4
|
+
const roleValues = await Promise.all(DASHBOARD_ROLES_KEYS.map((key) => contract.read[key]()));
|
|
5
|
+
const roles = Object.fromEntries(DASHBOARD_ROLES_KEYS.map((key, index) => [key, roleValues[index]]));
|
|
6
|
+
const rolesNames = rolesKeccak
|
|
7
|
+
.map((keccak) => {
|
|
8
|
+
const roleName = Object.keys(roles).find((name) => roles[name] === keccak);
|
|
9
|
+
return roleName;
|
|
10
|
+
})
|
|
11
|
+
.filter((roleName) => roleName !== undefined);
|
|
12
|
+
return rolesNames;
|
|
13
|
+
};
|
|
14
|
+
const getKeccakByRoleName = async (contract, roleName) => {
|
|
15
|
+
const roleKeccak = await Promise.all(roleName.map((name) => callReadMethodSilent(contract, name)));
|
|
16
|
+
return Object.fromEntries(roleName.map((name, index) => [name, roleKeccak[index]]));
|
|
17
|
+
};
|
|
18
|
+
export const logRolesOperations = async (contract, roleAssignment, operation) => {
|
|
19
|
+
const rolesNames = await getRoleNameByKeccak(contract, roleAssignment.map((role) => role.role));
|
|
20
|
+
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
21
|
+
const addressesWithRoles = roleAssignment.map((role, index) => ({
|
|
22
|
+
address: role.account,
|
|
23
|
+
role: rolesNames[index],
|
|
24
|
+
}));
|
|
25
|
+
const roleList = addressesWithRoles
|
|
26
|
+
.map((role) => `${role.role}: ${role.address}`)
|
|
27
|
+
.join('\n');
|
|
28
|
+
const message = 'Are you sure you want to ' +
|
|
29
|
+
operation +
|
|
30
|
+
' the roles ' +
|
|
31
|
+
'\n' +
|
|
32
|
+
roleList +
|
|
33
|
+
'\n' +
|
|
34
|
+
' in the vault ' +
|
|
35
|
+
vault +
|
|
36
|
+
` (dashboard: ${contract.address})?`;
|
|
37
|
+
const confirm = await confirmOperation(message);
|
|
38
|
+
return confirm;
|
|
39
|
+
};
|
|
40
|
+
export const askRoleOperationInfo = async (contract, operation, rolesOverride) => {
|
|
41
|
+
const role = await selectPrompt('Select the role to ' + operation, 'value', (rolesOverride ?? DASHBOARD_ROLES_KEYS).map((role) => ({
|
|
42
|
+
title: role,
|
|
43
|
+
value: role,
|
|
44
|
+
})));
|
|
45
|
+
const rolesRemaining = (rolesOverride ?? DASHBOARD_ROLES_KEYS).filter((item) => item !== role.value);
|
|
46
|
+
if (!role.value)
|
|
47
|
+
throw new Error('No role selected');
|
|
48
|
+
const address = await addressPrompt('Enter the address to ' + operation + ' the role ' + role.value, 'value');
|
|
49
|
+
if (!address.value)
|
|
50
|
+
throw new Error('No address entered');
|
|
51
|
+
const isMore = await confirmPrompt('Do you want to ' + operation + ' more roles? (y/n)', 'value');
|
|
52
|
+
const roleKeccak = await getKeccakByRoleName(contract, [role.value]);
|
|
53
|
+
const roleKeccakValue = roleKeccak[role.value];
|
|
54
|
+
if (!roleKeccakValue) {
|
|
55
|
+
throw new Error('No role keccak found for role: ' + role.value);
|
|
56
|
+
}
|
|
57
|
+
if (isMore.value) {
|
|
58
|
+
return [
|
|
59
|
+
...(await askRoleOperationInfo(contract, operation, rolesRemaining)),
|
|
60
|
+
{ role: roleKeccakValue, account: address.value },
|
|
61
|
+
];
|
|
62
|
+
}
|
|
63
|
+
return [{ role: roleKeccakValue, account: address.value }];
|
|
64
|
+
};
|
|
65
|
+
//# sourceMappingURL=roles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"roles.js","sourceRoot":"","sources":["../../../features/vault-operations/roles.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,11 +2,13 @@ import { formatEther } from 'viem';
|
|
|
2
2
|
import { formatBP, logInfo, logTable, logResult, showSpinner, printError, callReadMethodSilent, } from '../../utils/index.js';
|
|
3
3
|
import { getPublicClient } from '../../providers/index.js';
|
|
4
4
|
import { reportFreshWarning } from '../index.js';
|
|
5
|
+
import { getStakingVaultContract } from '../../contracts/index.js';
|
|
5
6
|
export const getVaultInfoByDashboard = async (contract) => {
|
|
6
7
|
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
8
|
+
const vaultContract = await getStakingVaultContract(vault);
|
|
7
9
|
await reportFreshWarning(vault);
|
|
8
10
|
const hideSpinner = showSpinner();
|
|
9
|
-
const publicClient = getPublicClient();
|
|
11
|
+
const publicClient = await getPublicClient();
|
|
10
12
|
try {
|
|
11
13
|
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
14
|
contract.read.STETH(),
|
|
@@ -30,9 +32,12 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
30
32
|
contract.read.MAX_CONFIRM_EXPIRY(),
|
|
31
33
|
contract.read.MIN_CONFIRM_EXPIRY(),
|
|
32
34
|
]);
|
|
33
|
-
const balance = await
|
|
34
|
-
|
|
35
|
-
|
|
35
|
+
const [balance, nodeOperator] = await Promise.all([
|
|
36
|
+
publicClient.getBalance({
|
|
37
|
+
address: vault,
|
|
38
|
+
}),
|
|
39
|
+
callReadMethodSilent(vaultContract, 'nodeOperator'),
|
|
40
|
+
]);
|
|
36
41
|
hideSpinner();
|
|
37
42
|
logResult({});
|
|
38
43
|
logInfo('Dashboard Base Info');
|
|
@@ -44,6 +49,7 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
44
49
|
['LIDO Locator address', lidoLocator],
|
|
45
50
|
['stETH address', steth],
|
|
46
51
|
['wstETH address', wsteth],
|
|
52
|
+
['Node Operator', nodeOperator],
|
|
47
53
|
['Reserve Ratio, BP', vaultConnection.reserveRatioBP],
|
|
48
54
|
['Reserve Ratio, %', formatBP(vaultConnection.reserveRatioBP)],
|
|
49
55
|
[
|
|
@@ -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;
|
|
1
|
+
{"version":3,"file":"vault-info.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-info.ts"],"names":[],"mappings":"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"}
|