@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,5 +1,5 @@
|
|
|
1
1
|
import { VaultReport } from '../../../index.js';
|
|
2
|
-
export declare const prepareBottomLine: (history: VaultReport[],
|
|
2
|
+
export declare const prepareBottomLine: (history: VaultReport[], nodeOperatorAccruedFees: bigint[], vaultAddress: string) => Promise<{
|
|
3
3
|
values: string[];
|
|
4
4
|
timestamp: number[];
|
|
5
5
|
}>;
|
|
@@ -7,11 +7,11 @@ export declare const prepareGrossStakingAPR: (history: VaultReport[]) => {
|
|
|
7
7
|
values: number[];
|
|
8
8
|
timestamp: number[];
|
|
9
9
|
};
|
|
10
|
-
export declare const prepareNetStakingAPR: (history: VaultReport[],
|
|
10
|
+
export declare const prepareNetStakingAPR: (history: VaultReport[], nodeOperatorAccruedFees: bigint[]) => {
|
|
11
11
|
values: number[];
|
|
12
12
|
timestamp: number[];
|
|
13
13
|
};
|
|
14
|
-
export declare const prepareCarrySpread: (history: VaultReport[],
|
|
14
|
+
export declare const prepareCarrySpread: (history: VaultReport[], nodeOperatorAccruedFees: bigint[], vaultAddress: string) => Promise<{
|
|
15
15
|
values: number[];
|
|
16
16
|
timestamp: number[];
|
|
17
17
|
}>;
|
|
@@ -23,11 +23,11 @@ export declare const prepareGrossStakingRewards: (history: VaultReport[]) => {
|
|
|
23
23
|
values: string[];
|
|
24
24
|
timestamp: number[];
|
|
25
25
|
};
|
|
26
|
-
export declare const prepareNodeOperatorRewards: (history: VaultReport[],
|
|
26
|
+
export declare const prepareNodeOperatorRewards: (history: VaultReport[], nodeOperatorAccruedFees: bigint[]) => {
|
|
27
27
|
values: string[];
|
|
28
28
|
timestamp: number[];
|
|
29
29
|
};
|
|
30
|
-
export declare const prepareNetStakingRewards: (history: VaultReport[],
|
|
30
|
+
export declare const prepareNetStakingRewards: (history: VaultReport[], nodeOperatorAccruedFees: bigint[]) => {
|
|
31
31
|
values: string[];
|
|
32
32
|
timestamp: number[];
|
|
33
33
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
|
-
import { getBottomLine, getGrossStakingAPR, getNetStakingAPR, getCarrySpread, calculateLidoAPR, getGrossStakingRewards,
|
|
2
|
+
import { getBottomLine, getGrossStakingAPR, getNetStakingAPR, getCarrySpread, calculateLidoAPR, getGrossStakingRewards, getNetStakingRewards, getDailyLidoFees, } from '../../../index.js';
|
|
3
3
|
import { getRebaseRewardFromCache, getShareRateFromCache } from '../../../index.js';
|
|
4
|
-
export const prepareBottomLine = async (history,
|
|
4
|
+
export const prepareBottomLine = async (history, nodeOperatorAccruedFees, vaultAddress) => {
|
|
5
5
|
const bottomLine = [];
|
|
6
6
|
const timestamp = [];
|
|
7
7
|
for (let i = 1; i < history.length; i++) {
|
|
@@ -16,7 +16,7 @@ export const prepareBottomLine = async (history, nodeOperatorFeeBPs, vaultAddres
|
|
|
16
16
|
liabilitySharesCurr: BigInt(current.data.liabilityShares),
|
|
17
17
|
liabilitySharesPrev: BigInt(previous.data.liabilityShares),
|
|
18
18
|
});
|
|
19
|
-
const bottomLineValue = getBottomLine(current, previous,
|
|
19
|
+
const bottomLineValue = getBottomLine(current, previous, nodeOperatorAccruedFees[i] ?? 0n, stEthLiabilityRebaseRewards);
|
|
20
20
|
bottomLine.push(String(bottomLineValue));
|
|
21
21
|
timestamp.push(current.timestamp);
|
|
22
22
|
}
|
|
@@ -36,7 +36,7 @@ export const prepareGrossStakingAPR = (history) => {
|
|
|
36
36
|
}
|
|
37
37
|
return { values: grossStakingAPRPercent, timestamp };
|
|
38
38
|
};
|
|
39
|
-
export const prepareNetStakingAPR = (history,
|
|
39
|
+
export const prepareNetStakingAPR = (history, nodeOperatorAccruedFees) => {
|
|
40
40
|
const netStakingAPRPercent = [];
|
|
41
41
|
const timestamp = [];
|
|
42
42
|
for (let i = 1; i < history.length; i++) {
|
|
@@ -44,13 +44,13 @@ export const prepareNetStakingAPR = (history, nodeOperatorFeeBPs) => {
|
|
|
44
44
|
const previous = history[i - 1];
|
|
45
45
|
if (!current || !previous)
|
|
46
46
|
continue;
|
|
47
|
-
const value = getNetStakingAPR(current, previous,
|
|
47
|
+
const value = getNetStakingAPR(current, previous, nodeOperatorAccruedFees[i] ?? 0n);
|
|
48
48
|
netStakingAPRPercent.push(value.apr_percent);
|
|
49
49
|
timestamp.push(current.timestamp);
|
|
50
50
|
}
|
|
51
51
|
return { values: netStakingAPRPercent, timestamp };
|
|
52
52
|
};
|
|
53
|
-
export const prepareCarrySpread = async (history,
|
|
53
|
+
export const prepareCarrySpread = async (history, nodeOperatorAccruedFees, vaultAddress) => {
|
|
54
54
|
const carrySpreadPercent = [];
|
|
55
55
|
const timestamp = [];
|
|
56
56
|
for (let i = 1; i < history.length; i++) {
|
|
@@ -65,7 +65,7 @@ export const prepareCarrySpread = async (history, nodeOperatorFeeBPs, vaultAddre
|
|
|
65
65
|
liabilitySharesCurr: BigInt(current.data.liabilityShares),
|
|
66
66
|
liabilitySharesPrev: BigInt(previous.data.liabilityShares),
|
|
67
67
|
});
|
|
68
|
-
const value = getCarrySpread(current, previous,
|
|
68
|
+
const value = getCarrySpread(current, previous, nodeOperatorAccruedFees[i] ?? 0n, stEthLiabilityRebaseRewards);
|
|
69
69
|
carrySpreadPercent.push(value.apr_percent);
|
|
70
70
|
timestamp.push(current.timestamp);
|
|
71
71
|
}
|
|
@@ -102,7 +102,7 @@ export const prepareGrossStakingRewards = (history) => {
|
|
|
102
102
|
}
|
|
103
103
|
return { values: grossStakingRewards, timestamp };
|
|
104
104
|
};
|
|
105
|
-
export const prepareNodeOperatorRewards = (history,
|
|
105
|
+
export const prepareNodeOperatorRewards = (history, nodeOperatorAccruedFees) => {
|
|
106
106
|
const nodeOperatorRewards = [];
|
|
107
107
|
const timestamp = [];
|
|
108
108
|
for (let i = 1; i < history.length; i++) {
|
|
@@ -110,13 +110,13 @@ export const prepareNodeOperatorRewards = (history, nodeOperatorFeeBPs) => {
|
|
|
110
110
|
const previous = history[i - 1];
|
|
111
111
|
if (!current || !previous)
|
|
112
112
|
continue;
|
|
113
|
-
const value =
|
|
113
|
+
const value = nodeOperatorAccruedFees[i] ?? 0n;
|
|
114
114
|
nodeOperatorRewards.push(String(formatEther(value)));
|
|
115
115
|
timestamp.push(current.timestamp);
|
|
116
116
|
}
|
|
117
117
|
return { values: nodeOperatorRewards, timestamp };
|
|
118
118
|
};
|
|
119
|
-
export const prepareNetStakingRewards = (history,
|
|
119
|
+
export const prepareNetStakingRewards = (history, nodeOperatorAccruedFees) => {
|
|
120
120
|
const netStakingRewards = [];
|
|
121
121
|
const timestamp = [];
|
|
122
122
|
for (let i = 1; i < history.length; i++) {
|
|
@@ -124,7 +124,7 @@ export const prepareNetStakingRewards = (history, nodeOperatorFeeBPs) => {
|
|
|
124
124
|
const previous = history[i - 1];
|
|
125
125
|
if (!current || !previous)
|
|
126
126
|
continue;
|
|
127
|
-
const value = getNetStakingRewards(current, previous,
|
|
127
|
+
const value = getNetStakingRewards(current, previous, nodeOperatorAccruedFees[i] ?? 0n);
|
|
128
128
|
netStakingRewards.push(String(formatEther(value)));
|
|
129
129
|
timestamp.push(current.timestamp);
|
|
130
130
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prepare-metrics.js","sourceRoot":"","sources":["../../../../../utils/charts/blessed/datasets/prepare-metrics.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAEnC,OAAO,EAEL,aAAa,EACb,kBAAkB,EAClB,gBAAgB,EAChB,cAAc,EACd,gBAAgB,EAChB,sBAAsB,EACtB,
|
|
1
|
+
{"version":3,"file":"prepare-metrics.js","sourceRoot":"","sources":["../../../../../utils/charts/blessed/datasets/prepare-metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
2
|
import { getDashboardContract } from '../../../contracts/index.js';
|
|
3
|
-
import { logError, logInfo, callReadMethodSilent, getVaultReportHistory,
|
|
3
|
+
import { logError, logInfo, callReadMethodSilent, getVaultReportHistory, getGrossStakingAPR, getGrossStakingRewards, getNetStakingAPR, getCarrySpread, getBottomLine, getRebaseRewardFromCache, formatTimestamp, } from '../../index.js';
|
|
4
|
+
import { getNodeOperatorAccruedFeeByBlockNumbers } from '../../../features/index.js';
|
|
4
5
|
import { logGrossStakingAPRChart, logNetStakingAPRChart, logCarrySpreadChart, logBottomLineChart, } from '../metrics.js';
|
|
5
6
|
// TODO: Refactor this file
|
|
6
7
|
// Render simple charts for APR metrics
|
|
7
8
|
export const renderSimpleCharts = async ({ dashboard, cid, limit = 20, cacheUse = true, }) => {
|
|
8
|
-
const dashboardContract = getDashboardContract(dashboard);
|
|
9
|
+
const dashboardContract = await getDashboardContract(dashboard);
|
|
9
10
|
const vault = await callReadMethodSilent(dashboardContract, 'stakingVault');
|
|
10
11
|
logInfo(`\n=== Getting report history for vault ${vault} (CID: ${cid}) ===\n`);
|
|
11
12
|
let history;
|
|
@@ -34,19 +35,8 @@ export const renderSimpleCharts = async ({ dashboard, cid, limit = 20, cacheUse
|
|
|
34
35
|
// eslint-disable-next-line sonarjs/no-unused-collection
|
|
35
36
|
const grossStakingRewards = [];
|
|
36
37
|
const timeLabels = [];
|
|
37
|
-
|
|
38
|
-
const
|
|
39
|
-
for (const r of history) {
|
|
40
|
-
let fee = await cache.getNodeOperatorFeeRate(vault, r.blockNumber);
|
|
41
|
-
if (fee === null) {
|
|
42
|
-
const feeRate = await callReadMethodSilent(dashboardContract, 'feeRate', {
|
|
43
|
-
blockNumber: BigInt(r.blockNumber),
|
|
44
|
-
});
|
|
45
|
-
fee = BigInt(feeRate);
|
|
46
|
-
await cache.setNodeOperatorFeeRate(vault, r.blockNumber, fee);
|
|
47
|
-
}
|
|
48
|
-
nodeOperatorFeeBPs.push(fee);
|
|
49
|
-
}
|
|
38
|
+
const blockNumbers = history.map((r) => r.blockNumber);
|
|
39
|
+
const nodeOperatorAccruedFees = await getNodeOperatorAccruedFeeByBlockNumbers(vault, blockNumbers, dashboardContract);
|
|
50
40
|
for (let i = 1; i < history.length; i++) {
|
|
51
41
|
const current = history[i];
|
|
52
42
|
const previous = history[i - 1];
|
|
@@ -61,10 +51,10 @@ export const renderSimpleCharts = async ({ dashboard, cid, limit = 20, cacheUse
|
|
|
61
51
|
});
|
|
62
52
|
grossStakingRewards.push(Number(formatEther(getGrossStakingRewards(current, previous), 'gwei')));
|
|
63
53
|
grossStakingAPRPercent.push(getGrossStakingAPR(current, previous).apr_percent);
|
|
64
|
-
netStakingAPRPercent.push(getNetStakingAPR(current, previous,
|
|
54
|
+
netStakingAPRPercent.push(getNetStakingAPR(current, previous, nodeOperatorAccruedFees[i] ?? 0n)
|
|
65
55
|
.apr_percent);
|
|
66
|
-
carrySpreadPercent.push(getCarrySpread(current, previous,
|
|
67
|
-
bottomLine.push(Number(getBottomLine(current, previous,
|
|
56
|
+
carrySpreadPercent.push(getCarrySpread(current, previous, nodeOperatorAccruedFees[i] ?? 0n, stEthLiabilityRebaseRewards).apr_percent);
|
|
57
|
+
bottomLine.push(Number(getBottomLine(current, previous, nodeOperatorAccruedFees[i] ?? 0n, stEthLiabilityRebaseRewards)));
|
|
68
58
|
timeLabels.push(formatTimestamp(current.timestamp, 'dd.mm hh:mm'));
|
|
69
59
|
}
|
|
70
60
|
logGrossStakingAPRChart(grossStakingAPRPercent, timeLabels);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simple-charts.js","sourceRoot":"","sources":["../../../../utils/charts/simple/simple-charts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EACL,QAAQ,EACR,OAAO,EACP,oBAAoB,EACpB,qBAAqB,EACrB,
|
|
1
|
+
{"version":3,"file":"simple-charts.js","sourceRoot":"","sources":["../../../../utils/charts/simple/simple-charts.ts"],"names":[],"mappings":"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"}
|
|
@@ -24,7 +24,7 @@ export const formatConfirmationArgs = (args, functionName) => {
|
|
|
24
24
|
}
|
|
25
25
|
};
|
|
26
26
|
export const getConfirmationsInfo = async (contract, abi) => {
|
|
27
|
-
const publicClient = getPublicClient();
|
|
27
|
+
const publicClient = await getPublicClient();
|
|
28
28
|
const confirmExpire = await contract.read.getConfirmExpiry();
|
|
29
29
|
const currentBlock = await publicClient.getBlockNumber();
|
|
30
30
|
const confirmExpireInBlocks = confirmExpire / AVG_BLOCK_TIME_SEC;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"confirmations.js","sourceRoot":"","sources":["../../../utils/commands/confirmations.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,kBAAkB,EAIlB,WAAW,GAEZ,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,mBAAmB,EAAE,MAAM,OAAO,CAAC;AAGxE,MAAM,kBAAkB,GAAG,GAAG,CAAC;AAU/B,yBAAyB;AACzB,MAAM,CAAC,MAAM,mBAAmB,GAAG;IACjC,gBAAgB,EAAE,CAAC,IAAyC,EAAE,EAAE,CAC9D,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,QAAQ;IACnC,sBAAsB,EAAE,CAAC,IAA+C,EAAE,EAAE,CAC1E,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACnB,UAAU,EAAE,CAAC,IAAmC,EAAE,EAAE,CAClD,UAAU,IAAI,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,CAAC,4BAA4B,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;IAC9F,sBAAsB,EAAE,CAAC,IAA+C,EAAE,EAAE,CAC1E,cAAc,IAAI,CAAC,CAAC,CAAC,EAAE;CACjB,CAAC;AAwBX,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,IAGsB,EACtB,YAA0B,EAC1B,EAAE;IACF,QAAQ,YAAY,EAAE,CAAC;QACrB,KAAK,kBAAkB;YACrB,OAAO,mBAAmB,CAAC,gBAAgB,CACzC,IAA2C,CAC5C,CAAC;QACJ,KAAK,wBAAwB;YAC3B,OAAO,mBAAmB,CAAC,sBAAsB,CAC/C,IAAiD,CAClD,CAAC;QACJ,KAAK,YAAY;YACf,OAAO,mBAAmB,CAAC,UAAU,CACnC,IAAqC,CACtC,CAAC;QACJ,KAAK,wBAAwB;YAC3B,OAAO,mBAAmB,CAAC,sBAAsB,CAC/C,IAAiD,CAClD,CAAC;QACJ;YACE,MAAM,IAAI,KAAK,CAAC,qBAAqB,YAAY,EAAE,CAAC,CAAC;IACzD,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,oBAAoB,GAAG,KAAK,EACvC,QAAW,EACX,GAAQ,EACR,EAAE;IACF,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"confirmations.js","sourceRoot":"","sources":["../../../utils/commands/confirmations.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
import { Address } from 'viem';
|
|
2
|
+
import { PopulatedTx } from '../index.js';
|
|
2
3
|
type SubmitReportArgs = {
|
|
3
4
|
vault: Address;
|
|
4
5
|
gateway?: string;
|
|
6
|
+
populateTx?: boolean;
|
|
5
7
|
};
|
|
6
|
-
export declare const submitReport: ({ vault, gateway, }: SubmitReportArgs) => Promise<
|
|
8
|
+
export declare const submitReport: ({ vault, gateway, populateTx, }: SubmitReportArgs) => Promise<{
|
|
9
|
+
isFresh: boolean;
|
|
10
|
+
data?: PopulatedTx;
|
|
11
|
+
}>;
|
|
7
12
|
export {};
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { program } from '../../command/index.js';
|
|
2
2
|
import { getLazyOracleContract, getVaultHubContract } from '../../contracts/index.js';
|
|
3
3
|
import { callReadMethod, callReadMethodSilent, logCancel, callWriteMethodWithReceipt, confirmOperation, getReportProofByVault, } from '../index.js';
|
|
4
|
-
export const submitReport = async ({ vault, gateway, }) => {
|
|
4
|
+
export const submitReport = async ({ vault, gateway, populateTx = false, }) => {
|
|
5
5
|
const lazyOracleContract = await getLazyOracleContract();
|
|
6
6
|
const vaultHubContract = await getVaultHubContract();
|
|
7
7
|
const [_vaultsDataTimestamp, _vaultsDataRefSlot, _vaultsDataTreeRoot, vaultsDataReportCid,] = await callReadMethod(lazyOracleContract, 'latestReportData');
|
|
8
8
|
const isReportFresh = await callReadMethodSilent(vaultHubContract, 'isReportFresh', [vault]);
|
|
9
9
|
if (isReportFresh) {
|
|
10
10
|
logCancel('Report is fresh. You dont need to submit it again');
|
|
11
|
-
return;
|
|
11
|
+
return { isFresh: true, data: undefined };
|
|
12
12
|
}
|
|
13
13
|
const { cacheUse } = program.opts();
|
|
14
14
|
const proof = await getReportProofByVault({
|
|
@@ -24,9 +24,9 @@ export const submitReport = async ({ vault, gateway, }) => {
|
|
|
24
24
|
`);
|
|
25
25
|
if (!confirm) {
|
|
26
26
|
logCancel('Report not submitted');
|
|
27
|
-
return;
|
|
27
|
+
return { isFresh: false, data: undefined };
|
|
28
28
|
}
|
|
29
|
-
await callWriteMethodWithReceipt({
|
|
29
|
+
const reportCall = await callWriteMethodWithReceipt({
|
|
30
30
|
contract: lazyOracleContract,
|
|
31
31
|
methodName: 'updateVaultData',
|
|
32
32
|
payload: [
|
|
@@ -38,6 +38,8 @@ export const submitReport = async ({ vault, gateway, }) => {
|
|
|
38
38
|
BigInt(proof.data.slashingReserve),
|
|
39
39
|
proof.proof,
|
|
40
40
|
],
|
|
41
|
+
populateTx,
|
|
41
42
|
});
|
|
43
|
+
return { isFresh: true, data: reportCall.data };
|
|
42
44
|
};
|
|
43
45
|
//# sourceMappingURL=report.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"report.js","sourceRoot":"","sources":["../../../utils/commands/report.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AACvE,OAAO,EACL,cAAc,EACd,oBAAoB,EACpB,SAAS,EACT,0BAA0B,EAC1B,gBAAgB,EAChB,qBAAqB,
|
|
1
|
+
{"version":3,"file":"report.js","sourceRoot":"","sources":["../../../utils/commands/report.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AACvE,OAAO,EACL,cAAc,EACd,oBAAoB,EACpB,SAAS,EACT,0BAA0B,EAC1B,gBAAgB,EAChB,qBAAqB,GAEtB,MAAM,OAAO,CAAC;AAQf,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAAE,EACjC,KAAK,EACL,OAAO,EACP,UAAU,GAAG,KAAK,GACD,EAGhB,EAAE;IACH,MAAM,kBAAkB,GAAG,MAAM,qBAAqB,EAAE,CAAC;IACzD,MAAM,gBAAgB,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAErD,MAAM,CACJ,oBAAoB,EACpB,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACpB,GAAG,MAAM,cAAc,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;IACjE,MAAM,aAAa,GAAG,MAAM,oBAAoB,CAC9C,gBAAgB,EAChB,eAAe,EACf,CAAC,KAAK,CAAC,CACR,CAAC;IAEF,IAAI,aAAa,EAAE,CAAC;QAClB,SAAS,CAAC,mDAAmD,CAAC,CAAC;QAC/D,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;IAC5C,CAAC;IAED,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IACpC,MAAM,KAAK,GAAG,MAAM,qBAAqB,CACvC;QACE,KAAK;QACL,GAAG,EAAE,mBAAmB;QACxB,OAAO;KACR,EACD,QAAQ,CACT,CAAC;IAEF,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oDAAoD,KAAK;2BAClC,KAAK,CAAC,IAAI,CAAC,aAAa;eACpC,KAAK,CAAC,IAAI,CAAC,GAAG;4BACD,KAAK,CAAC,IAAI,CAAC,eAAe;4BAC1B,KAAK,CAAC,IAAI,CAAC,eAAe;SAC7C,CACN,CAAC;IACF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,SAAS,CAAC,sBAAsB,CAAC,CAAC;QAClC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;IAC7C,CAAC;IAED,MAAM,UAAU,GAAG,MAAM,0BAA0B,CAAC;QAClD,QAAQ,EAAE,kBAAkB;QAC5B,UAAU,EAAE,iBAAiB;QAC7B,OAAO,EAAE;YACP,KAAK;YACL,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC;YAChC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC;YACtB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;YAClC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC;YACrC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;YAClC,KAAK,CAAC,KAAK;SACZ;QACD,UAAU;KACX,CAAC,CAAC;IAEH,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,CAAC,IAAI,EAAE,CAAC;AAClD,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { Address, Hex } from 'viem';
|
|
2
|
+
import { PubkeyMap } from './types.js';
|
|
3
|
+
export declare const checkPubkeysArgs: (file: PubkeyMap, sourcePubkeys: Hex[][], targetPubkeys: Hex[]) => {
|
|
4
|
+
sourcePubkeys: `0x${string}`[][];
|
|
5
|
+
targetPubkeys: `0x${string}`[];
|
|
6
|
+
};
|
|
7
|
+
export declare const validateConsolidationInput: (sourcePubkeys: Hex[][], targetPubkeys: Hex[], dashboard: Address, refundRecipient?: Address) => void;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { hexToBytes, isHex, zeroAddress } from 'viem';
|
|
2
|
+
import { toHex } from '../index.js';
|
|
3
|
+
export const checkPubkeysArgs = (file, sourcePubkeys, targetPubkeys) => {
|
|
4
|
+
if (!file && !(sourcePubkeys && targetPubkeys)) {
|
|
5
|
+
throw new Error('Provide --file or both --source_pubkeys and --target_pubkeys');
|
|
6
|
+
}
|
|
7
|
+
const currentSourcePubkeys = file
|
|
8
|
+
? Object.values(file)
|
|
9
|
+
: (sourcePubkeys ?? []);
|
|
10
|
+
const currentTargetPubkeys = file
|
|
11
|
+
? Object.keys(file).map(toHex)
|
|
12
|
+
: (targetPubkeys ?? []);
|
|
13
|
+
return {
|
|
14
|
+
sourcePubkeys: currentSourcePubkeys,
|
|
15
|
+
targetPubkeys: currentTargetPubkeys,
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
export const validateConsolidationInput = (sourcePubkeys, targetPubkeys, dashboard, refundRecipient) => {
|
|
19
|
+
const sourcePubkeysFlat = sourcePubkeys.flat();
|
|
20
|
+
validatePubkeys(sourcePubkeysFlat);
|
|
21
|
+
validatePubkeys(targetPubkeys);
|
|
22
|
+
if (sourcePubkeys.length !== targetPubkeys.length) {
|
|
23
|
+
throw new Error('sourcePubkeys and targetPubkeys must have the same length');
|
|
24
|
+
}
|
|
25
|
+
if (refundRecipient != null && refundRecipient === zeroAddress) {
|
|
26
|
+
throw new Error('refundRecipient must be non-zero address');
|
|
27
|
+
}
|
|
28
|
+
if (dashboard === zeroAddress) {
|
|
29
|
+
throw new Error('dashboard address must be non-zero address');
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
const validatePubkeys = (pubkeys) => {
|
|
33
|
+
const invalid = pubkeys.filter((pubkey) => !(typeof pubkey === 'string' &&
|
|
34
|
+
isHex(pubkey) &&
|
|
35
|
+
hexToBytes(pubkey).length === 48));
|
|
36
|
+
if (invalid.length > 0) {
|
|
37
|
+
throw new Error('Invalid pubkeys (must be hex 0x + 48 bytes):\n' + invalid.join('\n'));
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=checks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checks.js","sourceRoot":"","sources":["../../../utils/consolidation/checks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,UAAU,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AACpE,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAI9B,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAC9B,IAAe,EACf,aAAsB,EACtB,aAAoB,EACpB,EAAE;IACF,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,aAAa,IAAI,aAAa,CAAC,EAAE,CAAC;QAC/C,MAAM,IAAI,KAAK,CACb,8DAA8D,CAC/D,CAAC;IACJ,CAAC;IAED,MAAM,oBAAoB,GAAG,IAAI;QAC/B,CAAC,CAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAa;QAClC,CAAC,CAAC,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;IAC1B,MAAM,oBAAoB,GAAG,IAAI;QAC/B,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC;QAC9B,CAAC,CAAC,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;IAE1B,OAAO;QACL,aAAa,EAAE,oBAAoB;QACnC,aAAa,EAAE,oBAAoB;KACpC,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,CACxC,aAAsB,EACtB,aAAoB,EACpB,SAAkB,EAClB,eAAyB,EACzB,EAAE;IACF,MAAM,iBAAiB,GAAG,aAAa,CAAC,IAAI,EAAE,CAAC;IAC/C,eAAe,CAAC,iBAAiB,CAAC,CAAC;IACnC,eAAe,CAAC,aAAa,CAAC,CAAC;IAE/B,IAAI,aAAa,CAAC,MAAM,KAAK,aAAa,CAAC,MAAM,EAAE,CAAC;QAClD,MAAM,IAAI,KAAK,CACb,2DAA2D,CAC5D,CAAC;IACJ,CAAC;IACD,IAAI,eAAe,IAAI,IAAI,IAAI,eAAe,KAAK,WAAW,EAAE,CAAC;QAC/D,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;IAC9D,CAAC;IACD,IAAI,SAAS,KAAK,WAAW,EAAE,CAAC;QAC9B,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;IAChE,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,eAAe,GAAG,CAAC,OAAc,EAAE,EAAE;IACzC,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAC5B,CAAC,MAAM,EAAE,EAAE,CACT,CAAC,CACC,OAAO,MAAM,KAAK,QAAQ;QAC1B,KAAK,CAAC,MAAM,CAAC;QACb,UAAU,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,EAAE,CACjC,CACJ,CAAC;IACF,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CACb,gDAAgD,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CACtE,CAAC;IACJ,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
import { TargetAndSourceValidators } from './types.js';
|
|
3
|
+
export declare const confirmToConsolidate: (targetAndSourceValidators: TargetAndSourceValidators, dashboard: Address) => Promise<void>;
|
|
4
|
+
export declare const calculateAndConfirmFeeExemption: (targetAndSourceValidators: TargetAndSourceValidators) => Promise<bigint>;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
import { logCancel, confirmOperation } from '../index.js';
|
|
3
|
+
export const confirmToConsolidate = async (targetAndSourceValidators, dashboard) => {
|
|
4
|
+
const lines = [
|
|
5
|
+
'Are you sure you want to consolidate the following validators?\n',
|
|
6
|
+
];
|
|
7
|
+
for (const [target, { sourceValidators }] of targetAndSourceValidators) {
|
|
8
|
+
for (const [source] of sourceValidators) {
|
|
9
|
+
lines.push(`Source: ${source}\nTarget: ${target}\n`);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
lines.push(`Dashboard: ${dashboard}`);
|
|
13
|
+
const confirm = await confirmOperation(lines.join('\n'));
|
|
14
|
+
if (!confirm) {
|
|
15
|
+
logCancel('User cancelled confirmation to consolidate');
|
|
16
|
+
throw new Error('User cancelled consolidation');
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
export const calculateAndConfirmFeeExemption = async (targetAndSourceValidators) => {
|
|
20
|
+
let feeExemption = 0n;
|
|
21
|
+
for (const [, { sourceValidators }] of targetAndSourceValidators) {
|
|
22
|
+
for (const [source, sourceValidatorInfo] of sourceValidators) {
|
|
23
|
+
if (sourceValidatorInfo.status === 'active_ongoing') {
|
|
24
|
+
feeExemption += sourceValidatorInfo.effectiveBalance;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
const confirm = await confirmOperation(`Validator with this pubkey ${source} is not in active state. Should we consider its balance for fee exemption?`);
|
|
28
|
+
if (confirm) {
|
|
29
|
+
feeExemption += sourceValidatorInfo.effectiveBalance;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
const confirmFeeExemption = await confirmOperation(`Fee Exemption: ${formatEther(feeExemption)} ETH. Continue?`);
|
|
35
|
+
if (!confirmFeeExemption) {
|
|
36
|
+
logCancel('User cancelled fee exemption confirmation');
|
|
37
|
+
throw new Error('User cancelled consolidation');
|
|
38
|
+
}
|
|
39
|
+
return feeExemption;
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=confirms.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"confirms.js","sourceRoot":"","sources":["../../../utils/consolidation/confirms.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AAIpD,MAAM,CAAC,MAAM,oBAAoB,GAAG,KAAK,EACvC,yBAAoD,EACpD,SAAkB,EACH,EAAE;IACjB,MAAM,KAAK,GAAa;QACtB,kEAAkE;KACnE,CAAC;IACF,KAAK,MAAM,CAAC,MAAM,EAAE,EAAE,gBAAgB,EAAE,CAAC,IAAI,yBAAyB,EAAE,CAAC;QACvE,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,gBAAgB,EAAE,CAAC;YACxC,KAAK,CAAC,IAAI,CAAC,WAAW,MAAM,aAAa,MAAM,IAAI,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IACD,KAAK,CAAC,IAAI,CAAC,cAAc,SAAS,EAAE,CAAC,CAAC;IACtC,MAAM,OAAO,GAAG,MAAM,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAEzD,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,SAAS,CAAC,4CAA4C,CAAC,CAAC;QAExD,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IAClD,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,+BAA+B,GAAG,KAAK,EAClD,yBAAoD,EACnC,EAAE;IACnB,IAAI,YAAY,GAAG,EAAE,CAAC;IAEtB,KAAK,MAAM,CAAC,EAAE,EAAE,gBAAgB,EAAE,CAAC,IAAI,yBAAyB,EAAE,CAAC;QACjE,KAAK,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,IAAI,gBAAgB,EAAE,CAAC;YAC7D,IAAI,mBAAmB,CAAC,MAAM,KAAK,gBAAgB,EAAE,CAAC;gBACpD,YAAY,IAAI,mBAAmB,CAAC,gBAAgB,CAAC;YACvD,CAAC;iBAAM,CAAC;gBACN,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,8BAA8B,MAAM,4EAA4E,CACjH,CAAC;gBACF,IAAI,OAAO,EAAE,CAAC;oBACZ,YAAY,IAAI,mBAAmB,CAAC,gBAAgB,CAAC;gBACvD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,mBAAmB,GAAG,MAAM,gBAAgB,CAChD,kBAAkB,WAAW,CAAC,YAAY,CAAC,iBAAiB,CAC7D,CAAC;IAEF,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzB,SAAS,CAAC,2CAA2C,CAAC,CAAC;QAEvD,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IAClD,CAAC;IAED,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../utils/consolidation/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,cAAc,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { TargetAndSourceValidators } from './types.js';
|
|
2
|
+
export declare const logAllTargetValidatorsTable: (targetAndSourceValidators: TargetAndSourceValidators) => Promise<void>;
|
|
3
|
+
export declare const logAllSourceValidatorsTable: (targetAndSourceValidators: TargetAndSourceValidators) => Promise<void>;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { formatUnits } from 'viem';
|
|
2
|
+
import { logInfo, logTable } from '../index.js';
|
|
3
|
+
export const logAllTargetValidatorsTable = async (targetAndSourceValidators) => {
|
|
4
|
+
const rows = [];
|
|
5
|
+
for (const [target, { info: targetValidatorInfo },] of targetAndSourceValidators) {
|
|
6
|
+
rows.push([
|
|
7
|
+
target,
|
|
8
|
+
targetValidatorInfo.status,
|
|
9
|
+
`${formatUnits(targetValidatorInfo.balance, 18)} ETH`,
|
|
10
|
+
`${formatUnits(targetValidatorInfo.effectiveBalance, 18)} ETH`,
|
|
11
|
+
targetValidatorInfo.index,
|
|
12
|
+
]);
|
|
13
|
+
}
|
|
14
|
+
logInfo('Target Validators Info');
|
|
15
|
+
logTable({
|
|
16
|
+
params: {
|
|
17
|
+
head: ['Pubkey', 'Status', 'Balance', 'Effective Balance', 'index'],
|
|
18
|
+
},
|
|
19
|
+
data: rows,
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
export const logAllSourceValidatorsTable = async (targetAndSourceValidators) => {
|
|
23
|
+
const rows = [];
|
|
24
|
+
for (const [, { sourceValidators }] of targetAndSourceValidators) {
|
|
25
|
+
for (const [source, sourceValidatorInfo] of sourceValidators) {
|
|
26
|
+
rows.push([
|
|
27
|
+
source,
|
|
28
|
+
sourceValidatorInfo.status,
|
|
29
|
+
`${formatUnits(sourceValidatorInfo.balance, 18)} ETH`,
|
|
30
|
+
`${formatUnits(sourceValidatorInfo.effectiveBalance, 18)} ETH`,
|
|
31
|
+
sourceValidatorInfo.index,
|
|
32
|
+
]);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
logInfo('Source Validators Info');
|
|
36
|
+
logTable({
|
|
37
|
+
params: {
|
|
38
|
+
head: ['Pubkey', 'Status', 'Balance', 'Effective Balance', 'index'],
|
|
39
|
+
},
|
|
40
|
+
data: rows,
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=logs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../utils/consolidation/logs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAI1C,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,yBAAoD,EACpD,EAAE;IACF,MAAM,IAAI,GAAoD,EAAE,CAAC;IAEjE,KAAK,MAAM,CACT,MAAM,EACN,EAAE,IAAI,EAAE,mBAAmB,EAAE,EAC9B,IAAI,yBAAyB,EAAE,CAAC;QAC/B,IAAI,CAAC,IAAI,CAAC;YACR,MAAM;YACN,mBAAmB,CAAC,MAAM;YAC1B,GAAG,WAAW,CAAC,mBAAmB,CAAC,OAAO,EAAE,EAAE,CAAC,MAAM;YACrD,GAAG,WAAW,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,EAAE,CAAC,MAAM;YAC9D,mBAAmB,CAAC,KAAK;SAC1B,CAAC,CAAC;IACL,CAAC;IAED,OAAO,CAAC,wBAAwB,CAAC,CAAC;IAClC,QAAQ,CAAC;QACP,MAAM,EAAE;YACN,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,mBAAmB,EAAE,OAAO,CAAC;SACpE;QACD,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,yBAAoD,EACpD,EAAE;IACF,MAAM,IAAI,GAAoD,EAAE,CAAC;IAEjE,KAAK,MAAM,CAAC,EAAE,EAAE,gBAAgB,EAAE,CAAC,IAAI,yBAAyB,EAAE,CAAC;QACjE,KAAK,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,IAAI,gBAAgB,EAAE,CAAC;YAC7D,IAAI,CAAC,IAAI,CAAC;gBACR,MAAM;gBACN,mBAAmB,CAAC,MAAM;gBAC1B,GAAG,WAAW,CAAC,mBAAmB,CAAC,OAAO,EAAE,EAAE,CAAC,MAAM;gBACrD,GAAG,WAAW,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,EAAE,CAAC,MAAM;gBAC9D,mBAAmB,CAAC,KAAK;aAC1B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,CAAC,wBAAwB,CAAC,CAAC;IAClC,QAAQ,CAAC;QACP,MAAM,EAAE;YACN,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,mBAAmB,EAAE,OAAO,CAAC;SACpE;QACD,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;AACL,CAAC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Hex } from 'viem';
|
|
2
|
+
import { TargetAndSourceValidators } from './types.js';
|
|
3
|
+
export declare const flattenSourcePubkeys: (targetAndSourceValidators: TargetAndSourceValidators) => `0x${string}`[];
|
|
4
|
+
export declare const getSourceAndTargetPubkeysFromEncodedCall: (encodedCall: Hex) => {
|
|
5
|
+
sourcePubkey: Hex;
|
|
6
|
+
targetPubkey: Hex;
|
|
7
|
+
};
|
|
8
|
+
export declare const addDummyTargetAndSourceValidator: (targetAndSourceValidators: TargetAndSourceValidators, feeExemption: bigint) => void;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { bytesToHex, hexToBytes } from 'viem';
|
|
2
|
+
export const flattenSourcePubkeys = (targetAndSourceValidators) => {
|
|
3
|
+
const targetPubkeys = [...targetAndSourceValidators.keys()];
|
|
4
|
+
return targetPubkeys.map((target) => {
|
|
5
|
+
const sourceMap = targetAndSourceValidators.get(target);
|
|
6
|
+
if (!sourceMap) {
|
|
7
|
+
throw new Error(`Target validator ${target} not found in map`);
|
|
8
|
+
}
|
|
9
|
+
const merged = [...sourceMap.sourceValidators.keys()]
|
|
10
|
+
.map((p) => p.replace(/^0x/, ''))
|
|
11
|
+
.join('');
|
|
12
|
+
return `0x${merged}`;
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
export const getSourceAndTargetPubkeysFromEncodedCall = (encodedCall) => {
|
|
16
|
+
const encodedCallBytes = hexToBytes(encodedCall);
|
|
17
|
+
const sourcePubkey = bytesToHex(encodedCallBytes.slice(0, encodedCallBytes.length / 2));
|
|
18
|
+
const targetPubkey = bytesToHex(encodedCallBytes.slice(encodedCallBytes.length / 2));
|
|
19
|
+
return { sourcePubkey, targetPubkey };
|
|
20
|
+
};
|
|
21
|
+
export const addDummyTargetAndSourceValidator = (targetAndSourceValidators, feeExemption) => {
|
|
22
|
+
targetAndSourceValidators.set('0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000', {
|
|
23
|
+
info: {
|
|
24
|
+
status: 'active_ongoing',
|
|
25
|
+
balance: feeExemption,
|
|
26
|
+
index: '0',
|
|
27
|
+
effectiveBalance: feeExemption,
|
|
28
|
+
},
|
|
29
|
+
sourceValidators: new Map([
|
|
30
|
+
[
|
|
31
|
+
'0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
|
32
|
+
{
|
|
33
|
+
status: 'active_ongoing',
|
|
34
|
+
balance: feeExemption,
|
|
35
|
+
index: '0',
|
|
36
|
+
effectiveBalance: feeExemption,
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
]),
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=pubkeys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pubkeys.js","sourceRoot":"","sources":["../../../utils/consolidation/pubkeys.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAO,UAAU,EAAE,MAAM,MAAM,CAAC;AAInD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAClC,yBAAoD,EACnC,EAAE;IACnB,MAAM,aAAa,GAAG,CAAC,GAAG,yBAAyB,CAAC,IAAI,EAAE,CAAC,CAAC;IAC5D,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;QAClC,MAAM,SAAS,GAAG,yBAAyB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACxD,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,oBAAoB,MAAM,mBAAmB,CAAC,CAAC;QACjE,CAAC;QAED,MAAM,MAAM,GAAG,CAAC,GAAG,SAAS,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;aAClD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;aAChC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEZ,OAAO,KAAK,MAAM,EAAE,CAAC;IACvB,CAAC,CAAoB,CAAC;AACxB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,wCAAwC,GAAG,CACtD,WAAgB,EAC0B,EAAE;IAC5C,MAAM,gBAAgB,GAAG,UAAU,CAAC,WAAW,CAAC,CAAC;IACjD,MAAM,YAAY,GAAG,UAAU,CAC7B,gBAAgB,CAAC,KAAK,CAAC,CAAC,EAAE,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CACvD,CAAC;IACF,MAAM,YAAY,GAAG,UAAU,CAC7B,gBAAgB,CAAC,KAAK,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CACpD,CAAC;IAEF,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC;AACxC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gCAAgC,GAAG,CAC9C,yBAAoD,EACpD,YAAoB,EACpB,EAAE;IACF,yBAAyB,CAAC,GAAG,CAC3B,oGAAoG,EACpG;QACE,IAAI,EAAE;YACJ,MAAM,EAAE,gBAAgB;YACxB,OAAO,EAAE,YAAY;YACrB,KAAK,EAAE,GAAG;YACV,gBAAgB,EAAE,YAAY;SAC/B;QACD,gBAAgB,EAAE,IAAI,GAAG,CAAC;YACxB;gBACE,oGAAoG;gBACpG;oBACE,MAAM,EAAE,gBAAgB;oBACxB,OAAO,EAAE,YAAY;oBACrB,KAAK,EAAE,GAAG;oBACV,gBAAgB,EAAE,YAAY;iBAC/B;aACF;SACF,CAAC;KACH,CACF,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Hex } from 'viem';
|
|
2
|
+
export type ValidatorInfo = {
|
|
3
|
+
status: string;
|
|
4
|
+
balance: bigint;
|
|
5
|
+
index: string;
|
|
6
|
+
effectiveBalance: bigint;
|
|
7
|
+
};
|
|
8
|
+
export type PubkeyMap = Record<Hex, Hex[]>;
|
|
9
|
+
export type TargetAndSourceValidators = Map<Hex, {
|
|
10
|
+
info: ValidatorInfo;
|
|
11
|
+
sourceValidators: Map<Hex, ValidatorInfo>;
|
|
12
|
+
}>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../utils/consolidation/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { Hex } from 'viem';
|
|
2
|
+
import { ValidatorsInfo } from '../fetchCL.js';
|
|
3
|
+
import { TargetAndSourceValidators } from './types.js';
|
|
4
|
+
export declare const getTargetAndSourceValidatorsInfo: (targetPubkeys: Hex[], targetValidatorsInfo: ValidatorsInfo, sourcePubkeys: Hex[][], sourceValidatorsInfo: ValidatorsInfo) => TargetAndSourceValidators;
|