@lidofinance/lsv-cli 1.3.1 → 1.4.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/abi/AccessControlConfirmable.js.map +1 -1
- package/dist/abi/Dashboard.d.ts +24 -0
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.js.map +1 -1
- package/dist/abi/LidoLocator.js.map +1 -1
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/PredepositGuarantee.d.ts +48 -0
- package/dist/abi/PredepositGuarantee.js +32 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -1
- package/dist/abi/StEth.d.ts +1175 -59
- package/dist/abi/StEth.js +885 -320
- package/dist/abi/StEth.js.map +1 -1
- package/dist/abi/StakingVault.js.map +1 -1
- package/dist/abi/ValidatorConsolidationRequests.js.map +1 -1
- package/dist/abi/VaultFactory.js.map +1 -1
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.js.map +1 -1
- package/dist/abi/WstEth.js.map +1 -1
- package/dist/abi/defi-wrapper/Distributor.js.map +1 -1
- package/dist/abi/defi-wrapper/Factory.d.ts +532 -657
- package/dist/abi/defi-wrapper/Factory.js +1083 -647
- package/dist/abi/defi-wrapper/Factory.js.map +1 -1
- package/dist/abi/defi-wrapper/OssifiableProxy.d.ts +71 -0
- package/dist/abi/defi-wrapper/OssifiableProxy.js +93 -0
- package/dist/abi/defi-wrapper/OssifiableProxy.js.map +1 -0
- package/dist/abi/defi-wrapper/StrategyFactory.d.ts +59 -0
- package/dist/abi/defi-wrapper/StrategyFactory.js +37 -0
- package/dist/abi/defi-wrapper/StrategyFactory.js.map +1 -0
- package/dist/abi/defi-wrapper/StvPool.js.map +1 -1
- package/dist/abi/defi-wrapper/StvStETHPool.d.ts +38 -32
- package/dist/abi/defi-wrapper/StvStETHPool.js +50 -42
- package/dist/abi/defi-wrapper/StvStETHPool.js.map +1 -1
- package/dist/abi/defi-wrapper/TimeLock.d.ts +770 -0
- package/dist/abi/defi-wrapper/TimeLock.js +999 -0
- package/dist/abi/defi-wrapper/TimeLock.js.map +1 -0
- package/dist/abi/defi-wrapper/WithdrawalQueue.js.map +1 -1
- package/dist/abi/defi-wrapper/index.d.ts +3 -0
- package/dist/abi/defi-wrapper/index.js +3 -0
- package/dist/abi/defi-wrapper/index.js.map +1 -1
- package/dist/command/index.js +11 -0
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +4 -4
- package/dist/contracts/dashboard-impl.d.ts +4 -3
- package/dist/contracts/dashboard-impl.js +5 -8
- package/dist/contracts/dashboard-impl.js.map +1 -1
- package/dist/contracts/dashboard.d.ts +4 -3
- package/dist/contracts/dashboard.js +1 -1
- package/dist/contracts/dashboard.js.map +1 -1
- package/dist/contracts/defi-wrapper/distributor.d.ts +5 -4
- package/dist/contracts/defi-wrapper/distributor.js +2 -2
- package/dist/contracts/defi-wrapper/distributor.js.map +1 -1
- package/dist/contracts/defi-wrapper/factory.d.ts +5 -4
- package/dist/contracts/defi-wrapper/factory.js +2 -2
- package/dist/contracts/defi-wrapper/factory.js.map +1 -1
- package/dist/contracts/defi-wrapper/index.d.ts +3 -0
- package/dist/contracts/defi-wrapper/index.js +3 -0
- package/dist/contracts/defi-wrapper/index.js.map +1 -1
- package/dist/contracts/defi-wrapper/ossifiable-proxy.d.ts +5 -0
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js +12 -0
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js.map +1 -0
- package/dist/contracts/defi-wrapper/strategy-factory.d.ts +5 -0
- package/dist/contracts/defi-wrapper/strategy-factory.js +12 -0
- package/dist/contracts/defi-wrapper/strategy-factory.js.map +1 -0
- package/dist/contracts/defi-wrapper/stv-pool.d.ts +5 -4
- package/dist/contracts/defi-wrapper/stv-pool.js +2 -2
- package/dist/contracts/defi-wrapper/stv-pool.js.map +1 -1
- package/dist/contracts/defi-wrapper/stv-steth-pool.d.ts +5 -4
- package/dist/contracts/defi-wrapper/stv-steth-pool.js +2 -2
- package/dist/contracts/defi-wrapper/stv-steth-pool.js.map +1 -1
- package/dist/contracts/defi-wrapper/timelock.d.ts +5 -0
- package/dist/contracts/defi-wrapper/timelock.js +12 -0
- package/dist/contracts/defi-wrapper/timelock.js.map +1 -0
- package/dist/contracts/defi-wrapper/withdrawal-queue.d.ts +5 -4
- package/dist/contracts/defi-wrapper/withdrawal-queue.js +2 -2
- package/dist/contracts/defi-wrapper/withdrawal-queue.js.map +1 -1
- package/dist/contracts/lazy-oracle.d.ts +5 -3
- package/dist/contracts/lazy-oracle.js +5 -9
- package/dist/contracts/lazy-oracle.js.map +1 -1
- package/dist/contracts/locator.d.ts +4 -2
- package/dist/contracts/locator.js +5 -8
- package/dist/contracts/locator.js.map +1 -1
- package/dist/contracts/operator-grid.d.ts +5 -4
- package/dist/contracts/operator-grid.js +5 -8
- package/dist/contracts/operator-grid.js.map +1 -1
- package/dist/contracts/pdg.d.ts +5 -4
- package/dist/contracts/pdg.js +5 -8
- package/dist/contracts/pdg.js.map +1 -1
- package/dist/contracts/steth.d.ts +5 -27706
- package/dist/contracts/steth.js +6 -10
- package/dist/contracts/steth.js.map +1 -1
- package/dist/contracts/validator-consolidation-requests.d.ts +3 -3
- package/dist/contracts/validator-consolidation-requests.js.map +1 -1
- package/dist/contracts/vault-factory.d.ts +5 -3
- package/dist/contracts/vault-factory.js +6 -8
- package/dist/contracts/vault-factory.js.map +1 -1
- package/dist/contracts/vault-hub.d.ts +5 -3
- package/dist/contracts/vault-hub.js +5 -9
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +4 -2
- package/dist/contracts/vault-viewer.js +7 -10
- package/dist/contracts/vault-viewer.js.map +1 -1
- package/dist/contracts/vault.d.ts +5 -4
- package/dist/contracts/vault.js +2 -2
- package/dist/contracts/vault.js.map +1 -1
- package/dist/contracts/wsteth.d.ts +5 -3
- package/dist/contracts/wsteth.js +5 -9
- package/dist/contracts/wsteth.js.map +1 -1
- package/dist/features/consolidation.d.ts +1 -1
- package/dist/features/consolidation.js +19 -3
- package/dist/features/consolidation.js.map +1 -1
- package/dist/features/defi-wrapper/create-vault.js +19 -16
- package/dist/features/defi-wrapper/create-vault.js.map +1 -1
- package/dist/features/defi-wrapper/defi-wrapper-factory.d.ts +22 -29
- package/dist/features/defi-wrapper/defi-wrapper-factory.js +124 -17
- package/dist/features/defi-wrapper/defi-wrapper-factory.js.map +1 -1
- package/dist/features/defi-wrapper/distributor.d.ts +24 -0
- package/dist/features/defi-wrapper/distributor.js +300 -0
- package/dist/features/defi-wrapper/distributor.js.map +1 -0
- package/dist/features/defi-wrapper/index.d.ts +1 -0
- package/dist/features/defi-wrapper/index.js +1 -0
- package/dist/features/defi-wrapper/index.js.map +1 -1
- package/dist/features/defi-wrapper/pool-info.d.ts +17 -2
- package/dist/features/defi-wrapper/pool-info.js +63 -13
- package/dist/features/defi-wrapper/pool-info.js.map +1 -1
- package/dist/features/defi-wrapper/timelock.d.ts +19 -0
- package/dist/features/defi-wrapper/timelock.js +198 -0
- package/dist/features/defi-wrapper/timelock.js.map +1 -0
- package/dist/features/deposits/check-bls-deposits.js +15 -3
- package/dist/features/deposits/check-bls-deposits.js.map +1 -1
- package/dist/features/deposits/make-pdg-proof.js +19 -7
- package/dist/features/deposits/make-pdg-proof.js.map +1 -1
- package/dist/features/deposits/no-pdg.js +50 -14
- package/dist/features/deposits/no-pdg.js.map +1 -1
- package/dist/features/deposits/pdg.js +5 -1
- package/dist/features/deposits/pdg.js.map +1 -1
- package/dist/features/deposits/validators.js +1 -1
- package/dist/features/deposits/validators.js.map +1 -1
- package/dist/features/dev-tools/impersonate.js +5 -1
- package/dist/features/dev-tools/impersonate.js.map +1 -1
- package/dist/features/metrics.d.ts +3 -0
- package/dist/features/metrics.js +49 -6
- package/dist/features/metrics.js.map +1 -1
- package/dist/features/mint-burn/allowance.js +15 -6
- package/dist/features/mint-burn/allowance.js.map +1 -1
- package/dist/features/mint-burn/burn-steth.js +5 -1
- package/dist/features/mint-burn/burn-steth.js.map +1 -1
- package/dist/features/mint-burn/index.d.ts +1 -0
- package/dist/features/mint-burn/index.js +1 -0
- package/dist/features/mint-burn/index.js.map +1 -1
- package/dist/features/mint-burn/mint-limit.d.ts +9 -0
- package/dist/features/mint-burn/mint-limit.js +31 -0
- package/dist/features/mint-burn/mint-limit.js.map +1 -0
- package/dist/features/mint-burn/mint-steth.js +5 -1
- package/dist/features/mint-burn/mint-steth.js.map +1 -1
- package/dist/features/pdg.js +5 -1
- package/dist/features/pdg.js.map +1 -1
- package/dist/features/utils/connection.js +5 -1
- package/dist/features/utils/connection.js.map +1 -1
- 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/liability-shares.js +5 -1
- package/dist/features/utils/liability-shares.js.map +1 -1
- package/dist/features/utils/minting-capacity.js +4 -3
- package/dist/features/utils/minting-capacity.js.map +1 -1
- package/dist/features/utils/quarantine.js +5 -1
- package/dist/features/utils/quarantine.js.map +1 -1
- package/dist/features/utils/report-fresh.js +15 -3
- package/dist/features/utils/report-fresh.js.map +1 -1
- package/dist/features/utils/try-fetch.d.ts +5 -0
- package/dist/features/utils/try-fetch.js +26 -0
- package/dist/features/utils/try-fetch.js.map +1 -0
- package/dist/features/vault-factory.js +16 -4
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-operations/connect-vault.js +10 -2
- package/dist/features/vault-operations/connect-vault.js.map +1 -1
- package/dist/features/vault-operations/dashboard-by-vault.js +10 -2
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -1
- package/dist/features/vault-operations/index.d.ts +1 -0
- package/dist/features/vault-operations/index.js +1 -0
- package/dist/features/vault-operations/index.js.map +1 -1
- package/dist/features/vault-operations/roles.js +10 -2
- package/dist/features/vault-operations/roles.js.map +1 -1
- package/dist/features/vault-operations/share-limit.d.ts +8 -0
- package/dist/features/vault-operations/share-limit.js +20 -0
- package/dist/features/vault-operations/share-limit.js.map +1 -0
- package/dist/features/vault-operations/vault-health.js +5 -1
- package/dist/features/vault-operations/vault-health.js.map +1 -1
- package/dist/features/vault-operations/vault-info.js +10 -2
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +25 -5
- package/dist/features/vault-operations/vault-overview.js.map +1 -1
- package/dist/features/vault-operations/vault-roles.js +10 -2
- package/dist/features/vault-operations/vault-roles.js.map +1 -1
- package/dist/features/vault-operations/vaults-by-role.d.ts +24 -0
- package/dist/features/vault-operations/vaults-by-role.js +78 -27
- package/dist/features/vault-operations/vaults-by-role.js.map +1 -1
- package/dist/features/with-report.d.ts +1 -1
- package/dist/index.js +45 -16
- package/dist/index.js.map +1 -1
- package/dist/programs/account/main.d.ts +1 -1
- package/dist/programs/account/read.js +10 -5
- package/dist/programs/account/read.js.map +1 -1
- package/dist/programs/account/write.js +29 -2
- package/dist/programs/account/write.js.map +1 -1
- package/dist/programs/contracts/dashboard/main.d.ts +1 -1
- package/dist/programs/contracts/dashboard/read.js +15 -3
- package/dist/programs/contracts/dashboard/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/write.js +233 -52
- package/dist/programs/contracts/dashboard/write.js.map +1 -1
- package/dist/programs/contracts/hub/main.d.ts +1 -1
- package/dist/programs/contracts/hub/read.js +15 -5
- package/dist/programs/contracts/hub/read.js.map +1 -1
- package/dist/programs/contracts/hub/write.js +12 -3
- package/dist/programs/contracts/hub/write.js.map +1 -1
- package/dist/programs/contracts/lazy-oracle/main.d.ts +1 -1
- package/dist/programs/contracts/main.d.ts +1 -1
- package/dist/programs/contracts/operator-grid/main.d.ts +1 -1
- package/dist/programs/contracts/operator-grid/read.js +5 -1
- package/dist/programs/contracts/operator-grid/read.js.map +1 -1
- package/dist/programs/contracts/operator-grid/write.js +18 -10
- package/dist/programs/contracts/operator-grid/write.js.map +1 -1
- package/dist/programs/contracts/pdg/main.d.ts +1 -1
- package/dist/programs/contracts/pdg/read.js +5 -1
- package/dist/programs/contracts/pdg/read.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +34 -4
- package/dist/programs/contracts/pdg/write.js.map +1 -1
- package/dist/programs/contracts/vault/main.d.ts +1 -1
- package/dist/programs/contracts/vault/write.js +5 -1
- package/dist/programs/contracts/vault/write.js.map +1 -1
- package/dist/programs/contracts/vault-factory/main.d.ts +1 -1
- package/dist/programs/contracts/vault-viewer/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/read.js +19 -7
- package/dist/programs/defi-wrapper/contracts/distributor/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/write.js +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/read.js +75 -15
- package/dist/programs/defi-wrapper/contracts/factory/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/write.js +261 -67
- package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +64 -20
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.js +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js +64 -20
- 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 +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +66 -18
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +34 -7
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js.map +1 -1
- package/dist/programs/defi-wrapper/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/distributor/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/read.js +86 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js +191 -0
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/health/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/read.js +73 -23
- package/dist/programs/defi-wrapper/use-cases/health/read.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/utils.js +11 -3
- package/dist/programs/defi-wrapper/use-cases/health/utils.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/write.js +68 -25
- package/dist/programs/defi-wrapper/use-cases/health/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/index.js +2 -0
- package/dist/programs/defi-wrapper/use-cases/index.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js +362 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js +86 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js +369 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.d.ts +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js +7 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js +184 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/index.js +4 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js +80 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js +139 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js +118 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.js +1 -2
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/index.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js +334 -12
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js +449 -2
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js.map +1 -1
- package/dist/programs/dev-tools/anvil/main.d.ts +1 -1
- package/dist/programs/dev-tools/defi-wrapper/main.d.ts +1 -1
- package/dist/programs/dev-tools/defi-wrapper/write.js +42 -12
- package/dist/programs/dev-tools/defi-wrapper/write.js.map +1 -1
- package/dist/programs/dev-tools/main.d.ts +1 -1
- package/dist/programs/pdg-helpers.js +59 -19
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/use-cases/consolidation/main.d.ts +1 -1
- package/dist/programs/use-cases/consolidation/write.d.ts +1 -1
- package/dist/programs/use-cases/consolidation/write.js +6 -2
- package/dist/programs/use-cases/consolidation/write.js.map +1 -1
- package/dist/programs/use-cases/deposits/main.d.ts +1 -1
- package/dist/programs/use-cases/deposits/read.js +40 -8
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/write.js +15 -3
- package/dist/programs/use-cases/deposits/write.js.map +1 -1
- package/dist/programs/use-cases/metrics/main.d.ts +1 -1
- package/dist/programs/use-cases/metrics/read.js +32 -12
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/report/main.d.ts +1 -1
- package/dist/programs/use-cases/report/read.js +25 -5
- package/dist/programs/use-cases/report/read.js.map +1 -1
- package/dist/programs/use-cases/report/write.js +10 -2
- package/dist/programs/use-cases/report/write.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/main.d.ts +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +59 -21
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/index.d.ts +1 -1
- package/dist/providers/index.js +1 -1
- package/dist/providers/wallet.d.ts +302 -300
- package/dist/providers/wallet.js +10 -2
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/integration/deposits.test.js +1 -1
- package/dist/tests/integration/deposits.test.js.map +1 -1
- package/dist/tests/integration/helpers/test-client.d.ts +150 -150
- package/dist/tests/integration/metrics.test.js.map +1 -1
- package/dist/tests/integration/mint-burn.test.js.map +1 -1
- package/dist/tests/utils/calculate-overview-v2.test.js +1 -1
- package/dist/tests/utils/csv-file.test.js +1 -1
- package/dist/tests/utils/error-handler.test.js +5 -8
- package/dist/tests/utils/error-handler.test.js.map +1 -1
- package/dist/tests/utils/lido-apr.test.js +1 -1
- package/dist/tests/utils/logging.test.js +30 -14
- package/dist/tests/utils/logging.test.js.map +1 -1
- package/dist/tests/utils/rate-limit.test.d.ts +1 -0
- package/dist/tests/utils/rate-limit.test.js +246 -0
- package/dist/tests/utils/rate-limit.test.js.map +1 -0
- package/dist/tests/utils/rebase-rewards.test.js +44 -43
- package/dist/tests/utils/rebase-rewards.test.js.map +1 -1
- package/dist/tests/utils/report-statistic.test.d.ts +1 -0
- package/dist/tests/utils/report-statistic.test.js +501 -0
- package/dist/tests/utils/report-statistic.test.js.map +1 -0
- package/dist/tests/utils/snake-to-camel.test.js +1 -1
- package/dist/tests/utils/spinner.test.d.ts +1 -0
- package/dist/tests/utils/spinner.test.js +113 -0
- package/dist/tests/utils/spinner.test.js.map +1 -0
- package/dist/tests/utils/timestamp.test.js +1 -1
- package/dist/types/index.d.ts +2 -2
- package/dist/types/index.js +2 -2
- package/dist/utils/arguments.d.ts +15 -1
- package/dist/utils/arguments.js +28 -0
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/cache.d.ts +6 -5
- package/dist/utils/cache.js +15 -13
- package/dist/utils/cache.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +10 -6
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +9 -5
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +6 -6
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +12 -13
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
- package/dist/utils/charts/blessed/utils.js +5 -2
- package/dist/utils/charts/blessed/utils.js.map +1 -1
- package/dist/utils/charts/simple/simple-charts.js +20 -8
- package/dist/utils/charts/simple/simple-charts.js.map +1 -1
- package/dist/utils/commands/report.d.ts +5 -2
- package/dist/utils/commands/report.js +21 -7
- package/dist/utils/commands/report.js.map +1 -1
- package/dist/utils/consts.d.ts +1 -0
- package/dist/utils/consts.js +5 -0
- package/dist/utils/consts.js.map +1 -1
- package/dist/utils/error-handler.js +3 -0
- package/dist/utils/error-handler.js.map +1 -1
- package/dist/utils/fetchCL.d.ts +10 -0
- package/dist/utils/fetchCL.js +38 -28
- package/dist/utils/fetchCL.js.map +1 -1
- package/dist/utils/health/health-utils.d.ts +2 -27707
- package/dist/utils/health/health-utils.js +26 -8
- package/dist/utils/health/health-utils.js.map +1 -1
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +2 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/interrupt-handler.js +14 -6
- package/dist/utils/interrupt-handler.js.map +1 -1
- package/dist/utils/logging/console.d.ts +5 -1
- package/dist/utils/logging/console.js +36 -25
- package/dist/utils/logging/console.js.map +1 -1
- package/dist/utils/prompts/confirmations.d.ts +1 -1
- package/dist/utils/prompts/operations.d.ts +1 -1
- package/dist/utils/prompts/operations.js +1 -3
- package/dist/utils/prompts/operations.js.map +1 -1
- package/dist/utils/prompts/predeposit-guarantee.d.ts +1 -1
- package/dist/utils/prompts/predeposit-guarantee.js +1 -1
- package/dist/utils/proof/create-proof.js +18 -3
- package/dist/utils/proof/create-proof.js.map +1 -1
- package/dist/utils/rate-limit.d.ts +10 -0
- package/dist/utils/rate-limit.js +30 -0
- package/dist/utils/rate-limit.js.map +1 -0
- package/dist/utils/read-programs-by-abi.js +22 -4
- package/dist/utils/read-programs-by-abi.js.map +1 -1
- package/dist/utils/rebase-rewards.d.ts +0 -1
- package/dist/utils/rebase-rewards.js +12 -3
- package/dist/utils/rebase-rewards.js.map +1 -1
- package/dist/utils/report/statistic-data.js +31 -10
- package/dist/utils/report/statistic-data.js.map +1 -1
- package/dist/utils/share-rate.js +16 -4
- package/dist/utils/share-rate.js.map +1 -1
- package/dist/utils/sleep.js.map +1 -1
- package/dist/utils/spinner/spinners.js +5 -3
- package/dist/utils/spinner/spinners.js.map +1 -1
- package/dist/utils/statistic/report-statistic.d.ts +21 -6
- package/dist/utils/statistic/report-statistic.js +65 -25
- package/dist/utils/statistic/report-statistic.js.map +1 -1
- package/dist/utils/transactions/tx-private-key.d.ts +5 -7
- package/dist/utils/transactions/tx-private-key.js +56 -21
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +12 -11
- package/dist/utils/transactions/tx-wc.js +108 -11
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/transactions/types.d.ts +7 -0
- package/dist/utils/transactions/utils.d.ts +1 -0
- package/dist/utils/transactions/utils.js +13 -2
- package/dist/utils/transactions/utils.js.map +1 -1
- package/dist/utils/wallet-connect.d.ts +4 -1
- package/dist/utils/wallet-connect.js +52 -4
- package/dist/utils/wallet-connect.js.map +1 -1
- package/dist/utils/with-error.d.ts +7 -0
- package/dist/utils/with-error.js +6 -0
- package/dist/utils/with-error.js.map +1 -0
- package/dist/version/index.js +1 -1
- package/package.json +4 -13
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.js +0 -180
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/create-pool.js.map +0 -1
- /package/dist/programs/defi-wrapper/use-cases/{wrapper-operations/create-pool.d.ts → distributor/read.d.ts} +0 -0
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { fromHex } from 'viem';
|
|
2
|
-
import { getStvStethPoolContract, getStvPoolContract, } from '
|
|
3
|
-
import { callReadMethodSilent } from '../../utils/index.js';
|
|
4
|
-
import { reportFreshWarning } from '../index.js';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const
|
|
2
|
+
import { getStvStethPoolContract, getStvPoolContract, getWithdrawalQueueContract, } from 'contracts/defi-wrapper/index.js';
|
|
3
|
+
import { callReadMethodSilent, fetchAndCalculateVaultHealth } from '../../utils/index.js';
|
|
4
|
+
import { reportFreshWarning, vaultMintLimit } from '../index.js';
|
|
5
|
+
import { getDashboardContract, getStakingVaultContract } from '../../contracts/index.js';
|
|
6
|
+
import { bigIntMax } from 'utils/bigInt.js';
|
|
7
|
+
export const STV_POOL_NAME = 'StvPool';
|
|
8
|
+
export const STV_STETH_POOL_NAME = 'StvStETHPool';
|
|
9
|
+
export const STV_STRATEGY_POOL_NAME = 'StvStrategyPool';
|
|
8
10
|
const getStvPoolInfo = async (address) => {
|
|
9
11
|
const contract = await getStvPoolContract(address);
|
|
10
12
|
const [vault, stETH, Dashboard, VaultHub, WithdrawalQueue, Distributor, poolType, totalNominalAssets, totalAssets, totalSupply, totalLiabilityShares, totalUnassignedLiabilityShares, totalUnassignedLiabilitySteth, decimals, DEPOSITS_FEATURE, ALLOW_LIST_ENABLED, allowListSize,] = await Promise.all([
|
|
@@ -26,8 +28,16 @@ const getStvPoolInfo = async (address) => {
|
|
|
26
28
|
contract.read.ALLOW_LIST_ENABLED(),
|
|
27
29
|
contract.read.getAllowListSize(),
|
|
28
30
|
]);
|
|
29
|
-
const
|
|
31
|
+
const wqContract = await getWithdrawalQueueContract(WithdrawalQueue);
|
|
32
|
+
const vaultContract = await getStakingVaultContract(vault);
|
|
33
|
+
const [isDepositsPaused, unfinalizedAssets, availableVaultBalance] = await Promise.all([
|
|
34
|
+
contract.read.isFeaturePaused([DEPOSITS_FEATURE]),
|
|
35
|
+
wqContract.read.unfinalizedAssets(),
|
|
36
|
+
vaultContract.read.availableBalance(),
|
|
37
|
+
]);
|
|
38
|
+
const availableAssetsForCLDeposit = bigIntMax(availableVaultBalance - unfinalizedAssets, 0n);
|
|
30
39
|
const isReportFresh = await reportFreshWarning(vault);
|
|
40
|
+
const { healthRatio, isHealthy, liabilitySharesInSteth: totalLiabilitySteth, } = await fetchAndCalculateVaultHealth(await getDashboardContract(Dashboard));
|
|
31
41
|
return {
|
|
32
42
|
vault,
|
|
33
43
|
stETH,
|
|
@@ -40,41 +50,81 @@ const getStvPoolInfo = async (address) => {
|
|
|
40
50
|
totalAssets,
|
|
41
51
|
totalSupply,
|
|
42
52
|
totalLiabilityShares,
|
|
53
|
+
totalLiabilitySteth,
|
|
54
|
+
healthRatio,
|
|
55
|
+
isHealthy,
|
|
43
56
|
totalUnassignedLiabilityShares,
|
|
44
57
|
totalUnassignedLiabilitySteth,
|
|
58
|
+
unfinalizedAssets,
|
|
59
|
+
availableVaultBalance,
|
|
45
60
|
decimals,
|
|
46
61
|
isDepositsPaused,
|
|
47
62
|
ALLOW_LIST_ENABLED,
|
|
48
63
|
DEPOSITS_FEATURE,
|
|
49
64
|
allowListSize,
|
|
50
65
|
isReportFresh,
|
|
66
|
+
availableAssetsForCLDeposit,
|
|
51
67
|
};
|
|
52
68
|
};
|
|
69
|
+
export const areVaultParamsInSync = async (poolAddress) => {
|
|
70
|
+
const pool = await getStvStethPoolContract(poolAddress);
|
|
71
|
+
const poolType = await pool.read.poolType();
|
|
72
|
+
const dashboardAddress = await pool.read.DASHBOARD();
|
|
73
|
+
const dashboard = await getDashboardContract(dashboardAddress);
|
|
74
|
+
const poolTypeName = fromHex(poolType, 'string').replace(/\W/g, '');
|
|
75
|
+
const isStvStethPool = poolTypeName === STV_STETH_POOL_NAME ||
|
|
76
|
+
poolTypeName === STV_STRATEGY_POOL_NAME;
|
|
77
|
+
if (!isStvStethPool) {
|
|
78
|
+
throw new Error(`The pool at address ${poolAddress} is not an StvStEth or StvStrategy pool. This operation is only applicable to StvStEth and StvStrategy pools.`);
|
|
79
|
+
}
|
|
80
|
+
const [{ reserveRatioBP: vaultReserveRatioBP, forcedRebalanceThresholdBP: vaultForcedRebalanceThresholdBP, }, poolForcedRebalanceThresholdBP, poolReserveRatioBP, RESERVE_RATIO_GAP_BP,] = await Promise.all([
|
|
81
|
+
dashboard.read.vaultConnection(),
|
|
82
|
+
pool.read.poolForcedRebalanceThresholdBP(),
|
|
83
|
+
pool.read.poolReserveRatioBP(),
|
|
84
|
+
pool.read.RESERVE_RATIO_GAP_BP(),
|
|
85
|
+
]);
|
|
86
|
+
const isInSync = poolReserveRatioBP == BigInt(vaultReserveRatioBP) + RESERVE_RATIO_GAP_BP &&
|
|
87
|
+
poolForcedRebalanceThresholdBP ==
|
|
88
|
+
BigInt(vaultForcedRebalanceThresholdBP) + RESERVE_RATIO_GAP_BP;
|
|
89
|
+
return isInSync;
|
|
90
|
+
};
|
|
53
91
|
const getStvStethPoolInfo = async (address) => {
|
|
54
92
|
const contract = await getStvStethPoolContract(address);
|
|
55
|
-
const [WSTETH, RESERVE_RATIO_GAP_BP, totalMintedStethShares,
|
|
93
|
+
const [WSTETH, DASHBOARD, RESERVE_RATIO_GAP_BP, totalMintedStethShares, poolReserveRatioBP, poolForcedRebalanceThresholdBP, totalExceedingMintedStethShares, totalExceedingMintedSteth, maxLossSocializationBP, MINTING_FEATURE,] = await Promise.all([
|
|
56
94
|
contract.read.WSTETH(),
|
|
95
|
+
contract.read.DASHBOARD(),
|
|
57
96
|
contract.read.RESERVE_RATIO_GAP_BP(),
|
|
58
97
|
contract.read.totalMintedStethShares(),
|
|
59
|
-
contract.read.
|
|
60
|
-
contract.read.
|
|
98
|
+
contract.read.poolReserveRatioBP(),
|
|
99
|
+
contract.read.poolForcedRebalanceThresholdBP(),
|
|
61
100
|
contract.read.totalExceedingMintedStethShares(),
|
|
62
101
|
contract.read.totalExceedingMintedSteth(),
|
|
63
102
|
contract.read.maxLossSocializationBP(),
|
|
64
103
|
contract.read.MINTING_FEATURE(),
|
|
65
104
|
]);
|
|
66
|
-
const isMintingPaused = await callReadMethodSilent(
|
|
105
|
+
const isMintingPaused = await callReadMethodSilent({
|
|
106
|
+
contract,
|
|
107
|
+
methodName: 'isFeaturePaused',
|
|
108
|
+
payload: [[MINTING_FEATURE]],
|
|
109
|
+
});
|
|
110
|
+
const { liabilityShares, remainingMintingCapacityShares, totalMintingCapacityShares, } = await vaultMintLimit(await getDashboardContract(DASHBOARD));
|
|
111
|
+
const isInSync = await areVaultParamsInSync(address);
|
|
67
112
|
return {
|
|
68
113
|
WSTETH,
|
|
114
|
+
DASHBOARD,
|
|
69
115
|
RESERVE_RATIO_GAP_BP,
|
|
70
116
|
totalMintedStethShares,
|
|
71
|
-
|
|
72
|
-
|
|
117
|
+
poolReserveRatioBP,
|
|
118
|
+
poolForcedRebalanceThresholdBP,
|
|
73
119
|
totalExceedingMintedStethShares,
|
|
74
120
|
totalExceedingMintedSteth,
|
|
121
|
+
liabilityShares,
|
|
122
|
+
remainingMintingCapacityShares,
|
|
123
|
+
totalMintingCapacityShares,
|
|
75
124
|
maxLossSocializationBP,
|
|
76
125
|
isMintingPaused,
|
|
77
126
|
MINTING_FEATURE,
|
|
127
|
+
isInSync,
|
|
78
128
|
};
|
|
79
129
|
};
|
|
80
130
|
export const getPoolInfo = async (address) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pool-info.js","sourceRoot":"","sources":["../../../features/defi-wrapper/pool-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,OAAO,EAAE,MAAM,MAAM,CAAC;AACxC,OAAO,EACL,uBAAuB,EACvB,kBAAkB,
|
|
1
|
+
{"version":3,"file":"pool-info.js","sourceRoot":"","sources":["../../../features/defi-wrapper/pool-info.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Address, Hex, GetContractReturnType, PublicClient, Abi } from 'viem';
|
|
2
|
+
import { TimeLockContract } from 'contracts/defi-wrapper/index.js';
|
|
3
|
+
export declare const DEFAULT_SALT: "0x0000000000000000000000000000000000000000000000000000000000000000";
|
|
4
|
+
export declare const DEFAULT_PREDECESSOR: "0x0000000000000000000000000000000000000000000000000000000000000000";
|
|
5
|
+
export declare const TIMELOCK_ARGUMENT: readonly ["[timelock]", "timelock contract address", (value: string) => Address];
|
|
6
|
+
export declare const OPERATION_ID_ARGUMENT: readonly ["[operationId]", "operation ID (bytes32 hash)", (value: string) => Hex];
|
|
7
|
+
export declare const ROLE_ARGUMENT: readonly ["[role]", "role (bytes32 hex or role name like DEFAULT_ADMIN_ROLE)"];
|
|
8
|
+
export declare const ACCOUNT_GRANT_ARGUMENT: readonly ["[account]", "account address to grant role to", (value: string) => Address];
|
|
9
|
+
export declare const ACCOUNT_REVOKE_ARGUMENT: readonly ["[account]", "account address to revoke role from", (value: string) => Address];
|
|
10
|
+
export declare const SALT_OPTION: readonly ["-s, --salt <salt>", "salt for operation (bytes32 hex, default: 0x0)", (value: string) => Hex, "0x0000000000000000000000000000000000000000000000000000000000000000"];
|
|
11
|
+
export declare const getPromptTimelock: (argAddress: Address | undefined) => Promise<TimeLockContract>;
|
|
12
|
+
export declare const promptRole: (roleInput: string | undefined, contract: unknown) => Promise<`0x${string}`>;
|
|
13
|
+
export declare const promptAccount: (accountInput: string | undefined, message: string) => Promise<`0x${string}`>;
|
|
14
|
+
export declare const promptOperationId: (operationIdInput: string | undefined) => Promise<`0x${string}`>;
|
|
15
|
+
export declare const processSalt: (saltOption?: string) => Hex;
|
|
16
|
+
export declare const resolveRole: (roleInput: string, contract: GetContractReturnType<Abi, PublicClient>) => Promise<Hex>;
|
|
17
|
+
export declare const waitTimeTo: (timestamp: bigint) => bigint;
|
|
18
|
+
export declare const proposeOperation: (timelock: Address, target: Address, data: Hex, salt: Hex, functionName: string, confirmationMessage: string) => Promise<Hex>;
|
|
19
|
+
export declare const executeOperation: (timelock: Address, target: Address, data: Hex, salt: Hex, functionName: string, confirmationMessage: string, value?: bigint, predecessor?: Hex) => Promise<void>;
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { logInfo, callWriteMethodWithReceipt, confirmOperation, callReadMethodSilent, stringToAddress, addressPrompt, stringToHash, textPrompt, stringToHex, } from '../../utils/index.js';
|
|
2
|
+
import { zeroHash, isHash, formatEther, } from 'viem';
|
|
3
|
+
import { getTimeLockContract, } from 'contracts/defi-wrapper/index.js';
|
|
4
|
+
// Common constants
|
|
5
|
+
export const DEFAULT_SALT = zeroHash;
|
|
6
|
+
export const DEFAULT_PREDECESSOR = zeroHash;
|
|
7
|
+
// Common argument and option definitions
|
|
8
|
+
export const TIMELOCK_ARGUMENT = [
|
|
9
|
+
'[timelock]',
|
|
10
|
+
'timelock contract address',
|
|
11
|
+
stringToAddress,
|
|
12
|
+
];
|
|
13
|
+
export const OPERATION_ID_ARGUMENT = [
|
|
14
|
+
'[operationId]',
|
|
15
|
+
'operation ID (bytes32 hash)',
|
|
16
|
+
stringToHash,
|
|
17
|
+
];
|
|
18
|
+
export const ROLE_ARGUMENT = [
|
|
19
|
+
'[role]',
|
|
20
|
+
'role (bytes32 hex or role name like DEFAULT_ADMIN_ROLE)',
|
|
21
|
+
];
|
|
22
|
+
export const ACCOUNT_GRANT_ARGUMENT = [
|
|
23
|
+
'[account]',
|
|
24
|
+
'account address to grant role to',
|
|
25
|
+
stringToAddress,
|
|
26
|
+
];
|
|
27
|
+
export const ACCOUNT_REVOKE_ARGUMENT = [
|
|
28
|
+
'[account]',
|
|
29
|
+
'account address to revoke role from',
|
|
30
|
+
stringToAddress,
|
|
31
|
+
];
|
|
32
|
+
export const SALT_OPTION = [
|
|
33
|
+
'-s, --salt <salt>',
|
|
34
|
+
'salt for operation (bytes32 hex, default: 0x0)',
|
|
35
|
+
stringToHash,
|
|
36
|
+
DEFAULT_SALT,
|
|
37
|
+
];
|
|
38
|
+
// Helper function to get timelock from argument or prompt user
|
|
39
|
+
export const getPromptTimelock = async (argAddress) => {
|
|
40
|
+
if (argAddress)
|
|
41
|
+
return getTimeLockContract(argAddress);
|
|
42
|
+
const timelockPrompt = await addressPrompt('Enter timelock contract address', 'timelock');
|
|
43
|
+
return getTimeLockContract(timelockPrompt.timelock);
|
|
44
|
+
};
|
|
45
|
+
export const promptRole = async (roleInput,
|
|
46
|
+
// hard to match correct type here
|
|
47
|
+
contract) => {
|
|
48
|
+
if (!roleInput) {
|
|
49
|
+
const rolePrompt = await textPrompt('Enter role (bytes32 hex or role name like DEFAULT_ADMIN_ROLE)', 'role');
|
|
50
|
+
roleInput = rolePrompt.role;
|
|
51
|
+
}
|
|
52
|
+
const role = await resolveRole(roleInput, contract);
|
|
53
|
+
return role;
|
|
54
|
+
};
|
|
55
|
+
export const promptAccount = async (accountInput, message) => {
|
|
56
|
+
let account;
|
|
57
|
+
if (!accountInput) {
|
|
58
|
+
const accountPrompt = await addressPrompt(message, 'account');
|
|
59
|
+
account = accountPrompt.account;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
account = stringToAddress(accountInput);
|
|
63
|
+
}
|
|
64
|
+
return account;
|
|
65
|
+
};
|
|
66
|
+
export const promptOperationId = async (operationIdInput) => {
|
|
67
|
+
let operationId;
|
|
68
|
+
if (!operationIdInput) {
|
|
69
|
+
const operationIdPrompt = await textPrompt('Enter operation ID (bytes32 hash)', 'operationId');
|
|
70
|
+
operationIdInput = operationIdPrompt.operationId;
|
|
71
|
+
}
|
|
72
|
+
// Validate and convert to hex - if already hex, use as is
|
|
73
|
+
if (isHash(operationIdInput)) {
|
|
74
|
+
operationId = operationIdInput;
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
operationId = stringToHash(operationIdInput);
|
|
78
|
+
}
|
|
79
|
+
return operationId;
|
|
80
|
+
};
|
|
81
|
+
// Helper function to process salt option
|
|
82
|
+
export const processSalt = (saltOption) => {
|
|
83
|
+
return saltOption ? stringToHex(saltOption) : DEFAULT_SALT;
|
|
84
|
+
};
|
|
85
|
+
// Helper function to resolve role
|
|
86
|
+
export const resolveRole = async (roleInput, contract) => {
|
|
87
|
+
if (isHash(roleInput))
|
|
88
|
+
return roleInput;
|
|
89
|
+
try {
|
|
90
|
+
const role = (await callReadMethodSilent({
|
|
91
|
+
contract,
|
|
92
|
+
methodName: roleInput,
|
|
93
|
+
payload: [],
|
|
94
|
+
}));
|
|
95
|
+
logInfo(`Resolved role "${roleInput}" to ${role}`);
|
|
96
|
+
return role;
|
|
97
|
+
}
|
|
98
|
+
catch {
|
|
99
|
+
throw new Error(`Failed to resolve role "${roleInput}". Please provide a valid role name (e.g., DEFAULT_ADMIN_ROLE) or bytes32 hex.`);
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
export const waitTimeTo = (timestamp) => {
|
|
103
|
+
const now = BigInt(Math.floor(Date.now() / 1000));
|
|
104
|
+
return timestamp > now ? timestamp - now : 0n;
|
|
105
|
+
};
|
|
106
|
+
// Helper function for propose operations
|
|
107
|
+
export const proposeOperation = async (timelock, target, data, salt, functionName, confirmationMessage) => {
|
|
108
|
+
const timelockContract = await getTimeLockContract(timelock);
|
|
109
|
+
const minDelay = await callReadMethodSilent({
|
|
110
|
+
contract: timelockContract,
|
|
111
|
+
methodName: 'getMinDelay',
|
|
112
|
+
payload: [],
|
|
113
|
+
});
|
|
114
|
+
const predecessor = DEFAULT_PREDECESSOR;
|
|
115
|
+
const operationId = await callReadMethodSilent({
|
|
116
|
+
contract: timelockContract,
|
|
117
|
+
methodName: 'hashOperation',
|
|
118
|
+
payload: [[target, 0n, data, predecessor, salt]],
|
|
119
|
+
});
|
|
120
|
+
logInfo('Proposing operation:');
|
|
121
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
122
|
+
logInfo(` Target: ${target}`);
|
|
123
|
+
logInfo(` Value: 0`);
|
|
124
|
+
logInfo(` Payload: ${data}`);
|
|
125
|
+
logInfo(` Predecessor: ${predecessor}`);
|
|
126
|
+
logInfo(` Salt: ${salt}`);
|
|
127
|
+
logInfo(` Function: ${functionName}`);
|
|
128
|
+
logInfo(` Min delay: ${minDelay} seconds`);
|
|
129
|
+
const confirm = await confirmOperation(confirmationMessage);
|
|
130
|
+
if (!confirm) {
|
|
131
|
+
throw new Error('Operation cancelled by user');
|
|
132
|
+
}
|
|
133
|
+
await callWriteMethodWithReceipt({
|
|
134
|
+
contract: timelockContract,
|
|
135
|
+
methodName: 'schedule',
|
|
136
|
+
payload: [target, 0n, data, predecessor, salt, minDelay],
|
|
137
|
+
});
|
|
138
|
+
logInfo(`✅ Operation proposed successfully!`);
|
|
139
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
140
|
+
logInfo(` Execute after: ${minDelay} seconds`);
|
|
141
|
+
return operationId;
|
|
142
|
+
};
|
|
143
|
+
// Helper function for execute operations
|
|
144
|
+
export const executeOperation = async (timelock, target, data, salt, functionName, confirmationMessage, value = 0n, predecessor = DEFAULT_PREDECESSOR) => {
|
|
145
|
+
const timelockContract = await getTimeLockContract(timelock);
|
|
146
|
+
const operationId = await callReadMethodSilent({
|
|
147
|
+
contract: timelockContract,
|
|
148
|
+
methodName: 'hashOperation',
|
|
149
|
+
payload: [[target, value, data, predecessor, salt]],
|
|
150
|
+
});
|
|
151
|
+
logInfo('Calculated operation details:');
|
|
152
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
153
|
+
logInfo(` Target: ${target}`);
|
|
154
|
+
logInfo(` Value: ${formatEther(value)} ETH`);
|
|
155
|
+
logInfo(` Payload: ${data}`);
|
|
156
|
+
logInfo(` Predecessor: ${predecessor}`);
|
|
157
|
+
logInfo(` Salt: ${salt}`);
|
|
158
|
+
const state = await callReadMethodSilent({
|
|
159
|
+
contract: timelockContract,
|
|
160
|
+
methodName: 'getOperationState',
|
|
161
|
+
payload: [[operationId]],
|
|
162
|
+
});
|
|
163
|
+
if (state === 0) {
|
|
164
|
+
logInfo('❌ Operation not found (Unset)');
|
|
165
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
166
|
+
return;
|
|
167
|
+
}
|
|
168
|
+
if (state === 3) {
|
|
169
|
+
logInfo('✅ Operation already executed (Done)');
|
|
170
|
+
return;
|
|
171
|
+
}
|
|
172
|
+
if (state === 1) {
|
|
173
|
+
const timestamp = await callReadMethodSilent({
|
|
174
|
+
contract: timelockContract,
|
|
175
|
+
methodName: 'getTimestamp',
|
|
176
|
+
payload: [[operationId]],
|
|
177
|
+
});
|
|
178
|
+
const waitTime = waitTimeTo(timestamp);
|
|
179
|
+
logInfo(`⏳ Operation is waiting. Will be ready at timestamp ${timestamp} (in ${waitTime} seconds)`);
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
logInfo('Executing operation:');
|
|
183
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
184
|
+
logInfo(` Target: ${target}`);
|
|
185
|
+
logInfo(` Function: ${functionName}`);
|
|
186
|
+
const confirm = await confirmOperation(confirmationMessage);
|
|
187
|
+
if (!confirm)
|
|
188
|
+
return;
|
|
189
|
+
await callWriteMethodWithReceipt({
|
|
190
|
+
contract: timelockContract,
|
|
191
|
+
methodName: 'execute',
|
|
192
|
+
payload: [target, value, data, predecessor, salt],
|
|
193
|
+
value: value,
|
|
194
|
+
});
|
|
195
|
+
logInfo(`✅ Operation executed successfully!`);
|
|
196
|
+
logInfo(` Operation ID: ${operationId}`);
|
|
197
|
+
};
|
|
198
|
+
//# sourceMappingURL=timelock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timelock.js","sourceRoot":"","sources":["../../../features/defi-wrapper/timelock.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { callReadMethod, isValidBLSDeposit } from '../../utils/index.js';
|
|
2
2
|
export const checkBLSDeposits = async (vaultContract, deposits) => {
|
|
3
|
-
const withdrawalCredentials = await callReadMethod(
|
|
3
|
+
const withdrawalCredentials = await callReadMethod({
|
|
4
|
+
contract: vaultContract,
|
|
5
|
+
methodName: 'withdrawalCredentials',
|
|
6
|
+
payload: [],
|
|
7
|
+
});
|
|
4
8
|
for (const deposit of deposits) {
|
|
5
9
|
const isBLSValid = await isValidBLSDeposit(deposit, withdrawalCredentials);
|
|
6
10
|
if (!isBLSValid) {
|
|
@@ -9,8 +13,16 @@ export const checkBLSDeposits = async (vaultContract, deposits) => {
|
|
|
9
13
|
}
|
|
10
14
|
};
|
|
11
15
|
export const checkBLSWithAmountDeposits = async (pdgContract, vaultContract, deposits) => {
|
|
12
|
-
const PREDEPOSIT_AMOUNT = await callReadMethod(
|
|
13
|
-
|
|
16
|
+
const PREDEPOSIT_AMOUNT = await callReadMethod({
|
|
17
|
+
contract: pdgContract,
|
|
18
|
+
methodName: 'PREDEPOSIT_AMOUNT',
|
|
19
|
+
payload: [],
|
|
20
|
+
});
|
|
21
|
+
const withdrawalCredentials = await callReadMethod({
|
|
22
|
+
contract: vaultContract,
|
|
23
|
+
methodName: 'withdrawalCredentials',
|
|
24
|
+
payload: [],
|
|
25
|
+
});
|
|
14
26
|
for (const deposit of deposits) {
|
|
15
27
|
const isBLSValid = await isValidBLSDeposit(deposit, withdrawalCredentials);
|
|
16
28
|
if (deposit.amount !== PREDEPOSIT_AMOUNT) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"check-bls-deposits.js","sourceRoot":"","sources":["../../../features/deposits/check-bls-deposits.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAI1D,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,aAAmC,EACnC,QAAmB,EACnB,EAAE;IACF,MAAM,qBAAqB,GAAG,MAAM,cAAc,
|
|
1
|
+
{"version":3,"file":"check-bls-deposits.js","sourceRoot":"","sources":["../../../features/deposits/check-bls-deposits.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAI1D,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,aAAmC,EACnC,QAAmB,EACnB,EAAE;IACF,MAAM,qBAAqB,GAAG,MAAM,cAAc,CAAC;QACjD,QAAQ,EAAE,aAAa;QACvB,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IAEH,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,UAAU,GAAG,MAAM,iBAAiB,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;QAE3E,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CACb,sDAAsD,OAAO,CAAC,MAAM,EAAE,CACvE,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,EAC7C,WAAwC,EACxC,aAAmC,EACnC,QAAmB,EACnB,EAAE;IACF,MAAM,iBAAiB,GAAG,MAAM,cAAc,CAAC;QAC7C,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,mBAAmB;QAC/B,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IACH,MAAM,qBAAqB,GAAG,MAAM,cAAc,CAAC;QACjD,QAAQ,EAAE,aAAa;QACvB,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IAEH,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,MAAM,UAAU,GAAG,MAAM,iBAAiB,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC;QAE3E,IAAI,OAAO,CAAC,MAAM,KAAK,iBAAiB,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CACb,iEAAiE,OAAO,CAAC,MAAM,EAAE,CAClF,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CACb,sDAAsD,OAAO,CAAC,MAAM,EAAE,CACvE,CAAC;QACJ,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -1,11 +1,23 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
|
-
import { logInfo, logResult, logTable,
|
|
2
|
+
import { logInfo, logResult, logTable, showSpinner, createPDGProof, confirmMakeProof, callReadMethodSilent, } from '../../utils/index.js';
|
|
3
3
|
import { getStakingVaultContract, } from '../../contracts/index.js';
|
|
4
|
-
import { VALIDATOR_STAGES } from '
|
|
4
|
+
import { VALIDATOR_STAGES } from 'features/pdg.js';
|
|
5
5
|
export const checkValidatorStageAndStagedBalanceForActivation = async (pdgContract, pubkey) => {
|
|
6
|
-
const { stage, stakingVault } = await callReadMethodSilent(
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
const { stage, stakingVault } = await callReadMethodSilent({
|
|
7
|
+
contract: pdgContract,
|
|
8
|
+
methodName: 'validatorStatus',
|
|
9
|
+
payload: [[pubkey]],
|
|
10
|
+
});
|
|
11
|
+
const vaultStagedBalance = await callReadMethodSilent({
|
|
12
|
+
contract: await getStakingVaultContract(stakingVault),
|
|
13
|
+
methodName: 'stagedBalance',
|
|
14
|
+
payload: [],
|
|
15
|
+
});
|
|
16
|
+
const ACTIVATION_DEPOSIT_AMOUNT = await callReadMethodSilent({
|
|
17
|
+
contract: pdgContract,
|
|
18
|
+
methodName: 'ACTIVATION_DEPOSIT_AMOUNT',
|
|
19
|
+
payload: [],
|
|
20
|
+
});
|
|
9
21
|
if (vaultStagedBalance < ACTIVATION_DEPOSIT_AMOUNT) {
|
|
10
22
|
throw new Error(`Staged balance is less than ${formatEther(ACTIVATION_DEPOSIT_AMOUNT)} ETH (current: ${formatEther(vaultStagedBalance)} ETH)`);
|
|
11
23
|
}
|
|
@@ -42,13 +54,13 @@ export const makePDGProofByIndex = async (validatorIndex) => {
|
|
|
42
54
|
}
|
|
43
55
|
catch (err) {
|
|
44
56
|
hideSpinner();
|
|
45
|
-
printError(err, 'Error when making proof');
|
|
46
57
|
throw err;
|
|
47
58
|
}
|
|
48
59
|
};
|
|
49
60
|
export const makePDGProofByIndexes = async (indexes) => {
|
|
50
61
|
const witnesses = [];
|
|
51
|
-
for (const index of indexes) {
|
|
62
|
+
for (const [i, index] of indexes.entries()) {
|
|
63
|
+
logInfo(`--- Validator ${i + 1}/${indexes.length} [index: ${index}] ---`);
|
|
52
64
|
const validatorIndex = await confirmMakeProof(index);
|
|
53
65
|
if (!validatorIndex)
|
|
54
66
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"make-pdg-proof.js","sourceRoot":"","sources":["../../../features/deposits/make-pdg-proof.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,WAAW,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EACL,OAAO,EACP,SAAS,EACT,QAAQ,EACR,
|
|
1
|
+
{"version":3,"file":"make-pdg-proof.js","sourceRoot":"","sources":["../../../features/deposits/make-pdg-proof.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,9 +3,21 @@ import { callReadMethodSilent, confirmOperation, logInfo, numberPrompt, addressP
|
|
|
3
3
|
import { getAccount } from '../../providers/index.js';
|
|
4
4
|
export const checkNOBalancePDGforDeposit = async (pdgContract, nodeOperator) => {
|
|
5
5
|
const currentAccount = await getAccount();
|
|
6
|
-
const balance = await callReadMethodSilent(
|
|
7
|
-
|
|
8
|
-
|
|
6
|
+
const balance = await callReadMethodSilent({
|
|
7
|
+
contract: pdgContract,
|
|
8
|
+
methodName: 'nodeOperatorBalance',
|
|
9
|
+
payload: [[nodeOperator]],
|
|
10
|
+
});
|
|
11
|
+
const unlockedBalance = await callReadMethodSilent({
|
|
12
|
+
contract: pdgContract,
|
|
13
|
+
methodName: 'unlockedBalance',
|
|
14
|
+
payload: [[nodeOperator]],
|
|
15
|
+
});
|
|
16
|
+
const nodeOperatorGuarantor = await callReadMethodSilent({
|
|
17
|
+
contract: pdgContract,
|
|
18
|
+
methodName: 'nodeOperatorGuarantor',
|
|
19
|
+
payload: [[nodeOperator]],
|
|
20
|
+
});
|
|
9
21
|
let amountToTopUp = 0n;
|
|
10
22
|
let isNeedTopUp = false;
|
|
11
23
|
if (balance.total === 0n || unlockedBalance === 0n) {
|
|
@@ -26,8 +38,16 @@ export const checkNOBalancePDGforDeposit = async (pdgContract, nodeOperator) =>
|
|
|
26
38
|
return { balance, unlockedBalance, amountToTopUp, isNeedTopUp };
|
|
27
39
|
};
|
|
28
40
|
export const checkNOBalancePDGforDeposits = async (pdgContract, nodeOperator, countOfDeposits) => {
|
|
29
|
-
const PREDEPOSIT_AMOUNT = await callReadMethodSilent(
|
|
30
|
-
|
|
41
|
+
const PREDEPOSIT_AMOUNT = await callReadMethodSilent({
|
|
42
|
+
contract: pdgContract,
|
|
43
|
+
methodName: 'PREDEPOSIT_AMOUNT',
|
|
44
|
+
payload: [],
|
|
45
|
+
});
|
|
46
|
+
const unlockedBalance = await callReadMethodSilent({
|
|
47
|
+
contract: pdgContract,
|
|
48
|
+
methodName: 'unlockedBalance',
|
|
49
|
+
payload: [[nodeOperator]],
|
|
50
|
+
});
|
|
31
51
|
const amountToTopUp = PREDEPOSIT_AMOUNT * BigInt(countOfDeposits);
|
|
32
52
|
const isNeedTopUp = unlockedBalance < amountToTopUp;
|
|
33
53
|
if (isNeedTopUp) {
|
|
@@ -39,10 +59,16 @@ export const checkNOBalancePDGforDeposits = async (pdgContract, nodeOperator, co
|
|
|
39
59
|
};
|
|
40
60
|
export const checkNodeOperatorOrDepositorForDeposit = async (vault, pdg) => {
|
|
41
61
|
const currentAccount = await getAccount();
|
|
42
|
-
const vaultNodeOperator = await callReadMethodSilent(
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
62
|
+
const vaultNodeOperator = await callReadMethodSilent({
|
|
63
|
+
contract: vault,
|
|
64
|
+
methodName: 'nodeOperator',
|
|
65
|
+
payload: [],
|
|
66
|
+
});
|
|
67
|
+
const noDepositor = await callReadMethodSilent({
|
|
68
|
+
contract: pdg,
|
|
69
|
+
methodName: 'nodeOperatorDepositor',
|
|
70
|
+
payload: [[vaultNodeOperator]],
|
|
71
|
+
});
|
|
46
72
|
if (noDepositor.toLocaleLowerCase() !==
|
|
47
73
|
currentAccount.address.toLocaleLowerCase()) {
|
|
48
74
|
throw new Error(`You are not the depositor of the node operator ${vaultNodeOperator}. Only depositor can deposit from the vault.`);
|
|
@@ -51,10 +77,16 @@ export const checkNodeOperatorOrDepositorForDeposit = async (vault, pdg) => {
|
|
|
51
77
|
};
|
|
52
78
|
export const checkAndSpecifyNodeOperatorForTopUpOrWithdraw = async (vault, pdg, isTopUp) => {
|
|
53
79
|
const currentAccount = await getAccount();
|
|
54
|
-
const vaultNodeOperator = await callReadMethodSilent(
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
80
|
+
const vaultNodeOperator = await callReadMethodSilent({
|
|
81
|
+
contract: vault,
|
|
82
|
+
methodName: 'nodeOperator',
|
|
83
|
+
payload: [],
|
|
84
|
+
});
|
|
85
|
+
const noGuarantor = await callReadMethodSilent({
|
|
86
|
+
contract: pdg,
|
|
87
|
+
methodName: 'nodeOperatorGuarantor',
|
|
88
|
+
payload: [[vaultNodeOperator]],
|
|
89
|
+
});
|
|
58
90
|
const isNoGuarantor = noGuarantor.toLocaleLowerCase() ===
|
|
59
91
|
currentAccount.address.toLocaleLowerCase();
|
|
60
92
|
const isNodeOperator = vaultNodeOperator.toLocaleLowerCase() ===
|
|
@@ -73,7 +105,11 @@ export const checkAndSpecifyNodeOperatorForTopUpOrWithdraw = async (vault, pdg,
|
|
|
73
105
|
};
|
|
74
106
|
export const getGuarantor = async (pdgContract) => {
|
|
75
107
|
const currentAccount = await getAccount();
|
|
76
|
-
const balance = await callReadMethodSilent(
|
|
108
|
+
const balance = await callReadMethodSilent({
|
|
109
|
+
contract: pdgContract,
|
|
110
|
+
methodName: 'nodeOperatorBalance',
|
|
111
|
+
payload: [[currentAccount.address]],
|
|
112
|
+
});
|
|
77
113
|
if (balance.locked > 0n) {
|
|
78
114
|
throw new Error(`You have locked balance in PDG. You can't change the guarantor.`);
|
|
79
115
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-pdg.js","sourceRoot":"","sources":["../../../features/deposits/no-pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAG5C,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,aAAa,GACd,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,WAAwC,EACxC,YAAqB,EACrB,EAAE;IACF,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAE1C,MAAM,OAAO,GAAG,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"no-pdg.js","sourceRoot":"","sources":["../../../features/deposits/no-pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAG5C,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,aAAa,GACd,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,WAAwC,EACxC,YAAqB,EACrB,EAAE;IACF,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAE1C,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC;QACzC,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,qBAAqB;QACjC,OAAO,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;KAC1B,CAAC,CAAC;IACH,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAAC;QACjD,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,iBAAiB;QAC7B,OAAO,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;KAC1B,CAAC,CAAC;IACH,MAAM,qBAAqB,GAAG,MAAM,oBAAoB,CAAC;QACvD,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;KAC1B,CAAC,CAAC;IACH,IAAI,aAAa,GAAG,EAAE,CAAC;IACvB,IAAI,WAAW,GAAG,KAAK,CAAC;IAExB,IAAI,OAAO,CAAC,KAAK,KAAK,EAAE,IAAI,eAAe,KAAK,EAAE,EAAE,CAAC;QACnD,OAAO,CACL,iBAAiB,YAAY,4CAA4C,CAC1E,CAAC;QAEF,IACE,qBAAqB,CAAC,iBAAiB,EAAE;YACzC,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAC1C,CAAC;YACD,MAAM,IAAI,KAAK,CACb,OAAO,cAAc,CAAC,OAAO,0BAA0B,qBAAqB,yBAAyB,YAAY,iCAAiC,CACnJ,CAAC;QACJ,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,0CAA0C,CAC3C,CAAC;QACF,IAAI,CAAC,OAAO;YACV,MAAM,IAAI,KAAK,CACb,kEAAkE,CACnE,CAAC;QAEJ,MAAM,MAAM,GAAG,MAAM,YAAY,CAC/B,qFAAqF,EACrF,OAAO,CACR,CAAC;QACF,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;QAEnD,aAAa,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACrC,WAAW,GAAG,IAAI,CAAC;IACrB,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;AAClE,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,4BAA4B,GAAG,KAAK,EAC/C,WAAwC,EACxC,YAAqB,EACrB,eAAuB,EACvB,EAAE;IACF,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAAC;QACnD,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,mBAAmB;QAC/B,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IACH,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAAC;QACjD,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,iBAAiB;QAC7B,OAAO,EAAE,CAAC,CAAC,YAAY,CAAC,CAAC;KAC1B,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG,iBAAiB,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;IAElE,MAAM,WAAW,GAAG,eAAe,GAAG,aAAa,CAAC;IAEpD,IAAI,WAAW,EAAE,CAAC;QAChB,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,2DAA2D,WAAW,CAAC,aAAa,CAAC,4CAA4C,CAClI,CAAC;QACF,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;IACvE,CAAC;IAED,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;AACxC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sCAAsC,GAAG,KAAK,EACzD,KAA2B,EAC3B,GAAgC,EAChC,EAAE;IACF,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAC1C,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAAC;QACnD,QAAQ,EAAE,KAAK;QACf,UAAU,EAAE,cAAc;QAC1B,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IACH,MAAM,WAAW,GAAG,MAAM,oBAAoB,CAAC;QAC7C,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC;KAC/B,CAAC,CAAC;IAEH,IACE,WAAW,CAAC,iBAAiB,EAAE;QAC/B,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,EAC1C,CAAC;QACD,MAAM,IAAI,KAAK,CACb,kDAAkD,iBAAiB,8CAA8C,CAClH,CAAC;IACJ,CAAC;IAED,OAAO,iBAAiB,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,6CAA6C,GAAG,KAAK,EAChE,KAA2B,EAC3B,GAAgC,EAChC,OAAgB,EAChB,EAAE;IACF,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAC1C,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAAC;QACnD,QAAQ,EAAE,KAAK;QACf,UAAU,EAAE,cAAc;QAC1B,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IACH,MAAM,WAAW,GAAG,MAAM,oBAAoB,CAAC;QAC7C,QAAQ,EAAE,GAAG;QACb,UAAU,EAAE,uBAAuB;QACnC,OAAO,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC;KAC/B,CAAC,CAAC;IAEH,MAAM,aAAa,GACjB,WAAW,CAAC,iBAAiB,EAAE;QAC/B,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAC7C,MAAM,cAAc,GAClB,iBAAiB,CAAC,iBAAiB,EAAE;QACrC,cAAc,CAAC,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAE7C,IAAI,CAAC,aAAa,IAAI,CAAC,cAAc,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CACb,8CAA8C,KAAK,CAAC,OAAO,6CAA6C,CACzG,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,cAAc,IAAI,aAAa,EAAE,CAAC;QACrC,OAAO,CACL,8CAA8C,KAAK,CAAC,OAAO,gDAAgD,iBAAiB,GAAG,CAChI,CAAC;QAEF,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,kBAAkB,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,sBAAsB,iBAAiB,WAAW,CACpG,CAAC;QACF,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QAErE,OAAO,iBAAiB,CAAC;IAC3B,CAAC;IAED,OAAO,iBAAiB,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAC/B,WAAwC,EACxC,EAAE;IACF,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAC1C,MAAM,OAAO,GAAG,MAAM,oBAAoB,CAAC;QACzC,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,qBAAqB;QACjC,OAAO,EAAE,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;KACpC,CAAC,CAAC;IAEH,IAAI,OAAO,CAAC,MAAM,GAAG,EAAE,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CACb,iEAAiE,CAClE,CAAC;IACJ,CAAC;IAED,IAAI,OAAO,CAAC,KAAK,GAAG,EAAE,EAAE,CAAC;QACvB,OAAO,CACL;oEAC8D,CAC/D,CAAC;QAEF,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,sCAAsC,CACvC,CAAC;QACF,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;IACzE,CAAC;IAED,MAAM,YAAY,GAAG,MAAM,aAAa,CACtC,6BAA6B,EAC7B,OAAO,CACR,CAAC;IACF,IAAI,CAAC,YAAY;QAAE,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;IAExE,OAAO;QACL,YAAY,EAAE,YAAY,CAAC,KAAK;QAChC,cAAc,EAAE,cAAc,CAAC,OAAO;KACvC,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,IAAI,EAAE;IACnD,MAAM,cAAc,GAAG,MAAM,UAAU,EAAE,CAAC;IAE1C,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,wDAAwD,cAAc,CAAC,OAAO,GAAG,CAClF,CAAC;IACF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,YAAY,GAAG,MAAM,aAAa,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;QACvE,IAAI,CAAC,YAAY,CAAC,KAAK;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAE5D,OAAO,YAAY,CAAC,KAAK,CAAC;IAC5B,CAAC;IAED,OAAO,cAAc,CAAC,OAAO,CAAC;AAChC,CAAC,CAAC"}
|
|
@@ -4,7 +4,11 @@ import { getChain } from '../../configs/index.js';
|
|
|
4
4
|
export const checkPdgIsPaused = async (pdgContract) => {
|
|
5
5
|
const chain = await getChain();
|
|
6
6
|
const isMainnet = chain.id === mainnet.id;
|
|
7
|
-
const isPaused = await callReadMethodSilent(
|
|
7
|
+
const isPaused = await callReadMethodSilent({
|
|
8
|
+
contract: pdgContract,
|
|
9
|
+
methodName: 'isPaused',
|
|
10
|
+
payload: [],
|
|
11
|
+
});
|
|
8
12
|
if (isPaused) {
|
|
9
13
|
const message = isMainnet
|
|
10
14
|
? 'PredepositGuarantee contract is paused until Phase 2'
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pdg.js","sourceRoot":"","sources":["../../../features/deposits/pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,WAAwC,EACxC,EAAE;IACF,MAAM,KAAK,GAAG,MAAM,QAAQ,EAAE,CAAC;IAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC;IAE1C,MAAM,QAAQ,GAAG,MAAM,oBAAoB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"pdg.js","sourceRoot":"","sources":["../../../features/deposits/pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAEnC,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,WAAwC,EACxC,EAAE;IACF,MAAM,KAAK,GAAG,MAAM,QAAQ,EAAE,CAAC;IAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,EAAE,KAAK,OAAO,CAAC,EAAE,CAAC;IAE1C,MAAM,QAAQ,GAAG,MAAM,oBAAoB,CAAC;QAC1C,QAAQ,EAAE,WAAW;QACrB,UAAU,EAAE,UAAU;QACtB,OAAO,EAAE,EAAE;KACZ,CAAC,CAAC;IAEH,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,OAAO,GAAG,SAAS;YACvB,CAAC,CAAC,sDAAsD;YACxD,CAAC,CAAC,oEAAoE,CAAC;QACzE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1B,OAAO,CAAC,OAAO,CAAC,CAAC;QACjB,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC,CAAC"}
|