@lidofinance/lsv-cli 1.1.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/Dashboard.d.ts +23 -3
- package/dist/abi/Dashboard.js +8 -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/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 +0 -14
- package/dist/abi/VaultViewer.js +0 -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/configs/constants.d.ts +44 -2
- package/dist/configs/constants.js +2 -2
- package/dist/configs/constants.js.map +1 -1
- package/dist/configs/deployed.d.ts +2 -2
- package/dist/configs/deployed.js +48 -6
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/utils.d.ts +1 -0
- package/dist/configs/utils.js +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 +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.js +2 -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.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/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 -1
- package/dist/features/index.js +4 -1
- 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/pdg.js +4 -0
- 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.js +2 -0
- package/dist/features/utils/quarantine.js.map +1 -1
- package/dist/features/utils/report-fresh.js +2 -3
- package/dist/features/utils/report-fresh.js.map +1 -1
- package/dist/features/vault-factory.js +2 -2
- 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 +11 -3
- 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 +1 -1
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +1 -1
- package/dist/features/vault-operations/vault-overview.js.map +1 -1
- package/dist/features/vault-operations/vault-roles.js +3 -0
- 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/index.js +7 -2
- 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 +42 -42
- 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/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 +2 -2
- 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 +90 -273
- 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 +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 +1 -0
- package/dist/programs/index.js +1 -0
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/pdg-helpers.js +19 -15
- 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 +2 -2
- package/dist/programs/use-cases/vault-operations/create-vault.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/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 +4 -0
- package/dist/utils/arguments.js +40 -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.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 +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/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.js +14 -9
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +5 -3
- package/dist/utils/transactions/tx-wc.js +21 -10
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/transactions/types.d.ts +4 -2
- package/dist/utils/wallet-connect.js +3 -3
- package/dist/utils/wallet-connect.js.map +1 -1
- package/dist/version/index.js +1 -1
- package/package.json +2 -2
- 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
|
@@ -0,0 +1,41 @@
|
|
|
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
|
+
targetValidatorInfo.index,
|
|
11
|
+
]);
|
|
12
|
+
}
|
|
13
|
+
logInfo('Target Validators Info');
|
|
14
|
+
logTable({
|
|
15
|
+
params: {
|
|
16
|
+
head: ['Pubkey', 'Status', 'Balance', 'index'],
|
|
17
|
+
},
|
|
18
|
+
data: rows,
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
export const logAllSourceValidatorsTable = async (targetAndSourceValidators) => {
|
|
22
|
+
const rows = [];
|
|
23
|
+
for (const [, { sourceValidators }] of targetAndSourceValidators) {
|
|
24
|
+
for (const [source, sourceValidatorInfo] of sourceValidators) {
|
|
25
|
+
rows.push([
|
|
26
|
+
source,
|
|
27
|
+
sourceValidatorInfo.status,
|
|
28
|
+
`${formatUnits(sourceValidatorInfo.balance, 18)} ETH`,
|
|
29
|
+
sourceValidatorInfo.index,
|
|
30
|
+
]);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
logInfo('Source Validators Info');
|
|
34
|
+
logTable({
|
|
35
|
+
params: {
|
|
36
|
+
head: ['Pubkey', 'Status', 'Balance', 'index'],
|
|
37
|
+
},
|
|
38
|
+
data: rows,
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
//# 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,GAA4C,EAAE,CAAC;IAEzD,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,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,OAAO,CAAC;SAC/C;QACD,IAAI,EAAE,IAAI;KACX,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,yBAAoD,EACpD,EAAE;IACF,MAAM,IAAI,GAA4C,EAAE,CAAC;IAEzD,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,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,OAAO,CAAC;SAC/C;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,40 @@
|
|
|
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
|
+
},
|
|
28
|
+
sourceValidators: new Map([
|
|
29
|
+
[
|
|
30
|
+
'0x000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000',
|
|
31
|
+
{
|
|
32
|
+
status: 'active_ongoing',
|
|
33
|
+
balance: feeExemption,
|
|
34
|
+
index: '0',
|
|
35
|
+
},
|
|
36
|
+
],
|
|
37
|
+
]),
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
//# 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;SACX;QACD,gBAAgB,EAAE,IAAI,GAAG,CAAC;YACxB;gBACE,oGAAoG;gBACpG;oBACE,MAAM,EAAE,gBAAgB;oBACxB,OAAO,EAAE,YAAY;oBACrB,KAAK,EAAE,GAAG;iBACX;aACF;SACF,CAAC;KACH,CACF,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Hex } from 'viem';
|
|
2
|
+
export type ValidatorInfo = {
|
|
3
|
+
status: string;
|
|
4
|
+
balance: bigint;
|
|
5
|
+
index: string;
|
|
6
|
+
};
|
|
7
|
+
export type PubkeyMap = Record<Hex, Hex[]>;
|
|
8
|
+
export type TargetAndSourceValidators = Map<Hex, {
|
|
9
|
+
info: ValidatorInfo;
|
|
10
|
+
sourceValidators: Map<Hex, ValidatorInfo>;
|
|
11
|
+
}>;
|
|
@@ -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;
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { parseGwei } from 'viem';
|
|
2
|
+
export const getTargetAndSourceValidatorsInfo = (targetPubkeys, targetValidatorsInfo, sourcePubkeys, sourceValidatorsInfo) => {
|
|
3
|
+
const targetAndSourceValidatorsInfo = new Map();
|
|
4
|
+
targetPubkeys.forEach((targetPubkey, i) => {
|
|
5
|
+
const targetValidatorInfo = targetValidatorsInfo.data.find((validator) => validator.validator.pubkey === targetPubkey);
|
|
6
|
+
if (!targetValidatorInfo) {
|
|
7
|
+
throw new Error(`Target validator with pubkey ${targetPubkey} not found`);
|
|
8
|
+
}
|
|
9
|
+
targetAndSourceValidatorsInfo.set(targetPubkey, {
|
|
10
|
+
info: {
|
|
11
|
+
status: targetValidatorInfo.status,
|
|
12
|
+
balance: parseGwei(targetValidatorInfo.balance),
|
|
13
|
+
index: targetValidatorInfo.index,
|
|
14
|
+
},
|
|
15
|
+
sourceValidators: new Map(),
|
|
16
|
+
});
|
|
17
|
+
const sourcePubkeysGroup = sourcePubkeys[i] ?? [];
|
|
18
|
+
sourcePubkeysGroup.forEach((sourcePubkey) => {
|
|
19
|
+
const sourceValidatorInfo = sourceValidatorsInfo.data.find((validator) => validator.validator.pubkey === sourcePubkey);
|
|
20
|
+
if (!sourceValidatorInfo) {
|
|
21
|
+
throw new Error(`Source validator with pubkey ${sourcePubkey} not found`);
|
|
22
|
+
}
|
|
23
|
+
targetAndSourceValidatorsInfo
|
|
24
|
+
.get(targetPubkey)
|
|
25
|
+
?.sourceValidators.set(sourcePubkey, {
|
|
26
|
+
status: sourceValidatorInfo.status,
|
|
27
|
+
balance: parseGwei(sourceValidatorInfo.balance),
|
|
28
|
+
index: sourceValidatorInfo.index,
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
return targetAndSourceValidatorsInfo;
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=validator-info.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validator-info.js","sourceRoot":"","sources":["../../../utils/consolidation/validator-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,SAAS,EAAE,MAAM,MAAM,CAAC;AAMtC,MAAM,CAAC,MAAM,gCAAgC,GAAG,CAC9C,aAAoB,EACpB,oBAAoC,EACpC,aAAsB,EACtB,oBAAoC,EACT,EAAE;IAC7B,MAAM,6BAA6B,GAA8B,IAAI,GAAG,EAAE,CAAC;IAC3E,aAAa,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,CAAC,EAAE,EAAE;QACxC,MAAM,mBAAmB,GAAG,oBAAoB,CAAC,IAAI,CAAC,IAAI,CACxD,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,KAAK,YAAY,CAC3D,CAAC;QACF,IAAI,CAAC,mBAAmB,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,gCAAgC,YAAY,YAAY,CAAC,CAAC;QAC5E,CAAC;QACD,6BAA6B,CAAC,GAAG,CAAC,YAAY,EAAE;YAC9C,IAAI,EAAE;gBACJ,MAAM,EAAE,mBAAmB,CAAC,MAAM;gBAClC,OAAO,EAAE,SAAS,CAAC,mBAAmB,CAAC,OAAO,CAAC;gBAC/C,KAAK,EAAE,mBAAmB,CAAC,KAAK;aACjC;YACD,gBAAgB,EAAE,IAAI,GAAG,EAAE;SAC5B,CAAC,CAAC;QACH,MAAM,kBAAkB,GAAG,aAAa,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QAClD,kBAAkB,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,EAAE;YAC1C,MAAM,mBAAmB,GAAG,oBAAoB,CAAC,IAAI,CAAC,IAAI,CACxD,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,KAAK,YAAY,CAC3D,CAAC;YACF,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBACzB,MAAM,IAAI,KAAK,CACb,gCAAgC,YAAY,YAAY,CACzD,CAAC;YACJ,CAAC;YACD,6BAA6B;iBAC1B,GAAG,CAAC,YAAY,CAAC;gBAClB,EAAE,gBAAgB,CAAC,GAAG,CAAC,YAAY,EAAE;gBACnC,MAAM,EAAE,mBAAmB,CAAC,MAAM;gBAClC,OAAO,EAAE,SAAS,CAAC,mBAAmB,CAAC,OAAO,CAAC;gBAC/C,KAAK,EAAE,mBAAmB,CAAC,KAAK;aACjC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IACH,OAAO,6BAA6B,CAAC;AACvC,CAAC,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Hex } from 'viem';
|
|
2
|
+
import { ValidatorsInfo } from '../fetchCL.js';
|
|
3
|
+
import { TargetAndSourceValidators } from './types.js';
|
|
4
|
+
export declare const getValidatorsInfo: (sourcePubkeys: Hex[][], targetPubkeys: Hex[]) => Promise<{
|
|
5
|
+
sourceValidatorsInfo: ValidatorsInfo;
|
|
6
|
+
targetValidatorsInfo: ValidatorsInfo;
|
|
7
|
+
}>;
|
|
8
|
+
export declare const checkSourceValidators: (sourceValidatorsInfoData: ValidatorsInfo["data"], finalizedEpoch: number) => void;
|
|
9
|
+
export declare const checkTargetValidators: (targetValidatorsInfoData: ValidatorsInfo["data"]) => void;
|
|
10
|
+
export declare const removeInactiveValidators: (targetAndSourceValidators: TargetAndSourceValidators) => void;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import assert from 'assert';
|
|
2
|
+
import { finalityCheckpoints, fetchValidatorsInfo, } from '../fetchCL.js';
|
|
3
|
+
const MIN_256_EPOCHS = 256;
|
|
4
|
+
export const getValidatorsInfo = async (sourcePubkeys, targetPubkeys) => {
|
|
5
|
+
const finalityCheckpointsInfo = await finalityCheckpoints();
|
|
6
|
+
const finalizedEpoch = Number(finalityCheckpointsInfo.data.finalized.epoch);
|
|
7
|
+
const sourcePubkeysFlat = sourcePubkeys.flat();
|
|
8
|
+
const [sourceValidatorsInfo, targetValidatorsInfo] = await Promise.all([
|
|
9
|
+
fetchValidatorsInfo(sourcePubkeysFlat),
|
|
10
|
+
fetchValidatorsInfo(targetPubkeys),
|
|
11
|
+
]);
|
|
12
|
+
if (sourceValidatorsInfo.data == null) {
|
|
13
|
+
throw new Error('sourceValidatorsInfo.data is null');
|
|
14
|
+
}
|
|
15
|
+
if (targetValidatorsInfo.data == null) {
|
|
16
|
+
throw new Error('targetValidatorsInfo.data is null');
|
|
17
|
+
}
|
|
18
|
+
checkSourceValidators(sourceValidatorsInfo.data, finalizedEpoch);
|
|
19
|
+
checkTargetValidators(targetValidatorsInfo.data);
|
|
20
|
+
return {
|
|
21
|
+
sourceValidatorsInfo,
|
|
22
|
+
targetValidatorsInfo,
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
export const checkSourceValidators = (sourceValidatorsInfoData, finalizedEpoch) => {
|
|
26
|
+
const incorrectWCSourceValidators = sourceValidatorsInfoData.filter((validator) => !validator.validator.withdrawal_credentials.startsWith('0x01') &&
|
|
27
|
+
!validator.validator.withdrawal_credentials.startsWith('0x02'));
|
|
28
|
+
assert(incorrectWCSourceValidators.length === 0, 'All source pubkeys must have a withdrawal credentials starting with 0x01 or 0x02. Wrong pubkeys:' +
|
|
29
|
+
incorrectWCSourceValidators.map((v) => v.validator.pubkey).join(', '));
|
|
30
|
+
const sourceValidatorsWithLess256Epochs = sourceValidatorsInfoData.filter((validator) => finalizedEpoch - Number(validator.validator.activation_epoch) <
|
|
31
|
+
MIN_256_EPOCHS);
|
|
32
|
+
assert(sourceValidatorsWithLess256Epochs.length === 0, 'All source pubkeys must have an activation epoch less than the finalized epoch by at least 256 epochs. Wrong pubkeys:' +
|
|
33
|
+
sourceValidatorsWithLess256Epochs
|
|
34
|
+
.map((v) => v.validator.pubkey)
|
|
35
|
+
.join(', '));
|
|
36
|
+
};
|
|
37
|
+
export const checkTargetValidators = (targetValidatorsInfoData) => {
|
|
38
|
+
const wrongWCTargetValidators = targetValidatorsInfoData.filter((validator) => !validator.validator.withdrawal_credentials.startsWith('0x02'));
|
|
39
|
+
assert(wrongWCTargetValidators.length === 0, 'All target pubkeys must have a withdrawal credentials starting with 0x02. Wrong pubkeys:' +
|
|
40
|
+
wrongWCTargetValidators.map((v) => v.validator.pubkey).join(', '));
|
|
41
|
+
};
|
|
42
|
+
export const removeInactiveValidators = (targetAndSourceValidators) => {
|
|
43
|
+
for (const [target, { sourceValidators }] of targetAndSourceValidators) {
|
|
44
|
+
const toDelete = [];
|
|
45
|
+
for (const [source, sourceValidatorInfo] of sourceValidators) {
|
|
46
|
+
if (sourceValidatorInfo.status !== 'active_ongoing') {
|
|
47
|
+
toDelete.push(source);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
for (const source of toDelete) {
|
|
51
|
+
sourceValidators.delete(source);
|
|
52
|
+
}
|
|
53
|
+
if (sourceValidators.size === 0) {
|
|
54
|
+
targetAndSourceValidators.delete(target);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
//# sourceMappingURL=validators-checks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators-checks.js","sourceRoot":"","sources":["../../../utils/consolidation/validators-checks.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/fetchCL.d.ts
CHANGED
|
@@ -3,30 +3,51 @@ import { Hex } from 'viem';
|
|
|
3
3
|
import { SupportedFork } from './proof/constants.js';
|
|
4
4
|
export type BlockId = RootHex | Slot | 'head' | 'genesis' | 'finalized';
|
|
5
5
|
export type StateId = RootHex | Slot | 'head' | 'genesis' | 'finalized' | 'justified';
|
|
6
|
-
type
|
|
6
|
+
export type ValidatorsInfo = {
|
|
7
|
+
execution_optimistic: boolean;
|
|
8
|
+
finalized: boolean;
|
|
9
|
+
data: [
|
|
10
|
+
{
|
|
11
|
+
index: string;
|
|
12
|
+
balance: string;
|
|
13
|
+
status: string;
|
|
14
|
+
validator: {
|
|
15
|
+
pubkey: string;
|
|
16
|
+
withdrawal_credentials: string;
|
|
17
|
+
effective_balance: string;
|
|
18
|
+
slashed: boolean;
|
|
19
|
+
activation_eligibility_epoch: string;
|
|
20
|
+
activation_epoch: string;
|
|
21
|
+
exit_epoch: string;
|
|
22
|
+
withdrawable_epoch: string;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
];
|
|
26
|
+
};
|
|
27
|
+
type FinalityCheckpoints = {
|
|
7
28
|
execution_optimistic: boolean;
|
|
8
29
|
finalized: boolean;
|
|
9
30
|
data: {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
withdrawable_epoch: string;
|
|
31
|
+
previous_justified: {
|
|
32
|
+
epoch: string;
|
|
33
|
+
root: string;
|
|
34
|
+
};
|
|
35
|
+
current_justified: {
|
|
36
|
+
epoch: string;
|
|
37
|
+
root: string;
|
|
38
|
+
};
|
|
39
|
+
finalized: {
|
|
40
|
+
epoch: string;
|
|
41
|
+
root: string;
|
|
22
42
|
};
|
|
23
43
|
};
|
|
24
44
|
};
|
|
45
|
+
export declare const finalityCheckpoints: (clURL?: string) => Promise<FinalityCheckpoints>;
|
|
25
46
|
export declare const fetchBeaconHeader: (stateId: StateId, clURL?: string) => Promise<any>;
|
|
26
47
|
export declare const fetchBeaconState: (stateId: StateId, clURL?: string) => Promise<{
|
|
27
48
|
stateBodyBytes: ArrayBuffer;
|
|
28
49
|
forkName: keyof typeof SupportedFork;
|
|
29
50
|
}>;
|
|
30
51
|
export declare const fetchBeaconHeaderByParentRoot: (parentRoot: RootHex, clURL?: string) => Promise<any>;
|
|
31
|
-
export declare const
|
|
52
|
+
export declare const fetchValidatorsInfo: (validatorPubkeys: Hex[], clURL?: string) => Promise<ValidatorsInfo>;
|
|
32
53
|
export {};
|
package/dist/utils/fetchCL.js
CHANGED
|
@@ -1,12 +1,78 @@
|
|
|
1
1
|
import { getConfig } from '../configs/index.js';
|
|
2
2
|
import { logError, printError } from './index.js';
|
|
3
3
|
import { SupportedFork } from './proof/constants.js';
|
|
4
|
+
const isFinalityCheckpoints = (obj) => {
|
|
5
|
+
return (obj &&
|
|
6
|
+
typeof obj === 'object' &&
|
|
7
|
+
isBool(obj.execution_optimistic) &&
|
|
8
|
+
isBool(obj.finalized) &&
|
|
9
|
+
isFinalityCheckpointsData(obj.data));
|
|
10
|
+
};
|
|
11
|
+
const isFinalityCheckpointsData = (obj) => {
|
|
12
|
+
return (obj &&
|
|
13
|
+
typeof obj === 'object' &&
|
|
14
|
+
isString(obj.previous_justified.epoch) &&
|
|
15
|
+
isString(obj.previous_justified.root) &&
|
|
16
|
+
isString(obj.current_justified.epoch) &&
|
|
17
|
+
isString(obj.current_justified.root) &&
|
|
18
|
+
isString(obj.finalized.epoch) &&
|
|
19
|
+
isString(obj.finalized.root));
|
|
20
|
+
};
|
|
21
|
+
const isString = (v) => typeof v === 'string';
|
|
22
|
+
const isBool = (v) => typeof v === 'boolean';
|
|
23
|
+
const isValidator = (obj) => {
|
|
24
|
+
return (obj &&
|
|
25
|
+
typeof obj === 'object' &&
|
|
26
|
+
isString(obj.index) &&
|
|
27
|
+
isString(obj.balance) &&
|
|
28
|
+
isString(obj.status) &&
|
|
29
|
+
obj.validator &&
|
|
30
|
+
typeof obj.validator === 'object' &&
|
|
31
|
+
isString(obj.validator.pubkey) &&
|
|
32
|
+
isString(obj.validator.withdrawal_credentials) &&
|
|
33
|
+
isString(obj.validator.effective_balance) &&
|
|
34
|
+
typeof obj.validator.slashed === 'boolean' &&
|
|
35
|
+
isString(obj.validator.activation_eligibility_epoch) &&
|
|
36
|
+
isString(obj.validator.activation_epoch) &&
|
|
37
|
+
isString(obj.validator.exit_epoch) &&
|
|
38
|
+
isString(obj.validator.withdrawable_epoch));
|
|
39
|
+
};
|
|
40
|
+
const isValidatorsInfoArray = (obj) => {
|
|
41
|
+
return (obj &&
|
|
42
|
+
typeof obj === 'object' &&
|
|
43
|
+
isBool(obj.execution_optimistic) &&
|
|
44
|
+
isBool(obj.finalized) &&
|
|
45
|
+
Array.isArray(obj.data) &&
|
|
46
|
+
obj.data.every(isValidator));
|
|
47
|
+
};
|
|
4
48
|
const endpoints = {
|
|
49
|
+
finalityCheckpoints: 'eth/v1/beacon/states/head/finality_checkpoints',
|
|
5
50
|
genesis: 'eth/v1/beacon/genesis',
|
|
6
51
|
beaconHeader: (blockId) => `eth/v1/beacon/headers/${blockId}`,
|
|
7
52
|
beaconHeadersByParentRoot: (parentRoot) => `eth/v1/beacon/headers?parent_root=${parentRoot}`,
|
|
8
53
|
state: (stateId) => `eth/v2/debug/beacon/states/${stateId}`,
|
|
9
|
-
|
|
54
|
+
validatorsInfo: (validatorsPubkeys) => `eth/v1/beacon/states/head/validators${validatorsPubkeys}`,
|
|
55
|
+
};
|
|
56
|
+
export const finalityCheckpoints = async (clURL) => {
|
|
57
|
+
const url = clURL || getConfig().CL_URL;
|
|
58
|
+
if (!url) {
|
|
59
|
+
throw new Error('CL_URL is not set. CL_URL is required for fetching epoch');
|
|
60
|
+
}
|
|
61
|
+
try {
|
|
62
|
+
const epochResp = await fetch(`${url.endsWith('/') ? url : url + '/'}${endpoints.finalityCheckpoints}`);
|
|
63
|
+
if (!epochResp.ok) {
|
|
64
|
+
throw new Error(`HTTP ${epochResp.status} ${epochResp.statusText}. URL: ${url}\n`);
|
|
65
|
+
}
|
|
66
|
+
const body = await epochResp.json();
|
|
67
|
+
if (!isFinalityCheckpoints(body)) {
|
|
68
|
+
throw new Error(`Response JSON is not of type FinalityCheckpoints.\nSnippet: ${JSON.stringify(body)}`);
|
|
69
|
+
}
|
|
70
|
+
return body;
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
printError(error, `Error fetching finality_сheckpoints. Used URL: ${url}. Please check if the CL_URL environment variable is correct or try to use another CL.`);
|
|
74
|
+
throw error;
|
|
75
|
+
}
|
|
10
76
|
};
|
|
11
77
|
export const fetchBeaconHeader = async (stateId, clURL) => {
|
|
12
78
|
const url = clURL || getConfig().CL_URL;
|
|
@@ -62,17 +128,24 @@ export const fetchBeaconHeaderByParentRoot = async (parentRoot, clURL) => {
|
|
|
62
128
|
throw error;
|
|
63
129
|
}
|
|
64
130
|
};
|
|
65
|
-
export const
|
|
131
|
+
export const fetchValidatorsInfo = async (validatorPubkeys, clURL) => {
|
|
66
132
|
const url = clURL || getConfig().CL_URL;
|
|
67
133
|
if (!url) {
|
|
68
134
|
throw new Error('CL_URL is not set. CL_URL is required for fetching validator info');
|
|
69
135
|
}
|
|
70
136
|
try {
|
|
71
|
-
const
|
|
72
|
-
|
|
137
|
+
const validatorsInfoResp = await fetch(`${url.endsWith('/') ? url : url + '/'}${endpoints.validatorsInfo('?id=' + validatorPubkeys.join(','))}`);
|
|
138
|
+
if (!validatorsInfoResp.ok) {
|
|
139
|
+
throw new Error(`HTTP ${validatorsInfoResp.status} ${validatorsInfoResp.statusText}. URL: ${url}\n`);
|
|
140
|
+
}
|
|
141
|
+
const body = await validatorsInfoResp.json();
|
|
142
|
+
if (!isValidatorsInfoArray(body)) {
|
|
143
|
+
throw new Error(`Response JSON is not of type ValidatorsInfo.\nSnippet: ${JSON.stringify(body)}`);
|
|
144
|
+
}
|
|
145
|
+
return body;
|
|
73
146
|
}
|
|
74
147
|
catch (error) {
|
|
75
|
-
printError(error, `Error fetching validator info. Used URL: ${url},
|
|
148
|
+
printError(error, `Error fetching validator info. Used URL: ${url}, validatorPubkeys: ${validatorPubkeys}. Please check if the CL_URL environment variable is correct or try to use another CL.`);
|
|
76
149
|
throw error;
|
|
77
150
|
}
|
|
78
151
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetchCL.js","sourceRoot":"","sources":["../../utils/fetchCL.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAG7C,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"fetchCL.js","sourceRoot":"","sources":["../../utils/fetchCL.ts"],"names":[],"mappings":"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"}
|