@lidofinance/lsv-cli 1.0.0 → 1.2.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/dist/abi/AccessControlConfirmable.d.ts +3 -2
- package/dist/abi/AccessControlConfirmable.js +3 -1
- package/dist/abi/AccessControlConfirmable.js.map +1 -1
- package/dist/abi/Dashboard.d.ts +87 -30
- package/dist/abi/Dashboard.js +46 -32
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.d.ts +408 -3
- package/dist/abi/LazyOracle.js +59 -3
- package/dist/abi/LazyOracle.js.map +1 -1
- package/dist/abi/OperatorGrid.d.ts +52 -0
- package/dist/abi/OperatorGrid.js +16 -0
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/PredepositGuarantee.d.ts +28 -0
- package/dist/abi/StakingVault.d.ts +56 -0
- package/dist/abi/StakingVault.js +2 -0
- package/dist/abi/StakingVault.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 +48 -4
- package/dist/abi/VaultHub.d.ts +38 -0
- 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/abi/index.d.ts +1 -0
- package/dist/abi/index.js +1 -0
- package/dist/abi/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 +48 -6
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/utils.d.ts +2 -0
- package/dist/configs/utils.js +12 -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 +2 -0
- package/dist/contracts/index.js +2 -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 -27674
- 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/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 +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/index.d.ts +1 -0
- package/dist/features/deposits/index.js +1 -0
- package/dist/features/deposits/index.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/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/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 +4 -0
- package/dist/features/index.js +4 -0
- package/dist/features/index.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.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 +9 -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 +1 -0
- package/dist/features/utils/index.js +1 -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 +19 -3
- package/dist/features/utils/report-fresh.js.map +1 -1
- 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 +2 -2
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +10 -12
- 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 +25 -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 +13 -4
- 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 -0
- package/dist/programs/contracts/dashboard/config.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 +85 -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 +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 +4 -6
- package/dist/programs/contracts/pdg/read.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +76 -10
- 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/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 +22 -18
- 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 +8 -4
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/write.js +141 -16
- 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 +38 -33
- 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/providers/wallet.d.ts +6986 -171
- package/dist/providers/wallet.js +15 -5
- package/dist/providers/wallet.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/types/config.d.ts +1 -0
- package/dist/utils/arguments.d.ts +8 -0
- package/dist/utils/arguments.js +56 -4
- 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.js +1 -2
- package/dist/utils/calculate-overview-v2.js.map +1 -1
- package/dist/utils/calculate-overview.js +1 -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 +1 -1
- package/dist/utils/commands/report.js +3 -2
- 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 +41 -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 +40 -0
- package/dist/utils/consolidation/pubkeys.js.map +1 -0
- package/dist/utils/consolidation/types.d.ts +11 -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 +34 -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/fetchCL.d.ts +36 -19
- package/dist/utils/fetchCL.js +82 -11
- 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/index.d.ts +1 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.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 +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 +2 -2
- package/dist/utils/transactions/tx-private-key.js +14 -9
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +32 -2
- package/dist/utils/transactions/tx-wc.js +61 -33
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/transactions/types.d.ts +4 -2
- 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
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Option } from 'commander';
|
|
2
|
+
import { logInfo, getCommandsJson } from '../../../../utils/index.js';
|
|
3
|
+
import { wrapperOperations } from './main.js';
|
|
4
|
+
export const wrapperOperationsWrite = wrapperOperations
|
|
5
|
+
.command('write')
|
|
6
|
+
.aliases(['w'])
|
|
7
|
+
.description('wrapper operations write commands');
|
|
8
|
+
wrapperOperationsWrite.addOption(new Option('-cmd2json'));
|
|
9
|
+
wrapperOperationsWrite.on('option:-cmd2json', function () {
|
|
10
|
+
logInfo(getCommandsJson(wrapperOperationsWrite));
|
|
11
|
+
process.exit();
|
|
12
|
+
});
|
|
13
|
+
//# sourceMappingURL=write.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../../../programs/defi-wrapper/use-cases/wrapper-operations/write.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,OAAO,CAAC;AACjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,WAAW,CAAC;AAE9C,MAAM,CAAC,MAAM,sBAAsB,GAAG,iBAAiB;KACpD,OAAO,CAAC,OAAO,CAAC;KAChB,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC;KACd,WAAW,CAAC,mCAAmC,CAAC,CAAC;AAEpD,sBAAsB,CAAC,SAAS,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;AAC1D,sBAAsB,CAAC,EAAE,CAAC,kBAAkB,EAAE;IAC5C,OAAO,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC,CAAC;IACjD,OAAO,CAAC,IAAI,EAAE,CAAC;AACjB,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../programs/dev-tools/anvil/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const anvil: import("commander").Command;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../programs/dev-tools/anvil/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,CAAC,MAAM,KAAK,GAAG,QAAQ;KAC1B,OAAO,CAAC,OAAO,CAAC;KAChB,WAAW,CAAC,iDAAiD,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { spawn } from 'child_process';
|
|
2
|
+
import { logInfo, logError } from '../../../utils/index.js';
|
|
3
|
+
import { anvil } from './main.js';
|
|
4
|
+
import { getChain } from '../../../configs/index.js';
|
|
5
|
+
anvil
|
|
6
|
+
.command('start')
|
|
7
|
+
.description('start Anvil node with optional parameters')
|
|
8
|
+
.argument('<forkUrl>', 'Fork from a remote Ethereum node')
|
|
9
|
+
.option('-p, --port <number>', 'Port number to listen on', '8545')
|
|
10
|
+
.option('-a, --accounts <number>', 'Number of dev accounts', '10')
|
|
11
|
+
.option('-b, --block-time <number>', 'Block time in seconds (0 = auto mining on tx)')
|
|
12
|
+
.option('--fork-block-number <number>', 'Fork from a specific block number')
|
|
13
|
+
.option('--chain-id <number>', 'Chain ID')
|
|
14
|
+
.option('--gas-limit <number>', 'Block gas limit')
|
|
15
|
+
.option('--gas-price <number>', 'Gas price in gwei')
|
|
16
|
+
.option('--mnemonic <string>', 'BIP39 mnemonic phrase')
|
|
17
|
+
.option('--derivation-path <string>', 'Derivation path for accounts')
|
|
18
|
+
.option('-s, --state <path>', 'Load state from file')
|
|
19
|
+
.option('--state-interval <number>', 'Interval for state snapshots')
|
|
20
|
+
.option('--dump-state <path>', 'Dump state to file on exit')
|
|
21
|
+
.option('--silent', 'No output except errors')
|
|
22
|
+
.option('--steps-tracing', 'Enable step tracing')
|
|
23
|
+
.option('--no-mining', 'Disable automatic mining')
|
|
24
|
+
.action(async (forkUrl, options) => {
|
|
25
|
+
const chainId = await getChain();
|
|
26
|
+
const args = [
|
|
27
|
+
'--port',
|
|
28
|
+
options.port,
|
|
29
|
+
'--accounts',
|
|
30
|
+
options.accounts,
|
|
31
|
+
'--chain-id',
|
|
32
|
+
options.chainId ?? chainId.id,
|
|
33
|
+
];
|
|
34
|
+
// Block time
|
|
35
|
+
if (options.blockTime) {
|
|
36
|
+
args.push('--block-time', options.blockTime);
|
|
37
|
+
}
|
|
38
|
+
// Fork URL
|
|
39
|
+
if (forkUrl) {
|
|
40
|
+
args.push('--fork-url', forkUrl);
|
|
41
|
+
}
|
|
42
|
+
// Fork block number
|
|
43
|
+
if (options.forkBlockNumber) {
|
|
44
|
+
args.push('--fork-block-number', options.forkBlockNumber);
|
|
45
|
+
}
|
|
46
|
+
// Gas limit
|
|
47
|
+
if (options.gasLimit) {
|
|
48
|
+
args.push('--gas-limit', options.gasLimit);
|
|
49
|
+
}
|
|
50
|
+
// Gas price
|
|
51
|
+
if (options.gasPrice) {
|
|
52
|
+
args.push('--gas-price', options.gasPrice);
|
|
53
|
+
}
|
|
54
|
+
// Mnemonic
|
|
55
|
+
if (options.mnemonic) {
|
|
56
|
+
args.push('--mnemonic', options.mnemonic);
|
|
57
|
+
}
|
|
58
|
+
// Derivation path
|
|
59
|
+
if (options.derivationPath) {
|
|
60
|
+
args.push('--derivation-path', options.derivationPath);
|
|
61
|
+
}
|
|
62
|
+
// Load state
|
|
63
|
+
if (options.state) {
|
|
64
|
+
args.push('--state', options.state);
|
|
65
|
+
}
|
|
66
|
+
// State interval
|
|
67
|
+
if (options.stateInterval) {
|
|
68
|
+
args.push('--state-interval', options.stateInterval);
|
|
69
|
+
}
|
|
70
|
+
// Dump state
|
|
71
|
+
if (options.dumpState) {
|
|
72
|
+
args.push('--dump-state', options.dumpState);
|
|
73
|
+
}
|
|
74
|
+
// Silent mode
|
|
75
|
+
if (options.silent) {
|
|
76
|
+
args.push('--silent');
|
|
77
|
+
}
|
|
78
|
+
// Steps tracing
|
|
79
|
+
if (options.stepsTracing) {
|
|
80
|
+
args.push('--steps-tracing');
|
|
81
|
+
}
|
|
82
|
+
// No mining
|
|
83
|
+
if (options.noMining) {
|
|
84
|
+
args.push('--no-mining');
|
|
85
|
+
}
|
|
86
|
+
logInfo('Starting Anvil with the following parameters:');
|
|
87
|
+
logInfo(`Command: anvil ${args.join(' ')}`);
|
|
88
|
+
logInfo('');
|
|
89
|
+
const anvilProcess = spawn('anvil', args, {
|
|
90
|
+
stdio: 'inherit',
|
|
91
|
+
shell: true,
|
|
92
|
+
});
|
|
93
|
+
logInfo(`Use url http://127.0.0.1:${options.port} to connect to Anvil. For CLI set ENV VAR EL_URL=http://127.0.0.1:${options.port}`);
|
|
94
|
+
anvilProcess.on('error', (error) => {
|
|
95
|
+
logError(`Failed to start Anvil: ${error.message}`);
|
|
96
|
+
logError('Make sure Foundry is installed: https://book.getfoundry.sh/');
|
|
97
|
+
process.exit(1);
|
|
98
|
+
});
|
|
99
|
+
anvilProcess.on('exit', (code, signal) => {
|
|
100
|
+
if (code !== null) {
|
|
101
|
+
if (code === 0) {
|
|
102
|
+
logInfo('Anvil stopped successfully');
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
logError(`Anvil exited with code ${code}`);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
else if (signal) {
|
|
109
|
+
logInfo(`Anvil was killed with signal ${signal}`);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
// Handle graceful shutdown
|
|
113
|
+
process.on('SIGINT', () => {
|
|
114
|
+
logInfo('\nShutting down Anvil...');
|
|
115
|
+
anvilProcess.kill('SIGINT');
|
|
116
|
+
});
|
|
117
|
+
process.on('SIGTERM', () => {
|
|
118
|
+
logInfo('\nShutting down Anvil...');
|
|
119
|
+
anvilProcess.kill('SIGTERM');
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
//# sourceMappingURL=write.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../../programs/dev-tools/anvil/write.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../programs/dev-tools/defi-wrapper/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const defiWrapperTools: import("commander").Command;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../programs/dev-tools/defi-wrapper/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEtC,MAAM,CAAC,MAAM,gBAAgB,GAAG,QAAQ;KACrC,OAAO,CAAC,cAAc,CAAC;KACvB,KAAK,CAAC,IAAI,CAAC;KACX,WAAW,CAAC,6BAA6B,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { encodeAbiParameters, keccak256, parseEther, formatEther, parseUnits, formatUnits, } from 'viem';
|
|
2
|
+
import { logInfo, callReadMethodSilent, stringToBigInt } from '../../../utils/index.js';
|
|
3
|
+
import { getTestClient } from '../../../providers/index.js';
|
|
4
|
+
import { getStvStethPoolContract } from '../../../contracts/defi-wrapper/index.js';
|
|
5
|
+
import { defiWrapperTools } from './main.js';
|
|
6
|
+
const STORAGE_LOCATION = '0x9eb73ffa4c77d08d5d1746cf5a5e50a47018b610ea5d728ea9bd9e399b76e200';
|
|
7
|
+
defiWrapperTools
|
|
8
|
+
.command('change-storage')
|
|
9
|
+
.description('Make user position unhealthy by manipulating VaultHub storage (for testing in Fork)')
|
|
10
|
+
.argument('<address>', 'wrapper address')
|
|
11
|
+
.argument('<user>', 'user address to make unhealthy. For checking user position and previewForceRebalance')
|
|
12
|
+
.option('-v, --value <number>', 'value to set in VaultHub storage (Report.totalValue) in ETH. Default is 1.7', '1.7')
|
|
13
|
+
.option('-s, --storage-location <string>', 'VaultHub storage location for VaultRecord', STORAGE_LOCATION)
|
|
14
|
+
.action(async (address, user, options) => {
|
|
15
|
+
const { storageLocation, value } = options;
|
|
16
|
+
const publicClient = await getTestClient();
|
|
17
|
+
const contract = await getStvStethPoolContract(address);
|
|
18
|
+
const forcedRebalanceThresholdBP = await callReadMethodSilent(contract, 'forcedRebalanceThresholdBP');
|
|
19
|
+
logInfo('\n=== Wrapper Configuration ===');
|
|
20
|
+
logInfo(`Force rebalance threshold: ${forcedRebalanceThresholdBP} BP (${Number(forcedRebalanceThresholdBP) / 100}%)`);
|
|
21
|
+
const [vault, vaultHub] = await Promise.all([
|
|
22
|
+
callReadMethodSilent(contract, 'VAULT'),
|
|
23
|
+
callReadMethodSilent(contract, 'VAULT_HUB'),
|
|
24
|
+
]);
|
|
25
|
+
const vaultSlot = keccak256(encodeAbiParameters([{ type: 'address' }, { type: 'uint256' }], [vault, stringToBigInt(storageLocation)]));
|
|
26
|
+
logInfo('\n=== User Position BEFORE ===');
|
|
27
|
+
const [totalAssetsBefore, userForceRebalanceBefore] = await Promise.all([
|
|
28
|
+
callReadMethodSilent(contract, 'totalAssets'),
|
|
29
|
+
callReadMethodSilent(contract, 'previewForceRebalance', [user]),
|
|
30
|
+
]);
|
|
31
|
+
const [_stethSharesBefore, _stvAmountBefore, isUndercollateralizedBefore,] = userForceRebalanceBefore;
|
|
32
|
+
logInfo(`Total wrapper assets: ${formatEther(totalAssetsBefore)}`);
|
|
33
|
+
logInfo(`User needs force rebalance: ${isUndercollateralizedBefore}`);
|
|
34
|
+
logInfo('\n=== Manipulating VaultHub Storage ===');
|
|
35
|
+
// Modifying slot 0 (report.totalValue) in VaultHub
|
|
36
|
+
const reportSlot = vaultSlot;
|
|
37
|
+
const reportValue = await publicClient.getStorageAt({
|
|
38
|
+
address: vaultHub,
|
|
39
|
+
slot: reportSlot,
|
|
40
|
+
});
|
|
41
|
+
if (!reportValue) {
|
|
42
|
+
throw new Error('Failed to read report storage');
|
|
43
|
+
}
|
|
44
|
+
// Structure: first 20 bytes - other fields, last 12 bytes - totalValue
|
|
45
|
+
const reportHex = reportValue.slice(2);
|
|
46
|
+
const reportPart1 = reportHex.slice(0, 40);
|
|
47
|
+
const reportTotalValue = reportHex.slice(40, 64);
|
|
48
|
+
const reportTotalValueDecimal = BigInt('0x' + reportTotalValue);
|
|
49
|
+
const newReportTotalValue = parseEther(value);
|
|
50
|
+
logInfo(`Reducing report.totalValue: ${formatEther(reportTotalValueDecimal)} → ${value}`);
|
|
51
|
+
const newReportTotalValueHex = newReportTotalValue
|
|
52
|
+
.toString(16)
|
|
53
|
+
.padStart(24, '0');
|
|
54
|
+
const newReportValue = `0x${reportPart1}${newReportTotalValueHex}`;
|
|
55
|
+
await publicClient.request({
|
|
56
|
+
method: 'anvil_setStorageAt',
|
|
57
|
+
params: [vaultHub, reportSlot, newReportValue],
|
|
58
|
+
});
|
|
59
|
+
logInfo('\n=== User Position AFTER ===');
|
|
60
|
+
const [totalAssetsAfter, userForceRebalanceAfter, previewRedeemResult] = await Promise.all([
|
|
61
|
+
callReadMethodSilent(contract, 'totalAssets'),
|
|
62
|
+
callReadMethodSilent(contract, 'previewForceRebalance', [user]),
|
|
63
|
+
callReadMethodSilent(contract, 'previewRedeem', [
|
|
64
|
+
parseUnits('1', 27),
|
|
65
|
+
]),
|
|
66
|
+
]);
|
|
67
|
+
const [stethShares, stvAmount, isUndercollateralizedAfter] = userForceRebalanceAfter;
|
|
68
|
+
logInfo(`Total wrapper assets: ${formatEther(totalAssetsAfter)} (was ${formatEther(totalAssetsBefore)})`);
|
|
69
|
+
logInfo(`User needs force rebalance: ${isUndercollateralizedAfter}`);
|
|
70
|
+
if (isUndercollateralizedAfter) {
|
|
71
|
+
logInfo(` ↳ stETH shares to burn: ${formatEther(stethShares)}`);
|
|
72
|
+
logInfo(` ↳ STV amount to burn: ${formatUnits(stvAmount, 27)}`);
|
|
73
|
+
}
|
|
74
|
+
logInfo(`Preview redeem (1 STV): ${formatEther(previewRedeemResult)}`);
|
|
75
|
+
logInfo('\n✅ Storage manipulation completed successfully!');
|
|
76
|
+
});
|
|
77
|
+
//# sourceMappingURL=write.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../../programs/dev-tools/defi-wrapper/write.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../programs/dev-tools/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,kBAAkB,CAAC;AACjC,cAAc,yBAAyB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const devTools: import("commander").Command;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../programs/dev-tools/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,MAAM,CAAC,MAAM,QAAQ,GAAG,OAAO;KAC5B,OAAO,CAAC,WAAW,CAAC;KACpB,KAAK,CAAC,IAAI,CAAC;KACX,WAAW,CAAC,0BAA0B,CAAC,CAAC"}
|
package/dist/programs/index.d.ts
CHANGED
package/dist/programs/index.js
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
export * from './contracts/index.js';
|
|
2
|
+
export * from './defi-wrapper/index.js';
|
|
2
3
|
export * from './account/index.js';
|
|
3
4
|
export * from './pdg-helpers.js';
|
|
4
5
|
export * from './use-cases/index.js';
|
|
6
|
+
export * from './dev-tools/index.js';
|
|
5
7
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../programs/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../programs/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,yBAAyB,CAAC;AACxC,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC"}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { program } from '../command/index.js';
|
|
2
2
|
import { Option } from 'commander';
|
|
3
3
|
import { getStakingVaultContract, getPredepositGuaranteeContract, } from '../contracts/index.js';
|
|
4
|
-
import { createPDGProof, getFirstValidatorGIndex, confirmMakeProof, showSpinner, printError, computeDepositDataRoot, logResult, logInfo, getCommandsJson, computeDepositDomainByForkVersion, toHex, parseDepositArray, logError, callReadMethod, isValidBLSDeposit, expandBLSSignature, logTable, callReadMethodSilent, stringToNumber,
|
|
4
|
+
import { createPDGProof, getFirstValidatorGIndex, confirmMakeProof, showSpinner, printError, computeDepositDataRoot, logResult, logInfo, getCommandsJson, computeDepositDomainByForkVersion, toHex, parseDepositArray, logError, callReadMethod, isValidBLSDeposit, expandBLSSignature, logTable, callReadMethodSilent, stringToNumber, fetchValidatorsInfo, } from '../utils/index.js';
|
|
5
|
+
import { checkPdgIsPaused } from '../features/index.js';
|
|
5
6
|
const predepositGuaranteeHelpers = program
|
|
6
7
|
.command('pdg-helpers')
|
|
7
8
|
.description('predeposit guarantee helpers');
|
|
@@ -50,6 +51,7 @@ predepositGuaranteeHelpers
|
|
|
50
51
|
});
|
|
51
52
|
logInfo('-----------------------end-----------------------');
|
|
52
53
|
hideSpinner();
|
|
54
|
+
await checkPdgIsPaused(pdgContract);
|
|
53
55
|
}
|
|
54
56
|
catch (err) {
|
|
55
57
|
hideSpinner();
|
|
@@ -93,7 +95,7 @@ predepositGuaranteeHelpers
|
|
|
93
95
|
.option('-a, --vault <address>', 'vault address')
|
|
94
96
|
.option('-w, --withdrawalCredentials <hex>', 'withdrawal credentials')
|
|
95
97
|
.argument('<deposits>', 'deposits', parseDepositArray)
|
|
96
|
-
.addHelpText('after', `Deposit format:
|
|
98
|
+
.addHelpText('after', `Deposit format (amount are in gwei):
|
|
97
99
|
'[{
|
|
98
100
|
"pubkey": "...",
|
|
99
101
|
"signature": "...",
|
|
@@ -106,11 +108,11 @@ predepositGuaranteeHelpers
|
|
|
106
108
|
const vault = options.vault;
|
|
107
109
|
let withdrawalCredentials = options.withdrawalCredentials;
|
|
108
110
|
if (!vault && !withdrawalCredentials) {
|
|
109
|
-
logError('You must provide either vault or withdrawal credentials');
|
|
111
|
+
logError('You must provide either vault (-a, --vault) or withdrawal credentials (-w, --withdrawalCredentials)');
|
|
110
112
|
return;
|
|
111
113
|
}
|
|
112
114
|
else if (vault && withdrawalCredentials) {
|
|
113
|
-
logError('You can only provide one of vault or withdrawal credentials');
|
|
115
|
+
logError('You can only provide one of vault (-a, --vault) or withdrawal credentials (-w, --withdrawalCredentials)');
|
|
114
116
|
return;
|
|
115
117
|
}
|
|
116
118
|
const hideMetadataSpinner = showSpinner({
|
|
@@ -120,7 +122,7 @@ predepositGuaranteeHelpers
|
|
|
120
122
|
const pdg = await getPredepositGuaranteeContract();
|
|
121
123
|
const PREDEPOSIT_AMOUNT = await callReadMethod(pdg, 'PREDEPOSIT_AMOUNT');
|
|
122
124
|
if (vault) {
|
|
123
|
-
const vaultContract = getStakingVaultContract(vault);
|
|
125
|
+
const vaultContract = await getStakingVaultContract(vault);
|
|
124
126
|
const wc = await callReadMethod(vaultContract, 'withdrawalCredentials');
|
|
125
127
|
withdrawalCredentials = wc;
|
|
126
128
|
}
|
|
@@ -145,7 +147,7 @@ predepositGuaranteeHelpers
|
|
|
145
147
|
logInfo(`✅ depositDataRoot VALID for Pubkey ${deposit.pubkey}`);
|
|
146
148
|
}
|
|
147
149
|
// local BLS check
|
|
148
|
-
const isBLSValid = isValidBLSDeposit(deposit, withdrawalCredentials);
|
|
150
|
+
const isBLSValid = await isValidBLSDeposit(deposit, withdrawalCredentials);
|
|
149
151
|
if (!isBLSValid) {
|
|
150
152
|
logError(`❌ Offchain - BLS signature is not valid for Pubkey ${deposit.pubkey}`);
|
|
151
153
|
return;
|
|
@@ -175,6 +177,7 @@ predepositGuaranteeHelpers
|
|
|
175
177
|
]);
|
|
176
178
|
hideSpinner();
|
|
177
179
|
logInfo(`✅ ONCHAIN 🔗 SIGNATURE VALID for Pubkey ${deposit.pubkey}`);
|
|
180
|
+
await checkPdgIsPaused(pdg);
|
|
178
181
|
}
|
|
179
182
|
catch (err) {
|
|
180
183
|
hideSpinner();
|
|
@@ -231,26 +234,27 @@ predepositGuaranteeHelpers
|
|
|
231
234
|
.action(async (validatorPubkey) => {
|
|
232
235
|
if (!validatorPubkey)
|
|
233
236
|
return;
|
|
234
|
-
const
|
|
237
|
+
const validatorsInfo = await fetchValidatorsInfo([validatorPubkey]);
|
|
238
|
+
const validatorInfo = validatorsInfo.data[0];
|
|
235
239
|
logTable({
|
|
236
240
|
data: [
|
|
237
|
-
['Index', validatorInfo.
|
|
238
|
-
['Balance', validatorInfo.
|
|
239
|
-
['Status', validatorInfo.
|
|
240
|
-
['Pubkey', validatorInfo.
|
|
241
|
+
['Index', validatorInfo.index],
|
|
242
|
+
['Balance', validatorInfo.balance],
|
|
243
|
+
['Status', validatorInfo.status],
|
|
244
|
+
['Pubkey', validatorInfo.validator.pubkey],
|
|
241
245
|
[
|
|
242
246
|
'Withdrawal Credentials',
|
|
243
|
-
validatorInfo.
|
|
247
|
+
validatorInfo.validator.withdrawal_credentials,
|
|
244
248
|
],
|
|
245
|
-
['Effective Balance', validatorInfo.
|
|
246
|
-
['Slashed', validatorInfo.
|
|
249
|
+
['Effective Balance', validatorInfo.validator.effective_balance],
|
|
250
|
+
['Slashed', validatorInfo.validator.slashed],
|
|
247
251
|
[
|
|
248
252
|
'Activation Eligibility Epoch',
|
|
249
|
-
validatorInfo.
|
|
253
|
+
validatorInfo.validator.activation_eligibility_epoch,
|
|
250
254
|
],
|
|
251
|
-
['Activation Epoch', validatorInfo.
|
|
252
|
-
['Exit Epoch', validatorInfo.
|
|
253
|
-
['Withdrawable Epoch', validatorInfo.
|
|
255
|
+
['Activation Epoch', validatorInfo.validator.activation_epoch],
|
|
256
|
+
['Exit Epoch', validatorInfo.validator.exit_epoch],
|
|
257
|
+
['Withdrawable Epoch', validatorInfo.validator.withdrawable_epoch],
|
|
254
258
|
],
|
|
255
259
|
});
|
|
256
260
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pdg-helpers.js","sourceRoot":"","sources":["../../programs/pdg-helpers.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pdg-helpers.js","sourceRoot":"","sources":["../../programs/pdg-helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../programs/use-cases/consolidation/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const consolidation: import("commander").Command;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../programs/use-cases/consolidation/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,MAAM,CAAC,MAAM,aAAa,GAAG,OAAO;KACjC,OAAO,CAAC,eAAe,CAAC;KACxB,WAAW,CAAC,yBAAyB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const consolidationWrite: import("commander").Command;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { program } from '../../../command/index.js';
|
|
2
|
+
import { stringTo2dArray, stringToAddress, stringToHexArray, jsonFileToPubkeys, confirmOperation, callWriteMethodWithReceiptBatchCalls, logCancel, callReadMethodSilent, } from '../../../utils/index.js';
|
|
3
|
+
import { consolidation } from './main.js';
|
|
4
|
+
import { consolidateAndIncreaseFeeExemptionWithoutBatching, consolidationRequestsAndIncreaseFeeExemption, confirmNewFeeExemption, } from '../../../features/consolidation.js';
|
|
5
|
+
import { checkVaultRole, checkIsReportFresh } from '../../../features/index.js';
|
|
6
|
+
import { getAccount } from '../../../providers/index.js';
|
|
7
|
+
import { checkPubkeysArgs, validateConsolidationInput, getValidatorsInfo, getTargetAndSourceValidatorsInfo, logAllSourceValidatorsTable, logAllTargetValidatorsTable, confirmToConsolidate, calculateAndConfirmFeeExemption, removeInactiveValidators, } from '../../../utils/index.js';
|
|
8
|
+
import { getDashboardContract } from '../../../contracts/index.js';
|
|
9
|
+
export const consolidationWrite = consolidation
|
|
10
|
+
.command('write')
|
|
11
|
+
.aliases(['w'])
|
|
12
|
+
.description('consolidation write commands');
|
|
13
|
+
consolidationWrite
|
|
14
|
+
.command('consolidate-validators')
|
|
15
|
+
.aliases(['consolidate'])
|
|
16
|
+
.description('consolidate validators and increase rewards adjustment to fix fee calculation for node-operator')
|
|
17
|
+
.argument('<dashboard>', 'dashboard address', stringToAddress)
|
|
18
|
+
.option('-s, --source <source>', '2D array of source validator pubkeys: each inner list will be consolidated into a single target validator', stringTo2dArray)
|
|
19
|
+
.option('-t, --target <target>', 'List of target validator public keys to consolidate into. One target pubkey per group of source pubkeys', stringToHexArray)
|
|
20
|
+
.option('-f, --file <file>', 'Path to a JSON file containing the source pubkeys and target pubkeys in format: {"targetPubkey0": ["sourcePubkey0", "sourcePubkey1"], "targetPubkey1": ["sourcePubkey2", "sourcePubkey3"]}', jsonFileToPubkeys)
|
|
21
|
+
.option('-b, --batch', 'Batch the consolidation requests and increase fee exemption amount. Use this option if your wallet supports batching. Supports only WalletConnect option (--wallet-connect).', false)
|
|
22
|
+
.action(async (dashboard, { source, target, file, batch, }) => {
|
|
23
|
+
const isWC = program.opts().walletConnect;
|
|
24
|
+
if (batch && !isWC) {
|
|
25
|
+
logCancel('Transaction batching is only supported with WalletConnect option (--wallet-connect).');
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
// Validation
|
|
29
|
+
const { sourcePubkeys, targetPubkeys } = checkPubkeysArgs(file, source, target);
|
|
30
|
+
validateConsolidationInput(sourcePubkeys, targetPubkeys, dashboard);
|
|
31
|
+
const [account, dashboardContract] = await Promise.all([
|
|
32
|
+
getAccount(),
|
|
33
|
+
getDashboardContract(dashboard),
|
|
34
|
+
]);
|
|
35
|
+
const vault = await callReadMethodSilent(dashboardContract, 'stakingVault');
|
|
36
|
+
await checkVaultRole(dashboardContract, 'NODE_OPERATOR_FEE_EXEMPT_ROLE', account.address);
|
|
37
|
+
const isReportFresh = await checkIsReportFresh(vault);
|
|
38
|
+
if (!isReportFresh) {
|
|
39
|
+
logCancel('Report is not fresh. You need to submit a fresh report before consolidating validators.');
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const { sourceValidatorsInfo, targetValidatorsInfo } = await getValidatorsInfo(sourcePubkeys, targetPubkeys);
|
|
43
|
+
const targetAndSourceValidators = getTargetAndSourceValidatorsInfo(targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo);
|
|
44
|
+
const feeExemption = await calculateAndConfirmFeeExemption(targetAndSourceValidators);
|
|
45
|
+
const { isNeedToIncreaseFeeExemption } = await confirmNewFeeExemption(dashboardContract, feeExemption);
|
|
46
|
+
removeInactiveValidators(targetAndSourceValidators);
|
|
47
|
+
if (targetAndSourceValidators.size > 0) {
|
|
48
|
+
await logAllSourceValidatorsTable(targetAndSourceValidators);
|
|
49
|
+
await logAllTargetValidatorsTable(targetAndSourceValidators);
|
|
50
|
+
await confirmToConsolidate(targetAndSourceValidators, dashboard);
|
|
51
|
+
}
|
|
52
|
+
if (batch) {
|
|
53
|
+
const populatedTxs = await consolidationRequestsAndIncreaseFeeExemption({
|
|
54
|
+
targetAndSourceValidators,
|
|
55
|
+
feeExemption: isNeedToIncreaseFeeExemption ? feeExemption : 0n,
|
|
56
|
+
dashboard,
|
|
57
|
+
});
|
|
58
|
+
const confirm = await confirmOperation(`Are you sure you want to proceed with the consolidation? There are will be ${populatedTxs.length} operations to be executed`);
|
|
59
|
+
if (!confirm) {
|
|
60
|
+
logCancel('User cancelled consolidation');
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
await callWriteMethodWithReceiptBatchCalls({
|
|
64
|
+
calls: populatedTxs,
|
|
65
|
+
withSpinner: true,
|
|
66
|
+
silent: false,
|
|
67
|
+
skipError: false,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
await consolidateAndIncreaseFeeExemptionWithoutBatching({
|
|
72
|
+
targetAndSourceValidators,
|
|
73
|
+
feeExemption: isNeedToIncreaseFeeExemption ? feeExemption : 0n,
|
|
74
|
+
dashboard,
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
//# sourceMappingURL=write.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../../programs/use-cases/consolidation/write.ts"],"names":[],"mappings":"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"}
|