@lidofinance/lsv-cli 1.6.0 → 1.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +15 -9
- package/dist/abi/defi-wrapper/GenericStrategy.d.ts +308 -0
- package/dist/abi/defi-wrapper/GenericStrategy.js +409 -0
- package/dist/abi/defi-wrapper/GenericStrategy.js.map +1 -0
- package/dist/abi/defi-wrapper/{StvStETHPool.js → StvStEthPool.js} +1 -1
- package/dist/abi/defi-wrapper/{StvStETHPool.js.map → StvStEthPool.js.map} +1 -1
- package/dist/abi/defi-wrapper/index.d.ts +2 -1
- package/dist/abi/defi-wrapper/index.js +2 -1
- package/dist/abi/defi-wrapper/index.js.map +1 -1
- package/dist/abi/defi-wrapper/sources.d.ts +103 -0
- package/dist/abi/defi-wrapper/sources.js +104 -0
- package/dist/abi/defi-wrapper/sources.js.map +1 -0
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +21 -6
- package/dist/configs/deployed.d.ts +5 -0
- package/dist/configs/deployed.js +29 -10
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/envs.js +2 -0
- package/dist/configs/envs.js.map +1 -1
- package/dist/configs/utils.js +1 -1
- package/dist/configs/utils.js.map +1 -1
- package/dist/contracts/dashboard-impl.d.ts +1 -1
- package/dist/contracts/dashboard-impl.js +1 -1
- package/dist/contracts/defi-wrapper/distributor.d.ts +1 -1
- package/dist/contracts/defi-wrapper/distributor.js +1 -1
- package/dist/contracts/defi-wrapper/factory.d.ts +1 -1
- package/dist/contracts/defi-wrapper/factory.js +1 -1
- package/dist/contracts/defi-wrapper/generic-strategy.d.ts +5 -0
- package/dist/contracts/defi-wrapper/generic-strategy.js +12 -0
- package/dist/contracts/defi-wrapper/generic-strategy.js.map +1 -0
- package/dist/contracts/defi-wrapper/index.d.ts +1 -0
- package/dist/contracts/defi-wrapper/index.js +1 -0
- package/dist/contracts/defi-wrapper/index.js.map +1 -1
- package/dist/contracts/defi-wrapper/ossifiable-proxy.d.ts +1 -1
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js +1 -1
- package/dist/contracts/defi-wrapper/strategy-factory.d.ts +1 -1
- package/dist/contracts/defi-wrapper/strategy-factory.js +1 -1
- package/dist/contracts/defi-wrapper/stv-pool.d.ts +1 -1
- package/dist/contracts/defi-wrapper/stv-pool.js +1 -1
- package/dist/contracts/defi-wrapper/stv-steth-pool.d.ts +1 -1
- package/dist/contracts/defi-wrapper/stv-steth-pool.js +1 -1
- package/dist/contracts/defi-wrapper/timelock.d.ts +1 -1
- package/dist/contracts/defi-wrapper/timelock.js +1 -1
- package/dist/contracts/defi-wrapper/withdrawal-queue.d.ts +1 -1
- package/dist/contracts/defi-wrapper/withdrawal-queue.js +1 -1
- package/dist/contracts/lazy-oracle.d.ts +2 -2
- package/dist/contracts/lazy-oracle.js +3 -3
- package/dist/contracts/lazy-oracle.js.map +1 -1
- package/dist/contracts/locator.d.ts +1 -1
- package/dist/contracts/locator.js +1 -1
- package/dist/contracts/operator-grid.d.ts +2 -2
- package/dist/contracts/operator-grid.js +3 -3
- package/dist/contracts/operator-grid.js.map +1 -1
- package/dist/contracts/pdg.d.ts +2 -2
- package/dist/contracts/pdg.js +3 -3
- package/dist/contracts/pdg.js.map +1 -1
- package/dist/contracts/steth.d.ts +2 -2
- package/dist/contracts/steth.js +3 -3
- package/dist/contracts/steth.js.map +1 -1
- package/dist/contracts/vault-factory.d.ts +2 -2
- package/dist/contracts/vault-factory.js +2 -2
- package/dist/contracts/vault-hub.d.ts +2 -2
- package/dist/contracts/vault-hub.js +3 -3
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +1 -1
- package/dist/contracts/vault-viewer.js +2 -3
- package/dist/contracts/vault-viewer.js.map +1 -1
- package/dist/contracts/vault.d.ts +1 -1
- package/dist/contracts/vault.js +1 -1
- package/dist/contracts/wsteth.d.ts +2 -2
- package/dist/contracts/wsteth.js +3 -3
- package/dist/contracts/wsteth.js.map +1 -1
- package/dist/features/consolidation.d.ts +1 -1
- package/dist/features/defi-wrapper/defi-wrapper-factory.d.ts +4 -1
- package/dist/features/defi-wrapper/defi-wrapper-factory.js +7 -4
- package/dist/features/defi-wrapper/defi-wrapper-factory.js.map +1 -1
- package/dist/features/defi-wrapper/distributor.d.ts +3 -1
- package/dist/features/defi-wrapper/distributor.js +31 -16
- package/dist/features/defi-wrapper/distributor.js.map +1 -1
- 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 +18 -1
- package/dist/features/defi-wrapper/pool-info.js +52 -8
- package/dist/features/defi-wrapper/pool-info.js.map +1 -1
- package/dist/features/defi-wrapper/timelock-roles.d.ts +5 -0
- package/dist/features/defi-wrapper/timelock-roles.js +43 -0
- package/dist/features/defi-wrapper/timelock-roles.js.map +1 -0
- package/dist/features/defi-wrapper/timelock.d.ts +2 -7
- package/dist/features/defi-wrapper/timelock.js +6 -53
- package/dist/features/defi-wrapper/timelock.js.map +1 -1
- package/dist/features/defi-wrapper/verify-contracts.d.ts +20 -0
- package/dist/features/defi-wrapper/verify-contracts.js +145 -0
- package/dist/features/defi-wrapper/verify-contracts.js.map +1 -0
- package/dist/features/deposits/make-pdg-proof.js +1 -1
- package/dist/features/metrics.d.ts +2 -2
- package/dist/features/metrics.js +1 -1
- package/dist/features/mint-burn/mint-limit.js +1 -1
- package/dist/features/mint-burn/mint-limit.js.map +1 -1
- package/dist/features/utils/minting-capacity.js +1 -1
- package/dist/features/utils/try-fetch.js +4 -2
- package/dist/features/utils/try-fetch.js.map +1 -1
- package/dist/features/vault-factory.js +6 -5
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-operations/dashboard-by-vault.js +3 -7
- 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/with-report.d.ts +1 -1
- package/dist/features/with-report.js +1 -1
- package/dist/features/with-report.js.map +1 -1
- package/dist/index.js +7 -2
- package/dist/index.js.map +1 -1
- package/dist/programs/account/write.js +2 -1
- package/dist/programs/account/write.js.map +1 -1
- package/dist/programs/config.js +4 -2
- package/dist/programs/config.js.map +1 -1
- package/dist/programs/contracts/dashboard/read.js +3 -6
- package/dist/programs/contracts/dashboard/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/write.js +2 -2
- package/dist/programs/contracts/dashboard/write.js.map +1 -1
- package/dist/programs/contracts/lazy-oracle/config.js +2 -2
- package/dist/programs/contracts/lazy-oracle/config.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +1 -1
- package/dist/programs/contracts/vault/config.js +1 -1
- package/dist/programs/contracts/vault/config.js.map +1 -1
- package/dist/programs/contracts/vault-factory/write.js +8 -9
- package/dist/programs/contracts/vault-factory/write.js.map +1 -1
- package/dist/programs/contracts/vault-viewer/config.js +8 -8
- package/dist/programs/contracts/vault-viewer/config.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/read.js +2 -2
- 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/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/factory/write.js +79 -8
- package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/index.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/index.js +1 -0
- package/dist/programs/defi-wrapper/contracts/index.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/strategy/config.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/strategy/config.js +40 -0
- package/dist/programs/defi-wrapper/contracts/strategy/config.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/strategy/index.d.ts +3 -0
- package/dist/programs/defi-wrapper/contracts/strategy/index.js +4 -0
- package/dist/programs/defi-wrapper/contracts/strategy/index.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/strategy/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/strategy/main.js +6 -0
- package/dist/programs/defi-wrapper/contracts/strategy/main.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/strategy/read.js +30 -0
- package/dist/programs/defi-wrapper/contracts/strategy/read.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/strategy/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/contracts/strategy/write.js +34 -0
- package/dist/programs/defi-wrapper/contracts/strategy/write.js.map +1 -0
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +2 -2
- 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/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js +58 -22
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +4 -5
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/distributor/read.js +2 -2
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js +139 -31
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/read.js +2 -2
- package/dist/programs/defi-wrapper/use-cases/health/utils.js +2 -2
- package/dist/programs/defi-wrapper/use-cases/health/utils.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js +7 -12
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js +6 -10
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js +5 -5
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/index.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js +6 -6
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js +5 -5
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/index.d.ts +2 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/index.js +3 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/index.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/main.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/main.js +6 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/main.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/write.d.ts +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/write.js +57 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/strategy/write.js.map +1 -0
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js +5 -5
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js.map +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js +37 -16
- 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 +18 -17
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js.map +1 -1
- package/dist/programs/dev-tools/anvil/write.js +2 -2
- package/dist/programs/dev-tools/anvil/write.js.map +1 -1
- package/dist/programs/dev-tools/defi-wrapper/write.js +1 -1
- package/dist/programs/pdg-helpers.js +4 -0
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/use-cases/consolidation/write.js +4 -3
- package/dist/programs/use-cases/consolidation/write.js.map +1 -1
- package/dist/programs/use-cases/deposits/read.js +1 -2
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/metrics/read.js +115 -1
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/report/write.js +1 -3
- package/dist/programs/use-cases/report/write.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/create-vault.js +8 -9
- package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +2 -14
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/wallet.d.ts +687 -10399
- package/dist/providers/wallet.js +80 -9
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/fixtures/consolidation-fixtures.d.ts +64 -0
- package/dist/tests/fixtures/consolidation-fixtures.js +56 -0
- package/dist/tests/fixtures/consolidation-fixtures.js.map +1 -0
- package/dist/tests/integration/deposits.test.js +1 -1
- package/dist/tests/integration/gas-estimation.test.d.ts +1 -0
- package/dist/tests/integration/gas-estimation.test.js +76 -0
- package/dist/tests/integration/gas-estimation.test.js.map +1 -0
- package/dist/tests/integration/{globalSetup.js → global-setup.js} +2 -2
- package/dist/tests/integration/global-setup.js.map +1 -0
- package/dist/tests/integration/helpers/test-client.d.ts +586 -7068
- package/dist/tests/integration/helpers/test-config.js +4 -4
- package/dist/tests/integration/helpers/test-config.js.map +1 -1
- package/dist/tests/integration/metrics.test.js +1 -2
- package/dist/tests/integration/metrics.test.js.map +1 -1
- package/dist/tests/integration/mint-burn.test.js +1 -2
- package/dist/tests/integration/mint-burn.test.js.map +1 -1
- package/dist/tests/integration/minting-capacity.test.d.ts +1 -0
- package/dist/tests/integration/minting-capacity.test.js +52 -0
- package/dist/tests/integration/minting-capacity.test.js.map +1 -0
- package/dist/tests/integration/quarantine.test.d.ts +1 -0
- package/dist/tests/integration/quarantine.test.js +32 -0
- package/dist/tests/integration/quarantine.test.js.map +1 -0
- package/dist/tests/integration/report-fresh.test.d.ts +1 -0
- package/dist/tests/integration/report-fresh.test.js +47 -0
- package/dist/tests/integration/report-fresh.test.js.map +1 -0
- package/dist/tests/utils/arguments-security.test.d.ts +1 -0
- package/dist/tests/utils/arguments-security.test.js +34 -0
- package/dist/tests/utils/arguments-security.test.js.map +1 -0
- package/dist/tests/utils/arguments.test.js +5 -24
- package/dist/tests/utils/arguments.test.js.map +1 -1
- package/dist/tests/utils/big-int.test.d.ts +1 -0
- package/dist/tests/utils/{bigInt.test.js → big-int.test.js} +2 -2
- package/dist/tests/utils/big-int.test.js.map +1 -0
- package/dist/tests/utils/cache-security.test.d.ts +1 -0
- package/dist/tests/utils/cache-security.test.js +62 -0
- package/dist/tests/utils/cache-security.test.js.map +1 -0
- package/dist/tests/utils/cache.test.d.ts +1 -0
- package/dist/tests/utils/cache.test.js +233 -0
- package/dist/tests/utils/cache.test.js.map +1 -0
- package/dist/tests/utils/calculate-overview-v2.test.js +1 -1
- package/dist/tests/utils/calculate-overview.test.js +4 -2
- package/dist/tests/utils/calculate-overview.test.js.map +1 -1
- package/dist/tests/utils/confirmations.test.d.ts +1 -0
- package/dist/tests/utils/confirmations.test.js +35 -0
- package/dist/tests/utils/confirmations.test.js.map +1 -0
- package/dist/tests/utils/consolidation-checks.test.d.ts +1 -0
- package/dist/tests/utils/consolidation-checks.test.js +77 -0
- package/dist/tests/utils/consolidation-checks.test.js.map +1 -0
- package/dist/tests/utils/consolidation-pubkeys.test.d.ts +1 -0
- package/dist/tests/utils/consolidation-pubkeys.test.js +101 -0
- package/dist/tests/utils/consolidation-pubkeys.test.js.map +1 -0
- package/dist/tests/utils/consolidation-validator-info.test.d.ts +1 -0
- package/dist/tests/utils/consolidation-validator-info.test.js +101 -0
- package/dist/tests/utils/consolidation-validator-info.test.js.map +1 -0
- package/dist/tests/utils/consolidation-validators-checks.test.d.ts +1 -0
- package/dist/tests/utils/consolidation-validators-checks.test.js +156 -0
- package/dist/tests/utils/consolidation-validators-checks.test.js.map +1 -0
- package/dist/tests/utils/consts.test.d.ts +1 -0
- package/dist/tests/utils/consts.test.js +24 -0
- package/dist/tests/utils/consts.test.js.map +1 -0
- package/dist/tests/utils/contract-write-stateoverride.test.d.ts +1 -0
- package/dist/tests/utils/contract-write-stateoverride.test.js +135 -0
- package/dist/tests/utils/contract-write-stateoverride.test.js.map +1 -0
- package/dist/tests/utils/csv-file.test.js +1 -1
- package/dist/tests/utils/data-validators.test.js +22 -6
- package/dist/tests/utils/data-validators.test.js.map +1 -1
- package/dist/tests/utils/deployed-security.test.d.ts +1 -0
- package/dist/tests/utils/deployed-security.test.js +51 -0
- package/dist/tests/utils/deployed-security.test.js.map +1 -0
- package/dist/tests/utils/get-commands.test.js +1 -1
- package/dist/tests/utils/get-commands.test.js.map +1 -1
- package/dist/tests/utils/get-confirmations.test.d.ts +1 -0
- package/dist/tests/utils/get-confirmations.test.js +40 -0
- package/dist/tests/utils/get-confirmations.test.js.map +1 -0
- package/dist/tests/utils/ipfs-security.test.d.ts +1 -0
- package/dist/tests/utils/ipfs-security.test.js +105 -0
- package/dist/tests/utils/ipfs-security.test.js.map +1 -0
- package/dist/tests/utils/ipfs.test.js +10 -9
- package/dist/tests/utils/ipfs.test.js.map +1 -1
- package/dist/tests/utils/lido-apr.test.js +1 -1
- package/dist/tests/utils/logging.test.js +1 -1
- package/dist/tests/utils/logging.test.js.map +1 -1
- package/dist/tests/utils/merkle-utils.test.js +1 -0
- package/dist/tests/utils/merkle-utils.test.js.map +1 -1
- package/dist/tests/utils/public-client-gas-estimation.test.d.ts +1 -0
- package/dist/tests/utils/public-client-gas-estimation.test.js +231 -0
- package/dist/tests/utils/public-client-gas-estimation.test.js.map +1 -0
- package/dist/tests/utils/rate-limit-security.test.d.ts +1 -0
- package/dist/tests/utils/rate-limit-security.test.js +82 -0
- package/dist/tests/utils/rate-limit-security.test.js.map +1 -0
- package/dist/tests/utils/rebase-rewards.test.js +1 -1
- package/dist/tests/utils/report-statistic.test.js +1 -1
- package/dist/tests/utils/resove-path.test.js +2 -2
- package/dist/tests/utils/resove-path.test.js.map +1 -1
- package/dist/tests/utils/salt.test.d.ts +1 -0
- package/dist/tests/utils/salt.test.js +20 -0
- package/dist/tests/utils/salt.test.js.map +1 -0
- package/dist/tests/utils/snake-to-camel.test.js +1 -1
- package/dist/tests/utils/timestamp.test.js +1 -1
- package/dist/tests/utils/with-error.test.d.ts +1 -0
- package/dist/tests/utils/with-error.test.js +42 -0
- package/dist/tests/utils/with-error.test.js.map +1 -0
- package/dist/utils/arguments.d.ts +2 -7
- package/dist/utils/arguments.js +34 -34
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/big-int.js +7 -0
- package/dist/utils/big-int.js.map +1 -0
- package/dist/utils/cache.js +25 -22
- package/dist/utils/cache.js.map +1 -1
- package/dist/utils/calculate-overview-v2.js +1 -1
- package/dist/utils/calculate-overview-v2.js.map +1 -1
- package/dist/utils/calculate-overview.js +2 -2
- package/dist/utils/calculate-overview.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +2 -2
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +2 -2
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +1 -2
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
- package/dist/utils/charts/blessed/utils.js +1 -0
- package/dist/utils/charts/blessed/utils.js.map +1 -1
- package/dist/utils/charts/overview.js +3 -3
- package/dist/utils/charts/overview.js.map +1 -1
- package/dist/utils/commands/confirmations.js +15 -8
- package/dist/utils/commands/confirmations.js.map +1 -1
- package/dist/utils/consolidation/validator-info.d.ts +1 -1
- package/dist/utils/consolidation/validator-info.js +4 -4
- package/dist/utils/consolidation/validator-info.js.map +1 -1
- package/dist/utils/consolidation/validators-checks.d.ts +1 -1
- package/dist/utils/consolidation/validators-checks.js +5 -5
- package/dist/utils/consolidation/validators-checks.js.map +1 -1
- package/dist/utils/csv-file.js +1 -1
- package/dist/utils/csv-file.js.map +1 -1
- package/dist/utils/data-validators.d.ts +3 -2
- package/dist/utils/data-validators.js +11 -14
- package/dist/utils/data-validators.js.map +1 -1
- package/dist/utils/{fetchCL.d.ts → fetch-cl.d.ts} +15 -17
- package/dist/utils/{fetchCL.js → fetch-cl.js} +5 -3
- package/dist/utils/fetch-cl.js.map +1 -0
- package/dist/utils/get-commands.js +3 -2
- package/dist/utils/get-commands.js.map +1 -1
- package/dist/utils/get-value.js +1 -1
- package/dist/utils/get-value.js.map +1 -1
- package/dist/utils/index.d.ts +7 -6
- package/dist/utils/index.js +7 -6
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/interrupt-handler.js +1 -1
- package/dist/utils/interrupt-handler.js.map +1 -1
- package/dist/utils/ipfs.d.ts +11 -2
- package/dist/utils/ipfs.js +52 -12
- package/dist/utils/ipfs.js.map +1 -1
- package/dist/utils/logging/console.d.ts +1 -0
- package/dist/utils/logging/console.js +35 -7
- package/dist/utils/logging/console.js.map +1 -1
- package/dist/utils/prompts/account.d.ts +1 -0
- package/dist/utils/prompts/account.js +13 -0
- package/dist/utils/prompts/account.js.map +1 -0
- package/dist/utils/prompts/index.d.ts +3 -0
- package/dist/utils/prompts/index.js +3 -0
- package/dist/utils/prompts/index.js.map +1 -1
- package/dist/utils/prompts/predeposit-guarantee.js +1 -1
- package/dist/utils/prompts/strategy.d.ts +15398 -0
- package/dist/utils/prompts/strategy.js +10 -0
- package/dist/utils/prompts/strategy.js.map +1 -0
- package/dist/utils/prompts/timelock-roles.d.ts +1 -0
- package/dist/utils/prompts/timelock-roles.js +13 -0
- package/dist/utils/prompts/timelock-roles.js.map +1 -0
- package/dist/utils/proof/create-proof.js +1 -1
- package/dist/utils/proof/create-proof.js.map +1 -1
- package/dist/utils/proof/merkle-utils.js +1 -1
- package/dist/utils/proof/merkle-utils.js.map +1 -1
- package/dist/utils/rate-limit.d.ts +6 -9
- package/dist/utils/rate-limit.js +27 -5
- package/dist/utils/rate-limit.js.map +1 -1
- package/dist/utils/read-programs-by-abi.d.ts +1 -1
- package/dist/utils/read-programs-by-abi.js +11 -12
- package/dist/utils/read-programs-by-abi.js.map +1 -1
- package/dist/utils/report/report-proof.js +1 -1
- package/dist/utils/report/report-proof.js.map +1 -1
- package/dist/utils/report/report.js +2 -2
- package/dist/utils/report/report.js.map +1 -1
- package/dist/utils/report/statistic-data.js +1 -1
- package/dist/utils/resolve-path.js +2 -2
- package/dist/utils/resolve-path.js.map +1 -1
- package/dist/utils/salt.d.ts +3 -0
- package/dist/utils/salt.js +8 -0
- package/dist/utils/salt.js.map +1 -0
- package/dist/utils/share-rate.js +1 -1
- package/dist/utils/share-rate.js.map +1 -1
- package/dist/utils/snake-to-camel.js +1 -1
- package/dist/utils/snake-to-camel.js.map +1 -1
- package/dist/utils/spinner/spinners.js +2 -1
- package/dist/utils/spinner/spinners.js.map +1 -1
- package/dist/utils/statistic/report-statistic.d.ts +1 -1
- package/dist/utils/transactions/tx-private-key.d.ts +2 -1
- package/dist/utils/transactions/tx-private-key.js +5 -8
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +2 -2
- package/dist/utils/transactions/tx-wc.js +11 -15
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/transactions/utils.d.ts +1 -0
- package/dist/utils/transactions/utils.js +12 -0
- package/dist/utils/transactions/utils.js.map +1 -1
- package/dist/utils/wallet-connect.js +2 -3
- package/dist/utils/wallet-connect.js.map +1 -1
- package/dist/version/index.js +1 -1
- package/dist/vitest.config.js +1 -1
- package/dist/vitest.config.js.map +1 -1
- package/dist/vitest.integration.config.js +2 -2
- package/dist/vitest.integration.config.js.map +1 -1
- package/package.json +18 -24
- package/dist/tests/integration/globalSetup.js.map +0 -1
- package/dist/tests/utils/bigInt.test.js.map +0 -1
- package/dist/utils/bigInt.js +0 -3
- package/dist/utils/bigInt.js.map +0 -1
- package/dist/utils/fetchCL.js.map +0 -1
- /package/dist/abi/defi-wrapper/{StvStETHPool.d.ts → StvStEthPool.d.ts} +0 -0
- /package/dist/{tests/utils/bigInt.test.d.ts → programs/defi-wrapper/contracts/strategy/read.d.ts} +0 -0
- /package/dist/tests/integration/{globalSetup.d.ts → global-setup.d.ts} +0 -0
- /package/dist/utils/{bigInt.d.ts → big-int.d.ts} +0 -0
package/dist/providers/wallet.js
CHANGED
|
@@ -1,13 +1,85 @@
|
|
|
1
|
-
import { readFileSync } from 'fs';
|
|
1
|
+
import { readFileSync } from 'node:fs';
|
|
2
2
|
import { program } from '../command/index.js';
|
|
3
3
|
import { createPublicClient, createWalletClient, http, createTestClient, walletActions, publicActions, } from 'viem';
|
|
4
4
|
import { privateKeyToAccount } from 'viem/accounts';
|
|
5
5
|
import { Keystore } from 'ox';
|
|
6
6
|
import { envs, getConfig, getChainId, getElUrl, getChain } from '../configs/index.js';
|
|
7
7
|
import { createWalletConnectClient } from '../utils/index.js';
|
|
8
|
-
const
|
|
8
|
+
const MAX_UINT256_HEX = '0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff';
|
|
9
|
+
// Cached after the first eth_estimateGas call to avoid a double RPC
|
|
10
|
+
// roundtrip on every subsequent estimation when the node lacks support.
|
|
11
|
+
let nodeSupportsStateOverride = null;
|
|
12
|
+
const isStateOverrideError = (err) => {
|
|
13
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
14
|
+
return (msg.includes('stateOverride') ||
|
|
15
|
+
msg.includes('too many arguments') ||
|
|
16
|
+
msg.includes('invalid argument 2') ||
|
|
17
|
+
msg.includes('Invalid method parameters') ||
|
|
18
|
+
msg.includes('eth_estimateGas does not support'));
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Wraps viem's http() transport to inject a `stateOverride` into every
|
|
22
|
+
* `eth_estimateGas` RPC call, setting the sender's balance to maxUint256.
|
|
23
|
+
*
|
|
24
|
+
* Why: viem's `prepareTransactionRequest` fills `maxFeePerGas` BEFORE
|
|
25
|
+
* calling `eth_estimateGas`. The node then checks
|
|
26
|
+
* `balance >= blockGasLimit * maxFeePerGas`, which fails for low-balance
|
|
27
|
+
* accounts even though the actual TX cost is much lower.
|
|
28
|
+
*
|
|
29
|
+
* Operating at the transport level guarantees the override is applied
|
|
30
|
+
* regardless of how viem resolves its internal action chain (the
|
|
31
|
+
* `client.extend()` approach does not work because viem's bound methods
|
|
32
|
+
* close over the original base client and `getAction` short-circuits).
|
|
33
|
+
*
|
|
34
|
+
* Falls back to the original call if the RPC does not support
|
|
35
|
+
* `stateOverride` (geth < 1.13), and caches the result so subsequent
|
|
36
|
+
* calls skip the failed attempt.
|
|
37
|
+
*/
|
|
38
|
+
export const balanceAwareTransport = (url) => {
|
|
39
|
+
const baseTransport = http(url);
|
|
40
|
+
return ((params) => {
|
|
41
|
+
const base = baseTransport(params);
|
|
42
|
+
return {
|
|
43
|
+
...base,
|
|
44
|
+
async request(args) {
|
|
45
|
+
if (args.method === 'eth_estimateGas' &&
|
|
46
|
+
Array.isArray(args.params) &&
|
|
47
|
+
args.params[0]?.from) {
|
|
48
|
+
if (nodeSupportsStateOverride === false) {
|
|
49
|
+
return base.request(args);
|
|
50
|
+
}
|
|
51
|
+
const from = args.params[0].from;
|
|
52
|
+
const txRequest = args.params[0];
|
|
53
|
+
const blockTag = args.params[1] ?? 'latest';
|
|
54
|
+
const existingOverride = args.params[2] ?? {};
|
|
55
|
+
const stateOverride = {
|
|
56
|
+
...existingOverride,
|
|
57
|
+
[from]: { balance: MAX_UINT256_HEX },
|
|
58
|
+
};
|
|
59
|
+
try {
|
|
60
|
+
const result = await base.request({
|
|
61
|
+
method: 'eth_estimateGas',
|
|
62
|
+
params: [txRequest, blockTag, stateOverride],
|
|
63
|
+
});
|
|
64
|
+
nodeSupportsStateOverride = true;
|
|
65
|
+
return result;
|
|
66
|
+
}
|
|
67
|
+
catch (err) {
|
|
68
|
+
if (isStateOverrideError(err)) {
|
|
69
|
+
nodeSupportsStateOverride = false;
|
|
70
|
+
return await base.request(args);
|
|
71
|
+
}
|
|
72
|
+
throw err;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return base.request(args);
|
|
76
|
+
},
|
|
77
|
+
};
|
|
78
|
+
});
|
|
79
|
+
};
|
|
80
|
+
const getPrivateKey = async () => {
|
|
9
81
|
const { PRIVATE_KEY, ACCOUNT_FILE, ACCOUNT_FILE_PASSWORD } = getConfig();
|
|
10
|
-
const id = getChainId();
|
|
82
|
+
const id = await getChainId();
|
|
11
83
|
if (PRIVATE_KEY && ACCOUNT_FILE) {
|
|
12
84
|
throw new Error('You must provide only one of the following: private key or encrypted account file');
|
|
13
85
|
}
|
|
@@ -21,8 +93,7 @@ const getPrivateKey = () => {
|
|
|
21
93
|
if (!ACCOUNT_FILE_PASSWORD) {
|
|
22
94
|
throw new Error('Account file password is not provided');
|
|
23
95
|
}
|
|
24
|
-
|
|
25
|
-
const file = readFileSync(ACCOUNT_FILE, 'utf-8');
|
|
96
|
+
const file = readFileSync(ACCOUNT_FILE, 'utf8');
|
|
26
97
|
const fileContent = JSON.parse(file);
|
|
27
98
|
const kdfType = fileContent.crypto.kdf;
|
|
28
99
|
const [key] = Keystore[kdfType]({
|
|
@@ -37,7 +108,7 @@ const getPrivateKey = () => {
|
|
|
37
108
|
throw new Error('Private key or encrypted account file is not provided');
|
|
38
109
|
};
|
|
39
110
|
export const getAccount = async () => {
|
|
40
|
-
const id = getChainId();
|
|
111
|
+
const id = await getChainId();
|
|
41
112
|
if (program.opts().walletConnect) {
|
|
42
113
|
const { walletConnectClient } = await getWalletConnectClient();
|
|
43
114
|
if (!walletConnectClient.account) {
|
|
@@ -45,7 +116,7 @@ export const getAccount = async () => {
|
|
|
45
116
|
}
|
|
46
117
|
return walletConnectClient.account;
|
|
47
118
|
}
|
|
48
|
-
const privateKey = getPrivateKey();
|
|
119
|
+
const privateKey = await getPrivateKey();
|
|
49
120
|
if (!privateKey) {
|
|
50
121
|
throw new Error(`Private key for ${id} chain is not set`);
|
|
51
122
|
}
|
|
@@ -60,7 +131,7 @@ export const getPublicClient = async () => {
|
|
|
60
131
|
}
|
|
61
132
|
const publicClient = createPublicClient({
|
|
62
133
|
chain,
|
|
63
|
-
transport:
|
|
134
|
+
transport: balanceAwareTransport(getElUrl()),
|
|
64
135
|
});
|
|
65
136
|
PUBLIC_CLIENT_CACHE[chain.id] = publicClient;
|
|
66
137
|
return publicClient;
|
|
@@ -80,7 +151,7 @@ export const getWalletWithAccount = async () => {
|
|
|
80
151
|
return createWalletClient({
|
|
81
152
|
account,
|
|
82
153
|
chain,
|
|
83
|
-
transport:
|
|
154
|
+
transport: balanceAwareTransport(getElUrl()),
|
|
84
155
|
});
|
|
85
156
|
};
|
|
86
157
|
export const getWalletConnectClient = async () => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../providers/wallet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"wallet.js","sourceRoot":"","sources":["../../providers/wallet.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import type { Hex } from 'viem';
|
|
2
|
+
import type { TargetAndSourceValidators, ValidatorInfo } from '../../utils/consolidation/types.js';
|
|
3
|
+
export declare const VALID_PUBKEY_1: Hex;
|
|
4
|
+
export declare const VALID_PUBKEY_2: Hex;
|
|
5
|
+
export declare const VALID_PUBKEY_3: Hex;
|
|
6
|
+
export declare const VALID_PUBKEY_4: Hex;
|
|
7
|
+
export declare const ZERO_PUBKEY: Hex;
|
|
8
|
+
export declare const SHORT_PUBKEY: Hex;
|
|
9
|
+
export declare const VALID_DASHBOARD: Hex;
|
|
10
|
+
export declare const VALID_REFUND_RECIPIENT: Hex;
|
|
11
|
+
export declare const ZERO_ADDRESS: Hex;
|
|
12
|
+
export declare const createValidatorInfo: (overrides?: Partial<ValidatorInfo>) => ValidatorInfo;
|
|
13
|
+
export declare const createTargetAndSourceMap: (entries: Array<{
|
|
14
|
+
target: Hex;
|
|
15
|
+
targetInfo?: Partial<ValidatorInfo>;
|
|
16
|
+
sources: Array<{
|
|
17
|
+
pubkey: Hex;
|
|
18
|
+
info?: Partial<ValidatorInfo>;
|
|
19
|
+
}>;
|
|
20
|
+
}>) => TargetAndSourceValidators;
|
|
21
|
+
export declare const createCLValidatorData: (pubkey: string, overrides?: {
|
|
22
|
+
withdrawal_credentials?: string;
|
|
23
|
+
activation_epoch?: string;
|
|
24
|
+
status?: string;
|
|
25
|
+
balance?: string;
|
|
26
|
+
effective_balance?: string;
|
|
27
|
+
index?: string;
|
|
28
|
+
slashed?: boolean;
|
|
29
|
+
exit_epoch?: string;
|
|
30
|
+
withdrawable_epoch?: string;
|
|
31
|
+
}) => {
|
|
32
|
+
index: string;
|
|
33
|
+
balance: string;
|
|
34
|
+
status: string;
|
|
35
|
+
validator: {
|
|
36
|
+
pubkey: string;
|
|
37
|
+
withdrawal_credentials: string;
|
|
38
|
+
effective_balance: string;
|
|
39
|
+
slashed: boolean;
|
|
40
|
+
activation_eligibility_epoch: string;
|
|
41
|
+
activation_epoch: string;
|
|
42
|
+
exit_epoch: string;
|
|
43
|
+
withdrawable_epoch: string;
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
export declare const createValidatorsInfo: (validators: ReturnType<typeof createCLValidatorData>[]) => {
|
|
47
|
+
execution_optimistic: boolean;
|
|
48
|
+
finalized: boolean;
|
|
49
|
+
data: {
|
|
50
|
+
index: string;
|
|
51
|
+
balance: string;
|
|
52
|
+
status: string;
|
|
53
|
+
validator: {
|
|
54
|
+
pubkey: string;
|
|
55
|
+
withdrawal_credentials: string;
|
|
56
|
+
effective_balance: string;
|
|
57
|
+
slashed: boolean;
|
|
58
|
+
activation_eligibility_epoch: string;
|
|
59
|
+
activation_epoch: string;
|
|
60
|
+
exit_epoch: string;
|
|
61
|
+
withdrawable_epoch: string;
|
|
62
|
+
};
|
|
63
|
+
}[];
|
|
64
|
+
};
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
// Valid 48-byte pubkeys (96 hex chars after 0x)
|
|
2
|
+
export const VALID_PUBKEY_1 = ('0x' + 'aa'.repeat(48));
|
|
3
|
+
export const VALID_PUBKEY_2 = ('0x' + 'bb'.repeat(48));
|
|
4
|
+
export const VALID_PUBKEY_3 = ('0x' + 'cc'.repeat(48));
|
|
5
|
+
export const VALID_PUBKEY_4 = ('0x' + 'dd'.repeat(48));
|
|
6
|
+
export const ZERO_PUBKEY = ('0x' + '00'.repeat(48));
|
|
7
|
+
// Invalid pubkeys for testing validation
|
|
8
|
+
export const SHORT_PUBKEY = ('0x' + 'aa'.repeat(47));
|
|
9
|
+
// Valid addresses
|
|
10
|
+
export const VALID_DASHBOARD = '0x318FcB0CCE93aBA9C21a1B4B38dbACcCEfF091E0';
|
|
11
|
+
export const VALID_REFUND_RECIPIENT = '0x463f500FCb218d38FB35BECD20475ea75a79B7A9';
|
|
12
|
+
export const ZERO_ADDRESS = '0x0000000000000000000000000000000000000000';
|
|
13
|
+
export const createValidatorInfo = (overrides = {}) => ({
|
|
14
|
+
status: 'active_ongoing',
|
|
15
|
+
balance: 32000000000n,
|
|
16
|
+
index: '1',
|
|
17
|
+
effectiveBalance: 32000000000n,
|
|
18
|
+
...overrides,
|
|
19
|
+
});
|
|
20
|
+
export const createTargetAndSourceMap = (entries) => {
|
|
21
|
+
const map = new Map();
|
|
22
|
+
for (const entry of entries) {
|
|
23
|
+
const sourceValidators = new Map();
|
|
24
|
+
for (const source of entry.sources) {
|
|
25
|
+
sourceValidators.set(source.pubkey, createValidatorInfo(source.info));
|
|
26
|
+
}
|
|
27
|
+
map.set(entry.target, {
|
|
28
|
+
info: createValidatorInfo(entry.targetInfo),
|
|
29
|
+
sourceValidators,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
return map;
|
|
33
|
+
};
|
|
34
|
+
// CL ValidatorsInfo mock data builder
|
|
35
|
+
export const createCLValidatorData = (pubkey, overrides = {}) => ({
|
|
36
|
+
index: overrides.index ?? '1',
|
|
37
|
+
balance: overrides.balance ?? '32000000000',
|
|
38
|
+
status: overrides.status ?? 'active_ongoing',
|
|
39
|
+
validator: {
|
|
40
|
+
pubkey,
|
|
41
|
+
withdrawal_credentials: overrides.withdrawal_credentials ??
|
|
42
|
+
'0x0100000000000000000000000000000000000000000000000000000000000001',
|
|
43
|
+
effective_balance: overrides.effective_balance ?? '32000000000',
|
|
44
|
+
slashed: overrides.slashed ?? false,
|
|
45
|
+
activation_eligibility_epoch: '0',
|
|
46
|
+
activation_epoch: overrides.activation_epoch ?? '0',
|
|
47
|
+
exit_epoch: overrides.exit_epoch ?? '18446744073709551615',
|
|
48
|
+
withdrawable_epoch: overrides.withdrawable_epoch ?? '18446744073709551615',
|
|
49
|
+
},
|
|
50
|
+
});
|
|
51
|
+
export const createValidatorsInfo = (validators) => ({
|
|
52
|
+
execution_optimistic: false,
|
|
53
|
+
finalized: true,
|
|
54
|
+
data: validators,
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=consolidation-fixtures.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"consolidation-fixtures.js","sourceRoot":"","sources":["../../../tests/fixtures/consolidation-fixtures.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { describe, test, expect, beforeAll } from 'vitest';
|
|
2
2
|
import { checkValidatorInfo, checkPdgIsPaused } from '../../features/index.js';
|
|
3
|
-
import { getPredepositGuaranteeContract, } from 'contracts/pdg.js';
|
|
3
|
+
import { getPredepositGuaranteeContract, } from '../../contracts/pdg.js';
|
|
4
4
|
import { loadTestConfig } from './helpers/test-config.js';
|
|
5
5
|
import { setupIntegrationTestsBeforeEach } from './helpers/test-setup.js';
|
|
6
6
|
describe('Deposits Integration Tests', () => {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { describe, test, expect, beforeAll } from 'vitest';
|
|
2
|
+
import { createPublicClient, http, parseEther, maxUint256 } from 'viem';
|
|
3
|
+
import { getChain } from '../../configs/index.js';
|
|
4
|
+
import { loadTestConfig } from './helpers/test-config.js';
|
|
5
|
+
import { createAnvilTestClient, mintEth, getAccountFromPrivateKey, } from './helpers/test-client.js';
|
|
6
|
+
import { setupIntegrationTestsBeforeEach } from './helpers/test-setup.js';
|
|
7
|
+
/**
|
|
8
|
+
* Integration tests for the gas estimation stateOverride fix.
|
|
9
|
+
*
|
|
10
|
+
* Proves that stateOverride in eth_estimateGas allows accurate gas estimation
|
|
11
|
+
* for low-balance accounts on a real Anvil fork.
|
|
12
|
+
*/
|
|
13
|
+
// Anvil's default account #1 (not the one used by the test suite)
|
|
14
|
+
const LOW_BALANCE_KEY = '0x59c6995e998f97a5a0044966f0945389dc9e86dae88c7a8412f4603b6b78690d';
|
|
15
|
+
describe('gas estimation with stateOverride', () => {
|
|
16
|
+
setupIntegrationTestsBeforeEach();
|
|
17
|
+
let rpcUrl;
|
|
18
|
+
let chainObj;
|
|
19
|
+
beforeAll(async () => {
|
|
20
|
+
const config = loadTestConfig();
|
|
21
|
+
rpcUrl = config.EL_URL;
|
|
22
|
+
chainObj = await getChain();
|
|
23
|
+
});
|
|
24
|
+
test('stateOverride: low-balance account succeeds with balance override', async () => {
|
|
25
|
+
const testClient = createAnvilTestClient(chainObj, rpcUrl);
|
|
26
|
+
const lowBalanceAccount = getAccountFromPrivateKey(LOW_BALANCE_KEY);
|
|
27
|
+
await mintEth(testClient, lowBalanceAccount.address, parseEther('0.0001'));
|
|
28
|
+
const publicClient = createPublicClient({
|
|
29
|
+
chain: chainObj,
|
|
30
|
+
transport: http(rpcUrl),
|
|
31
|
+
});
|
|
32
|
+
// With stateOverride — estimation succeeds regardless of real balance
|
|
33
|
+
const gas = await publicClient.estimateGas({
|
|
34
|
+
account: lowBalanceAccount,
|
|
35
|
+
to: '0x0000000000000000000000000000000000000001',
|
|
36
|
+
value: 0n,
|
|
37
|
+
stateOverride: [
|
|
38
|
+
{
|
|
39
|
+
address: lowBalanceAccount.address,
|
|
40
|
+
balance: maxUint256,
|
|
41
|
+
},
|
|
42
|
+
],
|
|
43
|
+
});
|
|
44
|
+
expect(gas).toBeGreaterThan(0n);
|
|
45
|
+
expect(gas).toBeLessThanOrEqual(100000n);
|
|
46
|
+
});
|
|
47
|
+
test('contract interaction: estimateGas with stateOverride on ERC-20 approve', async () => {
|
|
48
|
+
const testClient = createAnvilTestClient(chainObj, rpcUrl);
|
|
49
|
+
const lowBalanceAccount = getAccountFromPrivateKey(LOW_BALANCE_KEY);
|
|
50
|
+
await mintEth(testClient, lowBalanceAccount.address, parseEther('0.0001'));
|
|
51
|
+
const publicClient = createPublicClient({
|
|
52
|
+
chain: chainObj,
|
|
53
|
+
transport: http(rpcUrl),
|
|
54
|
+
});
|
|
55
|
+
// ERC-20 approve(spender, amount) on WETH
|
|
56
|
+
const WETH = '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2';
|
|
57
|
+
const approveData = '0x095ea7b3' +
|
|
58
|
+
'000000000000000000000000deadbeefdeadbeefdeadbeefdeadbeefdeadbeef' +
|
|
59
|
+
'ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff';
|
|
60
|
+
const gas = await publicClient.estimateGas({
|
|
61
|
+
account: lowBalanceAccount,
|
|
62
|
+
to: WETH,
|
|
63
|
+
data: approveData,
|
|
64
|
+
stateOverride: [
|
|
65
|
+
{
|
|
66
|
+
address: lowBalanceAccount.address,
|
|
67
|
+
balance: maxUint256,
|
|
68
|
+
},
|
|
69
|
+
],
|
|
70
|
+
});
|
|
71
|
+
// approve() typically costs ~46k gas
|
|
72
|
+
expect(gas).toBeGreaterThan(20000n);
|
|
73
|
+
expect(gas).toBeLessThan(200000n);
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
//# sourceMappingURL=gas-estimation.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gas-estimation.test.js","sourceRoot":"","sources":["../../../tests/integration/gas-estimation.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { createAnvil } from '@viem/anvil';
|
|
2
2
|
import * as dotenv from 'dotenv';
|
|
3
|
-
import path from 'path';
|
|
3
|
+
import path from 'node:path';
|
|
4
4
|
// Load environment variables from .env.test or .env
|
|
5
5
|
dotenv.config({ path: path.resolve(process.cwd(), '.env.test') });
|
|
6
6
|
dotenv.config(); // Fallback to .env if .env.test doesn't exist
|
|
@@ -52,4 +52,4 @@ export default async function globalSetup() {
|
|
|
52
52
|
}
|
|
53
53
|
};
|
|
54
54
|
}
|
|
55
|
-
//# sourceMappingURL=
|
|
55
|
+
//# sourceMappingURL=global-setup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"global-setup.js","sourceRoot":"","sources":["../../../tests/integration/global-setup.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,oDAAoD;AACpD,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,WAAW,CAAC,EAAE,CAAC,CAAC;AAClE,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,8CAA8C;AAE/D,wBAAwB;AACxB,IAAI,aAAa,GAAmD,IAAI,CAAC;AAEzE,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,WAAW;IACvC,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,MAAM,CAAC,CAAC;IAC5D,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC;IACpC,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB;QACrD,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;QACvC,CAAC,CAAC,SAAS,CAAC;IACd,MAAM,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,GAAG,CAAC,CAAC;IAErD,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CACb,+DAA+D,CAChE,CAAC;IACJ,CAAC;IAED,OAAO,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACvC,OAAO,CAAC,IAAI,CAAC,aAAa,QAAQ,EAAE,CAAC,CAAC;IACtC,OAAO,CAAC,IAAI,CAAC,sBAAsB,iBAAiB,IAAI,QAAQ,EAAE,CAAC,CAAC;IACpE,OAAO,CAAC,IAAI,CAAC,aAAa,QAAQ,EAAE,CAAC,CAAC;IACtC,OAAO,CAAC,IAAI,CAAC,SAAS,UAAU,EAAE,CAAC,CAAC;IAEpC,wBAAwB;IACxB,MAAM,KAAK,GAAG,WAAW,CAAC;QACxB,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,QAAQ;QACjB,eAAe,EAAE,iBAAiB;QAClC,OAAO,EAAE,QAAQ;KAClB,CAAC,CAAC;IAEH,cAAc;IACd,MAAM,KAAK,CAAC,KAAK,EAAE,CAAC;IAEpB,wCAAwC;IACxC,MAAM,WAAW,GAAG,oBAAoB,UAAU,EAAE,CAAC;IACrD,OAAO,CAAC,GAAG,CAAC,MAAM,GAAG,WAAW,CAAC;IAEjC,OAAO,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IAC3C,OAAO,CAAC,IAAI,CAAC,kBAAkB,WAAW,EAAE,CAAC,CAAC;IAE9C,8BAA8B;IAC9B,aAAa,GAAG,KAAK,CAAC;IAEtB,wCAAwC;IACxC,OAAO,KAAK,IAAI,EAAE;QAChB,IAAI,CAAC;YACH,IAAI,aAAa,EAAE,CAAC;gBAClB,OAAO,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;gBAClC,MAAM,aAAa,CAAC,IAAI,EAAE,CAAC;gBAC3B,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBAC9B,aAAa,GAAG,IAAI,CAAC;YACvB,CAAC;QACH,CAAC;QAAC,OAAO,KAAU,EAAE,CAAC;YACpB,OAAO,CAAC,KAAK,CAAC,0BAA0B,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC,CAAC;AACJ,CAAC"}
|