@lidofinance/lsv-cli 1.0.0-alpha.6 → 1.0.0-alpha.61
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 +53 -20
- package/dist/abi/AccessControlConfirmable.d.ts +331 -0
- package/dist/abi/AccessControlConfirmable.js +430 -0
- package/dist/abi/AccessControlConfirmable.js.map +1 -0
- package/dist/abi/Dashboard.d.ts +2305 -0
- package/dist/abi/Dashboard.js +2105 -0
- package/dist/abi/Dashboard.js.map +1 -0
- package/dist/abi/LazyOracle.d.ts +592 -0
- package/dist/abi/LazyOracle.js +766 -0
- package/dist/abi/LazyOracle.js.map +1 -0
- package/dist/abi/LidoLocator.d.ts +358 -0
- package/dist/abi/LidoLocator.js +462 -0
- package/dist/abi/LidoLocator.js.map +1 -0
- package/dist/abi/OperatorGrid.d.ts +1246 -0
- package/dist/abi/OperatorGrid.js +1368 -0
- package/dist/abi/OperatorGrid.js.map +1 -0
- package/dist/abi/PredepositGuarantee.d.ts +1697 -0
- package/dist/abi/PredepositGuarantee.js +2010 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -0
- package/dist/abi/StEth.d.ts +372 -0
- package/dist/abi/StEth.js +493 -0
- package/dist/abi/StEth.js.map +1 -0
- package/dist/abi/StakingVault.d.ts +757 -0
- package/dist/abi/StakingVault.js +790 -0
- package/dist/abi/StakingVault.js.map +1 -0
- package/dist/abi/TokenManager.d.ts +577 -0
- package/dist/abi/TokenManager.js +756 -0
- package/dist/abi/TokenManager.js.map +1 -0
- package/dist/abi/VaultFactory.d.ts +739 -0
- package/dist/abi/VaultFactory.js +269 -0
- package/dist/abi/VaultFactory.js.map +1 -0
- package/dist/abi/VaultHub.d.ts +2546 -0
- package/dist/abi/VaultHub.js +2276 -509
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +617 -0
- package/dist/abi/VaultViewer.js +807 -0
- package/dist/abi/VaultViewer.js.map +1 -0
- package/dist/abi/Voting.d.ts +676 -0
- package/dist/abi/Voting.js +884 -0
- package/dist/abi/Voting.js.map +1 -0
- package/dist/abi/WstEth.d.ts +362 -0
- package/dist/abi/WstEth.js +478 -0
- package/dist/abi/WstEth.js.map +1 -0
- package/dist/abi/index.d.ts +14 -0
- package/dist/abi/index.js +15 -0
- package/dist/abi/index.js.map +1 -0
- package/dist/command/index.d.ts +2 -0
- package/dist/command/index.js +9 -5
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +35 -0
- package/dist/configs/constants.js +3 -0
- package/dist/configs/constants.js.map +1 -0
- package/dist/configs/deployed.d.ts +17 -0
- package/dist/configs/deployed.js +87 -52
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/envs.d.ts +2 -0
- package/dist/configs/envs.js +13 -37
- package/dist/configs/envs.js.map +1 -1
- package/dist/configs/index.d.ts +3 -0
- package/dist/configs/index.js +3 -18
- package/dist/configs/index.js.map +1 -1
- package/dist/configs/utils.d.ts +4 -0
- package/dist/configs/utils.js +22 -0
- package/dist/configs/utils.js.map +1 -0
- package/dist/contracts/dashboard.d.ts +4 -0
- package/dist/contracts/dashboard.js +11 -0
- package/dist/contracts/dashboard.js.map +1 -0
- package/dist/contracts/index.d.ts +12 -0
- package/dist/contracts/index.js +12 -17
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/lazy-oracle.d.ts +3 -0
- package/dist/contracts/lazy-oracle.js +18 -0
- package/dist/contracts/lazy-oracle.js.map +1 -0
- package/dist/contracts/locator.d.ts +8239 -0
- package/dist/contracts/locator.js +16 -0
- package/dist/contracts/locator.js.map +1 -0
- package/dist/contracts/operator-grid.d.ts +4 -0
- package/dist/contracts/operator-grid.js +17 -0
- package/dist/contracts/operator-grid.js.map +1 -0
- package/dist/contracts/pdg.d.ts +4 -0
- package/dist/contracts/pdg.js +17 -0
- package/dist/contracts/pdg.js.map +1 -0
- package/dist/contracts/steth.d.ts +27706 -0
- package/dist/contracts/steth.js +18 -0
- package/dist/contracts/steth.js.map +1 -0
- package/dist/contracts/token-manager.d.ts +3 -0
- package/dist/contracts/token-manager.js +13 -0
- package/dist/contracts/token-manager.js.map +1 -0
- package/dist/contracts/vault-factory.d.ts +16404 -0
- package/dist/contracts/vault-factory.js +14 -0
- package/dist/contracts/vault-factory.js.map +1 -0
- package/dist/contracts/vault-hub.d.ts +3 -0
- package/dist/contracts/vault-hub.js +14 -16
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +11197 -0
- package/dist/contracts/vault-viewer.js +23 -0
- package/dist/contracts/vault-viewer.js.map +1 -0
- package/dist/contracts/vault.d.ts +4 -0
- package/dist/contracts/vault.js +11 -0
- package/dist/contracts/vault.js.map +1 -0
- package/dist/contracts/wsteth.d.ts +24690 -0
- package/dist/contracts/wsteth.js +18 -0
- package/dist/contracts/wsteth.js.map +1 -0
- package/dist/features/dashboard.d.ts +5 -0
- package/dist/features/dashboard.js +14 -0
- package/dist/features/dashboard.js.map +1 -0
- package/dist/features/deposits/check-bls-deposits.d.ts +3 -0
- package/dist/features/deposits/check-bls-deposits.js +15 -0
- package/dist/features/deposits/check-bls-deposits.js.map +1 -0
- package/dist/features/deposits/index.d.ts +3 -0
- package/dist/features/deposits/index.js +4 -0
- package/dist/features/deposits/index.js.map +1 -0
- package/dist/features/deposits/make-pdg-proof.d.ts +3 -0
- package/dist/features/deposits/make-pdg-proof.js +52 -0
- package/dist/features/deposits/make-pdg-proof.js.map +1 -0
- package/dist/features/deposits/no-pdg.d.ts +22 -0
- package/dist/features/deposits/no-pdg.js +103 -0
- package/dist/features/deposits/no-pdg.js.map +1 -0
- package/dist/features/index.d.ts +10 -0
- package/dist/features/index.js +11 -0
- package/dist/features/index.js.map +1 -0
- package/dist/features/mint-burn/allowance.d.ts +2 -0
- package/dist/features/mint-burn/allowance.js +49 -0
- package/dist/features/mint-burn/allowance.js.map +1 -0
- package/dist/features/mint-burn/burn-shares.d.ts +3 -0
- package/dist/features/mint-burn/burn-shares.js +33 -0
- package/dist/features/mint-burn/burn-shares.js.map +1 -0
- package/dist/features/mint-burn/burn-steth.d.ts +3 -0
- package/dist/features/mint-burn/burn-steth.js +35 -0
- package/dist/features/mint-burn/burn-steth.js.map +1 -0
- package/dist/features/mint-burn/index.d.ts +5 -0
- package/dist/features/mint-burn/index.js +6 -0
- package/dist/features/mint-burn/index.js.map +1 -0
- package/dist/features/mint-burn/mint-shares.d.ts +3 -0
- package/dist/features/mint-burn/mint-shares.js +37 -0
- package/dist/features/mint-burn/mint-shares.js.map +1 -0
- package/dist/features/mint-burn/mint-steth.d.ts +3 -0
- package/dist/features/mint-burn/mint-steth.js +39 -0
- package/dist/features/mint-burn/mint-steth.js.map +1 -0
- package/dist/features/operator-grid.d.ts +2 -0
- package/dist/features/operator-grid.js +64 -0
- package/dist/features/operator-grid.js.map +1 -0
- package/dist/features/pdg.d.ts +4 -0
- package/dist/features/pdg.js +114 -0
- package/dist/features/pdg.js.map +1 -0
- package/dist/features/token-manager.d.ts +1 -0
- package/dist/features/token-manager.js +7 -0
- package/dist/features/token-manager.js.map +1 -0
- package/dist/features/utils/get-address.d.ts +2 -0
- package/dist/features/utils/get-address.js +16 -0
- package/dist/features/utils/get-address.js.map +1 -0
- package/dist/features/utils/index.d.ts +5 -0
- package/dist/features/utils/index.js +6 -0
- package/dist/features/utils/index.js.map +1 -0
- package/dist/features/utils/liability-shares.d.ts +2 -0
- package/dist/features/utils/liability-shares.js +10 -0
- package/dist/features/utils/liability-shares.js.map +1 -0
- package/dist/features/utils/minting-capacity.d.ts +2 -0
- package/dist/features/utils/minting-capacity.js +11 -0
- package/dist/features/utils/minting-capacity.js.map +1 -0
- package/dist/features/utils/quarantine.d.ts +23 -0
- package/dist/features/utils/quarantine.js +47 -0
- package/dist/features/utils/quarantine.js.map +1 -0
- package/dist/features/utils/report-fresh.d.ts +3 -0
- package/dist/features/utils/report-fresh.js +36 -0
- package/dist/features/utils/report-fresh.js.map +1 -0
- package/dist/features/vault-factory.d.ts +29 -0
- package/dist/features/vault-factory.js +99 -0
- package/dist/features/vault-factory.js.map +1 -0
- package/dist/features/vault-hub.d.ts +2 -0
- package/dist/features/vault-hub.js +88 -0
- package/dist/features/vault-hub.js.map +1 -0
- package/dist/features/vault-operations/create-vault.d.ts +2 -0
- package/dist/features/vault-operations/create-vault.js +58 -0
- package/dist/features/vault-operations/create-vault.js.map +1 -0
- package/dist/features/vault-operations/dashboard-by-vault.d.ts +11 -0
- package/dist/features/vault-operations/dashboard-by-vault.js +34 -0
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -0
- package/dist/features/vault-operations/index.d.ts +7 -0
- package/dist/features/vault-operations/index.js +8 -0
- package/dist/features/vault-operations/index.js.map +1 -0
- package/dist/features/vault-operations/vault-health.d.ts +2 -0
- package/dist/features/vault-operations/vault-health.js +27 -0
- package/dist/features/vault-operations/vault-health.js.map +1 -0
- package/dist/features/vault-operations/vault-info.d.ts +2 -0
- package/dist/features/vault-operations/vault-info.js +109 -0
- package/dist/features/vault-operations/vault-info.js.map +1 -0
- package/dist/features/vault-operations/vault-overview.d.ts +2 -0
- package/dist/features/vault-operations/vault-overview.js +141 -0
- package/dist/features/vault-operations/vault-overview.js.map +1 -0
- package/dist/features/vault-operations/vault-roles.d.ts +5 -0
- package/dist/features/vault-operations/vault-roles.js +64 -0
- package/dist/features/vault-operations/vault-roles.js.map +1 -0
- package/dist/features/vault-operations/vaults-by-role.d.ts +1 -0
- package/dist/features/vault-operations/vaults-by-role.js +48 -0
- package/dist/features/vault-operations/vaults-by-role.js.map +1 -0
- package/dist/features/vault.d.ts +2 -0
- package/dist/features/vault.js +48 -0
- package/dist/features/vault.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +23 -5
- package/dist/index.js.map +1 -1
- package/dist/programs/account/index.d.ts +3 -0
- package/dist/programs/account/index.js +4 -0
- package/dist/programs/account/index.js.map +1 -0
- package/dist/programs/account/main.d.ts +1 -0
- package/dist/programs/account/main.js +5 -0
- package/dist/programs/account/main.js.map +1 -0
- package/dist/programs/account/read.d.ts +1 -0
- package/dist/programs/account/read.js +79 -0
- package/dist/programs/account/read.js.map +1 -0
- package/dist/programs/account/write.d.ts +1 -0
- package/dist/programs/account/write.js +73 -0
- package/dist/programs/account/write.js.map +1 -0
- package/dist/programs/config.d.ts +1 -0
- package/dist/programs/config.js +31 -0
- package/dist/programs/config.js.map +1 -0
- package/dist/programs/contracts/dashboard/config.d.ts +3 -0
- package/dist/programs/contracts/dashboard/config.js +115 -0
- package/dist/programs/contracts/dashboard/config.js.map +1 -0
- package/dist/programs/contracts/dashboard/index.d.ts +3 -0
- package/dist/programs/contracts/dashboard/index.js +4 -0
- package/dist/programs/contracts/dashboard/index.js.map +1 -0
- package/dist/programs/contracts/dashboard/main.d.ts +1 -0
- package/dist/programs/contracts/dashboard/main.js +5 -0
- package/dist/programs/contracts/dashboard/main.js.map +1 -0
- package/dist/programs/contracts/dashboard/read.d.ts +1 -0
- package/dist/programs/contracts/dashboard/read.js +98 -0
- package/dist/programs/contracts/dashboard/read.js.map +1 -0
- package/dist/programs/contracts/dashboard/write.d.ts +1 -0
- package/dist/programs/contracts/dashboard/write.js +638 -0
- package/dist/programs/contracts/dashboard/write.js.map +1 -0
- package/dist/programs/contracts/hub/config.d.ts +3 -0
- package/dist/programs/contracts/hub/config.js +165 -0
- package/dist/programs/contracts/hub/config.js.map +1 -0
- package/dist/programs/contracts/hub/index.d.ts +3 -0
- package/dist/programs/contracts/hub/index.js +4 -0
- package/dist/programs/contracts/hub/index.js.map +1 -0
- package/dist/programs/contracts/hub/main.d.ts +1 -0
- package/dist/programs/contracts/hub/main.js +5 -0
- package/dist/programs/contracts/hub/main.js.map +1 -0
- package/dist/programs/contracts/hub/read.d.ts +1 -0
- package/dist/programs/contracts/hub/read.js +54 -0
- package/dist/programs/contracts/hub/read.js.map +1 -0
- package/dist/programs/contracts/hub/write.d.ts +1 -0
- package/dist/programs/contracts/hub/write.js +425 -0
- package/dist/programs/contracts/hub/write.js.map +1 -0
- package/dist/programs/contracts/index.d.ts +9 -0
- package/dist/programs/contracts/index.js +10 -0
- package/dist/programs/contracts/index.js.map +1 -0
- package/dist/programs/contracts/lazy-oracle/config.d.ts +3 -0
- package/dist/programs/contracts/lazy-oracle/config.js +57 -0
- package/dist/programs/contracts/lazy-oracle/config.js.map +1 -0
- package/dist/programs/contracts/lazy-oracle/index.d.ts +2 -0
- package/dist/programs/contracts/lazy-oracle/index.js +3 -0
- package/dist/programs/contracts/lazy-oracle/index.js.map +1 -0
- package/dist/programs/contracts/lazy-oracle/main.d.ts +1 -0
- package/dist/programs/contracts/lazy-oracle/main.js +5 -0
- package/dist/programs/contracts/lazy-oracle/main.js.map +1 -0
- package/dist/programs/contracts/lazy-oracle/read.d.ts +1 -0
- package/dist/programs/contracts/lazy-oracle/read.js +17 -0
- package/dist/programs/contracts/lazy-oracle/read.js.map +1 -0
- package/dist/programs/contracts/main.d.ts +1 -0
- package/dist/programs/contracts/main.js +6 -0
- package/dist/programs/contracts/main.js.map +1 -0
- package/dist/programs/contracts/operator-grid/config.d.ts +3 -0
- package/dist/programs/contracts/operator-grid/config.js +87 -0
- package/dist/programs/contracts/operator-grid/config.js.map +1 -0
- package/dist/programs/contracts/operator-grid/index.d.ts +3 -0
- package/dist/programs/contracts/operator-grid/index.js +4 -0
- package/dist/programs/contracts/operator-grid/index.js.map +1 -0
- package/dist/programs/contracts/operator-grid/main.d.ts +1 -0
- package/dist/programs/contracts/operator-grid/main.js +5 -0
- package/dist/programs/contracts/operator-grid/main.js.map +1 -0
- package/dist/programs/contracts/operator-grid/read.d.ts +1 -0
- package/dist/programs/contracts/operator-grid/read.js +30 -0
- package/dist/programs/contracts/operator-grid/read.js.map +1 -0
- package/dist/programs/contracts/operator-grid/write.d.ts +1 -0
- package/dist/programs/contracts/operator-grid/write.js +119 -0
- package/dist/programs/contracts/operator-grid/write.js.map +1 -0
- package/dist/programs/contracts/pdg/config.d.ts +3 -0
- package/dist/programs/contracts/pdg/config.js +160 -0
- package/dist/programs/contracts/pdg/config.js.map +1 -0
- package/dist/programs/contracts/pdg/index.d.ts +3 -0
- package/dist/programs/contracts/pdg/index.js +4 -0
- package/dist/programs/contracts/pdg/index.js.map +1 -0
- package/dist/programs/contracts/pdg/main.d.ts +1 -0
- package/dist/programs/contracts/pdg/main.js +5 -0
- package/dist/programs/contracts/pdg/main.js.map +1 -0
- package/dist/programs/contracts/pdg/read.d.ts +1 -0
- package/dist/programs/contracts/pdg/read.js +38 -0
- package/dist/programs/contracts/pdg/read.js.map +1 -0
- package/dist/programs/contracts/pdg/write.d.ts +1 -0
- package/dist/programs/contracts/pdg/write.js +388 -0
- package/dist/programs/contracts/pdg/write.js.map +1 -0
- package/dist/programs/contracts/vault/config.d.ts +3 -0
- package/dist/programs/contracts/vault/config.js +42 -0
- package/dist/programs/contracts/vault/config.js.map +1 -0
- package/dist/programs/contracts/vault/index.d.ts +3 -0
- package/dist/programs/contracts/vault/index.js +4 -0
- package/dist/programs/contracts/vault/index.js.map +1 -0
- package/dist/programs/contracts/vault/main.d.ts +1 -0
- package/dist/programs/contracts/vault/main.js +3 -0
- package/dist/programs/contracts/vault/main.js.map +1 -0
- package/dist/programs/contracts/vault/read.d.ts +1 -0
- package/dist/programs/contracts/vault/read.js +25 -0
- package/dist/programs/contracts/vault/read.js.map +1 -0
- package/dist/programs/contracts/vault/write.d.ts +1 -0
- package/dist/programs/contracts/vault/write.js +214 -0
- package/dist/programs/contracts/vault/write.js.map +1 -0
- package/dist/programs/contracts/vault-factory/config.d.ts +3 -0
- package/dist/programs/contracts/vault-factory/config.js +2 -0
- package/dist/programs/contracts/vault-factory/config.js.map +1 -0
- package/dist/programs/contracts/vault-factory/index.d.ts +3 -0
- package/dist/programs/contracts/vault-factory/index.js +4 -0
- package/dist/programs/contracts/vault-factory/index.js.map +1 -0
- package/dist/programs/contracts/vault-factory/main.d.ts +1 -0
- package/dist/programs/contracts/vault-factory/main.js +5 -0
- package/dist/programs/contracts/vault-factory/main.js.map +1 -0
- package/dist/programs/contracts/vault-factory/read.d.ts +1 -0
- package/dist/programs/contracts/vault-factory/read.js +24 -0
- package/dist/programs/contracts/vault-factory/read.js.map +1 -0
- package/dist/programs/contracts/vault-factory/write.d.ts +1 -0
- package/dist/programs/contracts/vault-factory/write.js +126 -0
- package/dist/programs/contracts/vault-factory/write.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/config.d.ts +3 -0
- package/dist/programs/contracts/vault-viewer/config.js +120 -0
- package/dist/programs/contracts/vault-viewer/config.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/index.d.ts +2 -0
- package/dist/programs/contracts/vault-viewer/index.js +3 -0
- package/dist/programs/contracts/vault-viewer/index.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/main.d.ts +1 -0
- package/dist/programs/contracts/vault-viewer/main.js +5 -0
- package/dist/programs/contracts/vault-viewer/main.js.map +1 -0
- package/dist/programs/contracts/vault-viewer/read.d.ts +1 -0
- package/dist/programs/contracts/vault-viewer/read.js +131 -0
- package/dist/programs/contracts/vault-viewer/read.js.map +1 -0
- package/dist/programs/index.d.ts +4 -0
- package/dist/programs/index.js +4 -17
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/pdg-helpers.d.ts +1 -0
- package/dist/programs/pdg-helpers.js +257 -0
- package/dist/programs/pdg-helpers.js.map +1 -0
- package/dist/programs/use-cases/deposits/index.d.ts +3 -0
- package/dist/programs/use-cases/deposits/index.js +4 -0
- package/dist/programs/use-cases/deposits/index.js.map +1 -0
- package/dist/programs/use-cases/deposits/main.d.ts +1 -0
- package/dist/programs/use-cases/deposits/main.js +6 -0
- package/dist/programs/use-cases/deposits/main.js.map +1 -0
- package/dist/programs/use-cases/deposits/read.d.ts +1 -0
- package/dist/programs/use-cases/deposits/read.js +77 -0
- package/dist/programs/use-cases/deposits/read.js.map +1 -0
- package/dist/programs/use-cases/deposits/write.d.ts +1 -0
- package/dist/programs/use-cases/deposits/write.js +212 -0
- package/dist/programs/use-cases/deposits/write.js.map +1 -0
- package/dist/programs/use-cases/index.d.ts +4 -0
- package/dist/programs/use-cases/index.js +5 -0
- package/dist/programs/use-cases/index.js.map +1 -0
- package/dist/programs/use-cases/metrics/index.d.ts +2 -0
- package/dist/programs/use-cases/metrics/index.js +3 -0
- package/dist/programs/use-cases/metrics/index.js.map +1 -0
- package/dist/programs/use-cases/metrics/main.d.ts +1 -0
- package/dist/programs/use-cases/metrics/main.js +6 -0
- package/dist/programs/use-cases/metrics/main.js.map +1 -0
- package/dist/programs/use-cases/metrics/read.d.ts +1 -0
- package/dist/programs/use-cases/metrics/read.js +239 -0
- package/dist/programs/use-cases/metrics/read.js.map +1 -0
- package/dist/programs/use-cases/report/index.d.ts +3 -0
- package/dist/programs/use-cases/report/index.js +4 -0
- package/dist/programs/use-cases/report/index.js.map +1 -0
- package/dist/programs/use-cases/report/main.d.ts +1 -0
- package/dist/programs/use-cases/report/main.js +6 -0
- package/dist/programs/use-cases/report/main.js.map +1 -0
- package/dist/programs/use-cases/report/read.d.ts +1 -0
- package/dist/programs/use-cases/report/read.js +104 -0
- package/dist/programs/use-cases/report/read.js.map +1 -0
- package/dist/programs/use-cases/report/write.d.ts +1 -0
- package/dist/programs/use-cases/report/write.js +97 -0
- package/dist/programs/use-cases/report/write.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/create-vault.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/create-vault.js +129 -0
- package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/index.d.ts +4 -0
- package/dist/programs/use-cases/vault-operations/index.js +5 -0
- package/dist/programs/use-cases/vault-operations/index.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/main.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/main.js +6 -0
- package/dist/programs/use-cases/vault-operations/main.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/read.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/read.js +58 -0
- package/dist/programs/use-cases/vault-operations/read.js.map +1 -0
- package/dist/programs/use-cases/vault-operations/write.d.ts +1 -0
- package/dist/programs/use-cases/vault-operations/write.js +220 -0
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -0
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.js +1 -17
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/wallet.d.ts +14564 -0
- package/dist/providers/wallet.js +64 -28
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/utils/arguments.test.d.ts +1 -0
- package/dist/tests/utils/arguments.test.js +92 -0
- package/dist/tests/utils/arguments.test.js.map +1 -0
- package/dist/tests/utils/calculate-overview.test.d.ts +1 -0
- package/dist/tests/utils/calculate-overview.test.js +30 -0
- package/dist/tests/utils/calculate-overview.test.js.map +1 -0
- package/dist/tests/utils/data-validators.test.d.ts +1 -0
- package/dist/tests/utils/data-validators.test.js +56 -0
- package/dist/tests/utils/data-validators.test.js.map +1 -0
- package/dist/tests/utils/error-handler.test.d.ts +1 -0
- package/dist/tests/utils/error-handler.test.js +43 -0
- package/dist/tests/utils/error-handler.test.js.map +1 -0
- package/dist/tests/utils/get-commands.test.d.ts +1 -0
- package/dist/tests/utils/get-commands.test.js +19 -0
- package/dist/tests/utils/get-commands.test.js.map +1 -0
- package/dist/tests/utils/get-deposit-data-root.test.d.ts +1 -0
- package/dist/tests/utils/get-deposit-data-root.test.js +31 -0
- package/dist/tests/utils/get-deposit-data-root.test.js.map +1 -0
- package/dist/tests/utils/get-value.test.d.ts +1 -0
- package/dist/tests/utils/get-value.test.js +13 -0
- package/dist/tests/utils/get-value.test.js.map +1 -0
- package/dist/tests/utils/health.test.d.ts +1 -0
- package/dist/tests/utils/health.test.js +22 -0
- package/dist/tests/utils/health.test.js.map +1 -0
- package/dist/tests/utils/interrupt-handler.test.d.ts +1 -0
- package/dist/tests/utils/interrupt-handler.test.js +15 -0
- package/dist/tests/utils/interrupt-handler.test.js.map +1 -0
- package/dist/tests/utils/ipfs.test.d.ts +1 -0
- package/dist/tests/utils/ipfs.test.js +110 -0
- package/dist/tests/utils/ipfs.test.js.map +1 -0
- package/dist/tests/utils/logging.test.d.ts +1 -0
- package/dist/tests/utils/logging.test.js +23 -0
- package/dist/tests/utils/logging.test.js.map +1 -0
- package/dist/tests/utils/resove-path.test.d.ts +1 -0
- package/dist/tests/utils/resove-path.test.js +18 -0
- package/dist/tests/utils/resove-path.test.js.map +1 -0
- package/dist/tests/utils/sleep.test.d.ts +1 -0
- package/dist/tests/utils/sleep.test.js +14 -0
- package/dist/tests/utils/sleep.test.js.map +1 -0
- package/dist/types/common.d.ts +35 -0
- package/dist/types/common.js +2 -0
- package/dist/types/common.js.map +1 -0
- package/dist/types/config.d.ts +26 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/arguments.d.ts +15 -0
- package/dist/utils/arguments.js +73 -0
- package/dist/utils/arguments.js.map +1 -0
- package/dist/utils/bls.d.ts +21 -0
- package/dist/utils/bls.js +101 -0
- package/dist/utils/bls.js.map +1 -0
- package/dist/utils/cache.d.ts +18 -0
- package/dist/utils/cache.js +109 -0
- package/dist/utils/cache.js.map +1 -0
- package/dist/utils/calculate-overview-v2.d.ts +25 -0
- package/dist/utils/calculate-overview-v2.js +59 -0
- package/dist/utils/calculate-overview-v2.js.map +1 -0
- package/dist/utils/calculate-overview.d.ts +28 -0
- package/dist/utils/calculate-overview.js +57 -0
- package/dist/utils/calculate-overview.js.map +1 -0
- package/dist/utils/charts/blessed/charts-apr.d.ts +98 -0
- package/dist/utils/charts/blessed/charts-apr.js +121 -0
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -0
- package/dist/utils/charts/blessed/charts-rewards.d.ts +74 -0
- package/dist/utils/charts/blessed/charts-rewards.js +106 -0
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/constants.d.ts +22 -0
- package/dist/utils/charts/blessed/constants.js +23 -0
- package/dist/utils/charts/blessed/constants.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.d.ts +19 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js +35 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/carry-spread.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/carry-spread.js +34 -0
- package/dist/utils/charts/blessed/datasets/carry-spread.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.js +34 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.d.ts +24 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js +40 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/index.d.ts +9 -0
- package/dist/utils/charts/blessed/datasets/index.js +10 -0
- package/dist/utils/charts/blessed/datasets/index.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.d.ts +19 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.js +35 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.js +34 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.js +34 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.d.ts +24 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js +40 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +37 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +147 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/types.d.ts +4 -0
- package/dist/utils/charts/blessed/datasets/types.js +2 -0
- package/dist/utils/charts/blessed/datasets/types.js.map +1 -0
- package/dist/utils/charts/blessed/index.d.ts +3 -0
- package/dist/utils/charts/blessed/index.js +4 -0
- package/dist/utils/charts/blessed/index.js.map +1 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.d.ts +13 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.js +19 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.js.map +1 -0
- package/dist/utils/charts/blessed/utils.d.ts +61 -0
- package/dist/utils/charts/blessed/utils.js +79 -0
- package/dist/utils/charts/blessed/utils.js.map +1 -0
- package/dist/utils/charts/index.d.ts +3 -0
- package/dist/utils/charts/index.js +4 -0
- package/dist/utils/charts/index.js.map +1 -0
- package/dist/utils/charts/metrics.d.ts +16 -0
- package/dist/utils/charts/metrics.js +160 -0
- package/dist/utils/charts/metrics.js.map +1 -0
- package/dist/utils/charts/overview.d.ts +10 -0
- package/dist/utils/charts/overview.js +89 -0
- package/dist/utils/charts/overview.js.map +1 -0
- package/dist/utils/charts/simple/index.d.ts +1 -0
- package/dist/utils/charts/simple/index.js +2 -0
- package/dist/utils/charts/simple/index.js.map +1 -0
- package/dist/utils/charts/simple/simple-charts.d.ts +7 -0
- package/dist/utils/charts/simple/simple-charts.js +78 -0
- package/dist/utils/charts/simple/simple-charts.js.map +1 -0
- package/dist/utils/commands/confirmations.d.ts +35 -0
- package/dist/utils/commands/confirmations.js +117 -0
- package/dist/utils/commands/confirmations.js.map +1 -0
- package/dist/utils/commands/index.d.ts +2 -0
- package/dist/utils/commands/index.js +3 -0
- package/dist/utils/commands/index.js.map +1 -0
- package/dist/utils/commands/report.d.ts +7 -0
- package/dist/utils/commands/report.js +42 -0
- package/dist/utils/commands/report.js.map +1 -0
- package/dist/utils/consts.d.ts +3 -0
- package/dist/utils/consts.js +4 -0
- package/dist/utils/consts.js.map +1 -0
- package/dist/utils/csv-file.d.ts +6 -0
- package/dist/utils/csv-file.js +48 -0
- package/dist/utils/csv-file.js.map +1 -0
- package/dist/utils/data-validators.d.ts +6 -0
- package/dist/utils/data-validators.js +54 -0
- package/dist/utils/data-validators.js.map +1 -0
- package/dist/utils/error-handler.d.ts +1 -0
- package/dist/utils/error-handler.js +13 -0
- package/dist/utils/error-handler.js.map +1 -0
- package/dist/utils/fetchCL.d.ts +36 -0
- package/dist/utils/fetchCL.js +81 -0
- package/dist/utils/fetchCL.js.map +1 -0
- package/dist/utils/get-commands.d.ts +2 -0
- package/dist/utils/get-commands.js +11 -0
- package/dist/utils/get-commands.js.map +1 -0
- package/dist/utils/get-deposit-data-root.d.ts +7 -0
- package/dist/utils/get-deposit-data-root.js +37 -0
- package/dist/utils/get-deposit-data-root.js.map +1 -0
- package/dist/utils/get-value.d.ts +1 -0
- package/dist/utils/get-value.js +5 -11
- package/dist/utils/get-value.js.map +1 -1
- package/dist/utils/health/calculate-health.d.ts +10 -0
- package/dist/utils/health/calculate-health.js +22 -0
- package/dist/utils/health/calculate-health.js.map +1 -0
- package/dist/utils/health/health-utils.d.ts +27743 -0
- package/dist/utils/health/health-utils.js +74 -0
- package/dist/utils/health/health-utils.js.map +1 -0
- package/dist/utils/health/index.d.ts +2 -0
- package/dist/utils/health/index.js +3 -0
- package/dist/utils/health/index.js.map +1 -0
- package/dist/utils/index.d.ts +35 -0
- package/dist/utils/index.js +35 -17
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/interrupt-handler.d.ts +3 -0
- package/dist/utils/interrupt-handler.js +28 -0
- package/dist/utils/interrupt-handler.js.map +1 -0
- package/dist/utils/ipfs.d.ts +17 -0
- package/dist/utils/ipfs.js +100 -0
- package/dist/utils/ipfs.js.map +1 -0
- package/dist/utils/lido-apr.d.ts +2 -0
- package/dist/utils/lido-apr.js +8 -0
- package/dist/utils/lido-apr.js.map +1 -0
- package/dist/utils/logging/console.d.ts +16 -0
- package/dist/utils/logging/console.js +44 -0
- package/dist/utils/logging/console.js.map +1 -0
- package/dist/utils/logging/constants.d.ts +4 -0
- package/dist/utils/logging/constants.js +18 -0
- package/dist/utils/logging/constants.js.map +1 -0
- package/dist/utils/logging/index.d.ts +1 -0
- package/dist/utils/logging/index.js +2 -0
- package/dist/utils/logging/index.js.map +1 -0
- package/dist/utils/prompts/confirmations.d.ts +2 -0
- package/dist/utils/prompts/confirmations.js +18 -0
- package/dist/utils/prompts/confirmations.js.map +1 -0
- package/dist/utils/prompts/default.d.ts +6 -0
- package/dist/utils/prompts/default.js +27 -0
- package/dist/utils/prompts/default.js.map +1 -0
- package/dist/utils/prompts/index.d.ts +6 -0
- package/dist/utils/prompts/index.js +7 -0
- package/dist/utils/prompts/index.js.map +1 -0
- package/dist/utils/prompts/mint-burn/confirm-burn.d.ts +17 -0
- package/dist/utils/prompts/mint-burn/confirm-burn.js +23 -0
- package/dist/utils/prompts/mint-burn/confirm-burn.js.map +1 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.d.ts +18 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.js +23 -0
- package/dist/utils/prompts/mint-burn/confirm-mint.js.map +1 -0
- package/dist/utils/prompts/mint-burn/constants.d.ts +2 -0
- package/dist/utils/prompts/mint-burn/constants.js +6 -0
- package/dist/utils/prompts/mint-burn/constants.js.map +1 -0
- package/dist/utils/prompts/mint-burn/index.d.ts +2 -0
- package/dist/utils/prompts/mint-burn/index.js +3 -0
- package/dist/utils/prompts/mint-burn/index.js.map +1 -0
- package/dist/utils/prompts/operations.d.ts +9 -0
- package/dist/utils/prompts/operations.js +52 -0
- package/dist/utils/prompts/operations.js.map +1 -0
- package/dist/utils/prompts/predeposit-guarantee.d.ts +3 -0
- package/dist/utils/prompts/predeposit-guarantee.js +23 -0
- package/dist/utils/prompts/predeposit-guarantee.js.map +1 -0
- package/dist/utils/prompts/vault.d.ts +2 -0
- package/dist/utils/prompts/vault.js +14 -0
- package/dist/utils/prompts/vault.js.map +1 -0
- package/dist/utils/proof/create-proof.d.ts +15 -0
- package/dist/utils/proof/create-proof.js +40 -0
- package/dist/utils/proof/create-proof.js.map +1 -0
- package/dist/utils/proof/first-validator-gindex.d.ts +1 -0
- package/dist/utils/proof/first-validator-gindex.js +32 -0
- package/dist/utils/proof/first-validator-gindex.js.map +1 -0
- package/dist/utils/proof/index.d.ts +3 -0
- package/dist/utils/proof/index.js +4 -0
- package/dist/utils/proof/index.js.map +1 -0
- package/dist/utils/proof/merkle-utils.d.ts +55 -0
- package/dist/utils/proof/merkle-utils.js +173 -0
- package/dist/utils/proof/merkle-utils.js.map +1 -0
- package/dist/utils/proof/proofs.d.ts +30 -0
- package/dist/utils/proof/proofs.js +52 -0
- package/dist/utils/proof/proofs.js.map +1 -0
- package/dist/utils/read-programs-by-abi.d.ts +27 -0
- package/dist/utils/read-programs-by-abi.js +92 -0
- package/dist/utils/read-programs-by-abi.js.map +1 -0
- package/dist/utils/rebase-rewards.d.ts +7 -0
- package/dist/utils/rebase-rewards.js +6 -0
- package/dist/utils/rebase-rewards.js.map +1 -0
- package/dist/utils/report/index.d.ts +4 -0
- package/dist/utils/report/index.js +5 -0
- package/dist/utils/report/index.js.map +1 -0
- package/dist/utils/report/report-proof.d.ts +39 -0
- package/dist/utils/report/report-proof.js +38 -0
- package/dist/utils/report/report-proof.js.map +1 -0
- package/dist/utils/report/report.d.ts +19 -0
- package/dist/utils/report/report.js +133 -0
- package/dist/utils/report/report.js.map +1 -0
- package/dist/utils/report/statistic-data.d.ts +32 -0
- package/dist/utils/report/statistic-data.js +28 -0
- package/dist/utils/report/statistic-data.js.map +1 -0
- package/dist/utils/report/types.d.ts +52 -0
- package/dist/utils/report/types.js +2 -0
- package/dist/utils/report/types.js.map +1 -0
- package/dist/utils/resolve-path.d.ts +1 -0
- package/dist/utils/resolve-path.js +10 -0
- package/dist/utils/resolve-path.js.map +1 -0
- package/dist/utils/share-rate.d.ts +1 -0
- package/dist/utils/share-rate.js +16 -0
- package/dist/utils/share-rate.js.map +1 -0
- package/dist/utils/sleep.d.ts +1 -0
- package/dist/utils/sleep.js +4 -0
- package/dist/utils/sleep.js.map +1 -0
- package/dist/utils/snake-to-camel.d.ts +6 -0
- package/dist/utils/snake-to-camel.js +9 -0
- package/dist/utils/snake-to-camel.js.map +1 -0
- package/dist/utils/spinner/constants.d.ts +6 -0
- package/dist/utils/spinner/constants.js +120 -0
- package/dist/utils/spinner/constants.js.map +1 -0
- package/dist/utils/spinner/index.d.ts +1 -0
- package/dist/utils/spinner/index.js +2 -0
- package/dist/utils/spinner/index.js.map +1 -0
- package/dist/utils/spinner/spinners.d.ts +7 -0
- package/dist/utils/spinner/spinners.js +16 -0
- package/dist/utils/spinner/spinners.js.map +1 -0
- package/dist/utils/statistic/index.d.ts +1 -0
- package/dist/utils/statistic/index.js +2 -0
- package/dist/utils/statistic/index.js.map +1 -0
- package/dist/utils/statistic/report-statistic.d.ts +51 -0
- package/dist/utils/statistic/report-statistic.js +125 -0
- package/dist/utils/statistic/report-statistic.js.map +1 -0
- package/dist/utils/timestamp.d.ts +1 -0
- package/dist/utils/timestamp.js +17 -0
- package/dist/utils/timestamp.js.map +1 -0
- package/dist/utils/transactions/index.d.ts +3 -0
- package/dist/utils/transactions/index.js +4 -0
- package/dist/utils/transactions/index.js.map +1 -0
- package/dist/utils/transactions/tx-private-key.d.ts +26 -0
- package/dist/utils/transactions/tx-private-key.js +310 -0
- package/dist/utils/transactions/tx-private-key.js.map +1 -0
- package/dist/utils/transactions/tx-wc.d.ts +34 -0
- package/dist/utils/transactions/tx-wc.js +174 -0
- package/dist/utils/transactions/tx-wc.js.map +1 -0
- package/dist/utils/transactions/types.d.ts +40 -0
- package/dist/utils/transactions/types.js +2 -0
- package/dist/utils/transactions/types.js.map +1 -0
- package/dist/utils/wallet-connect.d.ts +7677 -0
- package/dist/utils/wallet-connect.js +179 -0
- package/dist/utils/wallet-connect.js.map +1 -0
- package/dist/version/index.d.ts +1 -0
- package/dist/version/index.js +1 -0
- package/dist/version/index.js.map +1 -0
- package/package.json +82 -20
- package/dist/programs/vault-hub.js +0 -137
- package/dist/programs/vault-hub.js.map +0 -1
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { toHex, fromHex } from 'viem';
|
|
2
|
+
import { ProofType, createProof, } from '@chainsafe/persistent-merkle-tree';
|
|
3
|
+
import { ssz } from '@lodestar/types';
|
|
4
|
+
import { getPubkeyWCParentGIndex } from './merkle-utils.js';
|
|
5
|
+
const SupportedFork = {
|
|
6
|
+
capella: 'capella',
|
|
7
|
+
deneb: 'deneb',
|
|
8
|
+
electra: 'electra',
|
|
9
|
+
};
|
|
10
|
+
export const createPubkeyWCProof = async (validatorNode) => {
|
|
11
|
+
const pubkeyWCProof = createProof(validatorNode, {
|
|
12
|
+
type: ProofType.single,
|
|
13
|
+
gindex: getPubkeyWCParentGIndex(),
|
|
14
|
+
});
|
|
15
|
+
return { proof: pubkeyWCProof };
|
|
16
|
+
};
|
|
17
|
+
export const createStateProof = async (validatorIndex, bodyBytes, forkName) => {
|
|
18
|
+
const stateView = ssz[forkName].BeaconState.deserializeToView(new Uint8Array(bodyBytes));
|
|
19
|
+
if (validatorIndex >= stateView.validators.length)
|
|
20
|
+
throw new Error(`ValidatorIndex ${validatorIndex} out of range`);
|
|
21
|
+
const validator = stateView.validators.getReadonly(Number(validatorIndex));
|
|
22
|
+
const gIValidator = stateView.type.getPathInfo([
|
|
23
|
+
'validators',
|
|
24
|
+
Number(validatorIndex),
|
|
25
|
+
]).gindex;
|
|
26
|
+
const validatorStateProof = createProof(stateView.node, {
|
|
27
|
+
type: ProofType.single,
|
|
28
|
+
gindex: gIValidator,
|
|
29
|
+
});
|
|
30
|
+
return { proof: validatorStateProof, validator, view: stateView };
|
|
31
|
+
};
|
|
32
|
+
export const createBeaconHeaderProof = async (beaconHeader) => {
|
|
33
|
+
const beaconHeaderView = ssz['phase0'].BeaconBlockHeader.toView({
|
|
34
|
+
slot: Number(beaconHeader.slot),
|
|
35
|
+
proposerIndex: Number(beaconHeader.proposer_index),
|
|
36
|
+
parentRoot: fromHex(beaconHeader.parent_root, 'bytes'),
|
|
37
|
+
stateRoot: fromHex(beaconHeader.state_root, 'bytes'),
|
|
38
|
+
bodyRoot: fromHex(beaconHeader.body_root, 'bytes'),
|
|
39
|
+
});
|
|
40
|
+
const gIndexBeaconHeader = beaconHeaderView.type.getPathInfo([
|
|
41
|
+
'state_root',
|
|
42
|
+
]).gindex;
|
|
43
|
+
const beaconHeaderProof = createProof(beaconHeaderView.node, {
|
|
44
|
+
type: ProofType.single,
|
|
45
|
+
gindex: gIndexBeaconHeader,
|
|
46
|
+
});
|
|
47
|
+
return {
|
|
48
|
+
proof: beaconHeaderProof,
|
|
49
|
+
root: toHex(beaconHeaderView.hashTreeRoot()),
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
//# sourceMappingURL=proofs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proofs.js","sourceRoot":"","sources":["../../../utils/proof/proofs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAO,OAAO,EAAE,MAAM,MAAM,CAAC;AAC3C,OAAO,EAGL,SAAS,EACT,WAAW,GAEZ,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAEtC,OAAO,EAAE,uBAAuB,EAAE,MAAM,mBAAmB,CAAC;AAQ5D,MAAM,aAAa,GAAG;IACpB,OAAO,EAAE,SAAS;IAClB,KAAK,EAAE,OAAO;IACd,OAAO,EAAE,SAAS;CACnB,CAAC;AAUF,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EAAE,aAAmB,EAAE,EAAE;IAC/D,MAAM,aAAa,GAAU,WAAW,CAAC,aAAa,EAAE;QACtD,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,MAAM,EAAE,uBAAuB,EAAE;KAClC,CAAgB,CAAC;IAElB,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,CAAC;AAClC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,KAAK,EACnC,cAAsB,EACtB,SAAsB,EACtB,QAAoC,EAC+B,EAAE;IACrE,MAAM,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,iBAAiB,CAC3D,IAAI,UAAU,CAAC,SAAS,CAAC,CAC1B,CAAC;IAEF,IAAI,cAAc,IAAI,SAAS,CAAC,UAAU,CAAC,MAAM;QAC/C,MAAM,IAAI,KAAK,CAAC,kBAAkB,cAAc,eAAe,CAAC,CAAC;IAEnE,MAAM,SAAS,GAAG,SAAS,CAAC,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC;IAC3E,MAAM,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC;QAC7C,YAAY;QACZ,MAAM,CAAC,cAAc,CAAC;KACvB,CAAC,CAAC,MAAM,CAAC;IACV,MAAM,mBAAmB,GAAU,WAAW,CAAC,SAAS,CAAC,IAAI,EAAE;QAC7D,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,MAAM,EAAE,WAAW;KACpB,CAAgB,CAAC;IAElB,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACpE,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,KAAK,EAC1C,YAAkC,EAClC,EAAE;IACF,MAAM,gBAAgB,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,iBAAiB,CAAC,MAAM,CAAC;QAC9D,IAAI,EAAE,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC;QAC/B,aAAa,EAAE,MAAM,CAAC,YAAY,CAAC,cAAc,CAAC;QAClD,UAAU,EAAE,OAAO,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC;QACtD,SAAS,EAAE,OAAO,CAAC,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC;QACpD,QAAQ,EAAE,OAAO,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC;KACnD,CAAC,CAAC;IACH,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC;QAC3D,YAAY;KACb,CAAC,CAAC,MAAM,CAAC;IACV,MAAM,iBAAiB,GAAG,WAAW,CAAC,gBAAgB,CAAC,IAAI,EAAE;QAC3D,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,MAAM,EAAE,kBAAkB;KAC3B,CAAgB,CAAC;IAElB,OAAO;QACL,KAAK,EAAE,iBAAiB;QACxB,IAAI,EAAE,KAAK,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;KAC7C,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Command } from 'commander';
|
|
2
|
+
import { Abi } from 'viem';
|
|
3
|
+
import { ReadContract } from './index.js';
|
|
4
|
+
type ExtractFunctionNames<T extends Abi> = {
|
|
5
|
+
[K in keyof T]: T[K] extends {
|
|
6
|
+
type: 'function';
|
|
7
|
+
name: infer N;
|
|
8
|
+
} ? N extends string ? N : never : never;
|
|
9
|
+
}[number];
|
|
10
|
+
export type ReadProgramCommandConfig<T extends Abi> = {
|
|
11
|
+
[K in ExtractFunctionNames<T>]?: {
|
|
12
|
+
hidden?: boolean;
|
|
13
|
+
name?: string;
|
|
14
|
+
description?: string;
|
|
15
|
+
aliases?: string[];
|
|
16
|
+
arguments?: {
|
|
17
|
+
[argName: string]: {
|
|
18
|
+
name?: string;
|
|
19
|
+
description?: string;
|
|
20
|
+
modifier?: (value: string) => any;
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
export declare function generateReadCommands<T, U extends Abi>(abi: U, createContract: (address: T) => ReadContract, command: Command, commandConfig: ReadProgramCommandConfig<U>): Command;
|
|
26
|
+
export declare function generateReadCommands<U extends Abi>(abi: Abi, createContractAsync: () => Promise<ReadContract>, command: Command, commandConfig: ReadProgramCommandConfig<U>): Command;
|
|
27
|
+
export {};
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { callReadMethod, stringToAddress } from './index.js';
|
|
2
|
+
/**
|
|
3
|
+
* Generates a CLI command based on the provided ABI.
|
|
4
|
+
* Only functions with stateMutability === 'view' or 'pure' are taken.
|
|
5
|
+
* Allows adding custom descriptions.
|
|
6
|
+
*/
|
|
7
|
+
// eslint-disable-next-line func-style
|
|
8
|
+
export function generateReadCommands(abi, createContractOrContract, command, commandConfig) {
|
|
9
|
+
// Filter only view/pure functions with proper typing
|
|
10
|
+
const readOnlyFunctions = abi.filter((entry) => entry.type === 'function' &&
|
|
11
|
+
(entry.stateMutability === 'view' || entry.stateMutability === 'pure') &&
|
|
12
|
+
'name' in entry &&
|
|
13
|
+
entry.name !== undefined);
|
|
14
|
+
// Check if the contract is already created
|
|
15
|
+
const isNeedsAddress = createContractOrContract.length === 1;
|
|
16
|
+
const methods = [];
|
|
17
|
+
// Generate subcommands
|
|
18
|
+
readOnlyFunctions.forEach((fn) => {
|
|
19
|
+
const fnName = fn.name;
|
|
20
|
+
const inputs = fn.inputs || [];
|
|
21
|
+
// Search for a custom description for this function
|
|
22
|
+
const configForFn = commandConfig[fnName];
|
|
23
|
+
if (configForFn?.hidden)
|
|
24
|
+
return;
|
|
25
|
+
// Custom command name if specified
|
|
26
|
+
const commandName = methods.includes(fnName)
|
|
27
|
+
? `${fnName}${inputs[0]?.name || '0'}`
|
|
28
|
+
: configForFn?.name || fnName;
|
|
29
|
+
// Command description
|
|
30
|
+
const commandDescription = configForFn?.description ||
|
|
31
|
+
`Calls the read-only function "${fnName}" on the contract.`;
|
|
32
|
+
const aliases = configForFn?.aliases || [];
|
|
33
|
+
// Create a subcommand by function name
|
|
34
|
+
const fnCommand = command
|
|
35
|
+
.command(commandName)
|
|
36
|
+
.aliases(aliases)
|
|
37
|
+
.description(commandDescription);
|
|
38
|
+
methods.push(fnName);
|
|
39
|
+
// If the contract needs an address, add the <address> argument
|
|
40
|
+
if (isNeedsAddress) {
|
|
41
|
+
fnCommand.argument('<address>', 'Contract address', stringToAddress);
|
|
42
|
+
}
|
|
43
|
+
// Add arguments for each function parameter
|
|
44
|
+
inputs.forEach((input, index) => {
|
|
45
|
+
const abiArgName = input.name || `param${index}`;
|
|
46
|
+
// Check if there is a custom description for this argument
|
|
47
|
+
const configArg = configForFn?.arguments?.[abiArgName];
|
|
48
|
+
// If a custom name is specified, use it as the name
|
|
49
|
+
const cliArgName = configArg?.name || abiArgName;
|
|
50
|
+
// If a custom description is specified, use it, otherwise use the default
|
|
51
|
+
const cliArgDesc = configArg?.description || `Parameter of type ${input.type}`;
|
|
52
|
+
const parseFn = typeof configArg?.modifier === 'function'
|
|
53
|
+
? configArg.modifier
|
|
54
|
+
: undefined;
|
|
55
|
+
// Create an argument using the custom name and description
|
|
56
|
+
if (parseFn)
|
|
57
|
+
fnCommand.argument(`<${cliArgName}>`, cliArgDesc, parseFn);
|
|
58
|
+
else
|
|
59
|
+
fnCommand.argument(`<${cliArgName}>`, cliArgDesc);
|
|
60
|
+
});
|
|
61
|
+
fnCommand.action(async (...cliArgs) => {
|
|
62
|
+
try {
|
|
63
|
+
let contract;
|
|
64
|
+
let fnArgs;
|
|
65
|
+
if (isNeedsAddress) {
|
|
66
|
+
// The first argument is the contract address
|
|
67
|
+
const address = cliArgs[0];
|
|
68
|
+
// The rest are the function arguments
|
|
69
|
+
fnArgs = cliArgs.slice(1);
|
|
70
|
+
// Create the contract
|
|
71
|
+
contract = createContractOrContract(address);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
// Create the contract async
|
|
75
|
+
contract = await createContractOrContract();
|
|
76
|
+
fnArgs = cliArgs; // all the passed arguments are the function arguments
|
|
77
|
+
}
|
|
78
|
+
fnArgs = inputs.length > 0 ? fnArgs.slice(0, inputs.length) : undefined;
|
|
79
|
+
if (fnArgs)
|
|
80
|
+
await callReadMethod(contract, fnName, fnArgs);
|
|
81
|
+
else
|
|
82
|
+
await callReadMethod(contract, fnName);
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
console.error(`Error calling function ${fnName}:`, error);
|
|
86
|
+
process.exit(1);
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
});
|
|
90
|
+
return command;
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=read-programs-by-abi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"read-programs-by-abi.js","sourceRoot":"","sources":["../../utils/read-programs-by-abi.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export const calculateRebaseReward = (args) => {
|
|
2
|
+
const { shareRatePrev, shareRateCurr, sharesPrev, sharesCurr } = args;
|
|
3
|
+
const reward = (shareRateCurr * sharesCurr - shareRatePrev * sharesPrev) / 10n ** 27n;
|
|
4
|
+
return reward;
|
|
5
|
+
};
|
|
6
|
+
//# sourceMappingURL=rebase-rewards.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rebase-rewards.js","sourceRoot":"","sources":["../../utils/rebase-rewards.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,MAAM,qBAAqB,GAAG,CACnC,IAA+B,EACvB,EAAE;IACV,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC;IAEtE,MAAM,MAAM,GACV,CAAC,aAAa,GAAG,UAAU,GAAG,aAAa,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,GAAG,CAAC;IAEzE,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../utils/report/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC;AACpC,cAAc,YAAY,CAAC;AAC3B,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Address, Hex } from 'viem';
|
|
2
|
+
import { VaultReportArgs } from './types.js';
|
|
3
|
+
export declare const getReportProofByVault: (args: VaultReportArgs, cache?: boolean) => Promise<{
|
|
4
|
+
proof: Hex[];
|
|
5
|
+
data: import("../index.js").LeafDataFields;
|
|
6
|
+
extraData: import("../index.js").ExtraDataFields;
|
|
7
|
+
leaf: string;
|
|
8
|
+
refSlot: number;
|
|
9
|
+
blockNumber: number;
|
|
10
|
+
timestamp: number;
|
|
11
|
+
prevTreeCID: string;
|
|
12
|
+
cid: string;
|
|
13
|
+
}>;
|
|
14
|
+
type GetReportProofByVaultsArgs = Omit<VaultReportArgs, 'vault'> & {
|
|
15
|
+
vaults: Address[];
|
|
16
|
+
};
|
|
17
|
+
export declare const getReportProofByVaults: (args: GetReportProofByVaultsArgs, cache?: boolean) => Promise<{
|
|
18
|
+
proof: Hex[];
|
|
19
|
+
data: import("../index.js").LeafDataFields;
|
|
20
|
+
extraData: import("../index.js").ExtraDataFields;
|
|
21
|
+
leaf: string;
|
|
22
|
+
refSlot: number;
|
|
23
|
+
blockNumber: number;
|
|
24
|
+
timestamp: number;
|
|
25
|
+
prevTreeCID: string;
|
|
26
|
+
cid: string;
|
|
27
|
+
}[]>;
|
|
28
|
+
export declare const getReportProofs: (args: Omit<VaultReportArgs, "vault">, cache?: boolean) => Promise<{
|
|
29
|
+
proof: Hex[];
|
|
30
|
+
data: import("../index.js").LeafDataFields;
|
|
31
|
+
extraData: import("../index.js").ExtraDataFields;
|
|
32
|
+
leaf: string;
|
|
33
|
+
refSlot: number;
|
|
34
|
+
blockNumber: number;
|
|
35
|
+
timestamp: number;
|
|
36
|
+
prevTreeCID: string;
|
|
37
|
+
cid: string;
|
|
38
|
+
}[]>;
|
|
39
|
+
export {};
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { StandardMerkleTree } from '@openzeppelin/merkle-tree';
|
|
2
|
+
import { fetchIPFS } from '../index.js';
|
|
3
|
+
import { getVaultData } from './report.js';
|
|
4
|
+
export const getReportProofByVault = async (args, cache = true) => {
|
|
5
|
+
const { vault } = args;
|
|
6
|
+
const IPFSReportData = await fetchIPFS(args, cache);
|
|
7
|
+
const merkleTree = StandardMerkleTree.load({
|
|
8
|
+
...IPFSReportData,
|
|
9
|
+
values: IPFSReportData.values.map(({ treeIndex, value }) => {
|
|
10
|
+
return {
|
|
11
|
+
value,
|
|
12
|
+
treeIndex: Number(treeIndex),
|
|
13
|
+
};
|
|
14
|
+
}),
|
|
15
|
+
});
|
|
16
|
+
const vaultIndex = IPFSReportData.values.findIndex(({ value }) => value[0].toLowerCase() === vault.toLowerCase());
|
|
17
|
+
if (vaultIndex < 0) {
|
|
18
|
+
throw new Error(`Vault ${vault} not found in report`);
|
|
19
|
+
}
|
|
20
|
+
const reportData = getVaultData(IPFSReportData, vault, args.cid);
|
|
21
|
+
return {
|
|
22
|
+
...reportData,
|
|
23
|
+
proof: merkleTree.getProof(vaultIndex),
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
export const getReportProofByVaults = async (args, cache = true) => {
|
|
27
|
+
const { vaults } = args;
|
|
28
|
+
const proofs = await Promise.all(vaults.map((vault) => getReportProofByVault({ ...args, vault }, cache)));
|
|
29
|
+
return proofs;
|
|
30
|
+
};
|
|
31
|
+
export const getReportProofs = async (args, cache = true) => {
|
|
32
|
+
const report = await fetchIPFS(args, cache);
|
|
33
|
+
const vaultReports = report.values.map((value) => getVaultData(report, value.value[0], args.cid).data);
|
|
34
|
+
const vaults = vaultReports.map((vault) => vault.vaultAddress);
|
|
35
|
+
const proofs = await Promise.all(vaults.map((vault) => getReportProofByVault({ ...args, vault: vault }, cache)));
|
|
36
|
+
return proofs;
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=report-proof.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report-proof.js","sourceRoot":"","sources":["../../../utils/report/report-proof.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAE/D,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,EACxC,IAAqB,EACrB,KAAK,GAAG,IAAI,EACZ,EAAE;IACF,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC;IAEvB,MAAM,cAAc,GAAG,MAAM,SAAS,CAAS,IAAI,EAAE,KAAK,CAAC,CAAC;IAE5D,MAAM,UAAU,GAAG,kBAAkB,CAAC,IAAI,CAAC;QACzC,GAAG,cAAc;QACjB,MAAM,EAAE,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE;YACzD,OAAO;gBACL,KAAK;gBACL,SAAS,EAAE,MAAM,CAAC,SAAS,CAAC;aAC7B,CAAC;QACJ,CAAC,CAAC;KACH,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,cAAc,CAAC,MAAM,CAAC,SAAS,CAChD,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,WAAW,EAAE,CAC9D,CAAC;IAEF,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,SAAS,KAAK,sBAAsB,CAAC,CAAC;IACxD,CAAC;IACD,MAAM,UAAU,GAAG,YAAY,CAAC,cAAc,EAAE,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;IAEjE,OAAO;QACL,GAAG,UAAU;QACb,KAAK,EAAE,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAU;KAChD,CAAC;AACJ,CAAC,CAAC;AAMF,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EACzC,IAAgC,EAChC,KAAK,GAAG,IAAI,EACZ,EAAE;IACF,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IAExB,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAC9B,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,qBAAqB,CAAC,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,EAAE,KAAK,CAAC,CAAC,CACxE,CAAC;IAEF,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,KAAK,EAClC,IAAoC,EACpC,KAAK,GAAG,IAAI,EACZ,EAAE;IACF,MAAM,MAAM,GAAG,MAAM,SAAS,CAAS,IAAI,EAAE,KAAK,CAAC,CAAC;IACpD,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CACpC,CAAC,KAAK,EAAE,EAAE,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAC/D,CAAC;IACF,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IAE/D,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,GAAG,CAC9B,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACnB,qBAAqB,CAAC,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,KAAgB,EAAE,EAAE,KAAK,CAAC,CACnE,CACF,CAAC;IAEF,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
import type { VaultReport, VaultReportArgs, Report, LeafDataFields } from './types.js';
|
|
3
|
+
export declare const getVaultReport: (args: VaultReportArgs, cache?: boolean) => Promise<VaultReport>;
|
|
4
|
+
export declare const getVaultPreviousReport: (args: VaultReportArgs, cache?: boolean) => Promise<VaultReport>;
|
|
5
|
+
export declare const getVaultData: (report: Report, vault: Address, cid: string) => VaultReport;
|
|
6
|
+
export declare const getAllVaultsReports: (args: Omit<VaultReportArgs, "vault">, cache?: boolean) => Promise<{
|
|
7
|
+
vaultReports: LeafDataFields[];
|
|
8
|
+
prevTreeCID: string;
|
|
9
|
+
}>;
|
|
10
|
+
/**
|
|
11
|
+
* Retrieves a chain of historical VaultReport entries using prevTreeCID, starting from the specified CID.
|
|
12
|
+
* @param args { vault, cid, gateway, bigNumberType, limit, direction }
|
|
13
|
+
* @returns Promise<VaultReport[]> — array from newest to oldest (default) or oldest to newest (if direction === 'asc')
|
|
14
|
+
*/
|
|
15
|
+
export declare const getVaultReportHistory: (args: VaultReportArgs & {
|
|
16
|
+
limit?: number;
|
|
17
|
+
direction?: "asc" | "desc";
|
|
18
|
+
minTimestamp?: number;
|
|
19
|
+
}, cache?: boolean) => Promise<VaultReport[]>;
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { fetchIPFS, IPFS_GATEWAY, logInfo, snakeToCamel } from '../index.js';
|
|
2
|
+
export const getVaultReport = async (args, cache = true) => {
|
|
3
|
+
const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
4
|
+
const report = await fetchIPFS({
|
|
5
|
+
cid,
|
|
6
|
+
gateway,
|
|
7
|
+
bigNumberType,
|
|
8
|
+
}, cache);
|
|
9
|
+
const vaultData = getVaultData(report, vault, cid);
|
|
10
|
+
return vaultData;
|
|
11
|
+
};
|
|
12
|
+
export const getVaultPreviousReport = async (args, cache = true) => {
|
|
13
|
+
const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
14
|
+
const report = await fetchIPFS({
|
|
15
|
+
cid,
|
|
16
|
+
gateway,
|
|
17
|
+
bigNumberType,
|
|
18
|
+
}, cache);
|
|
19
|
+
const previousReportCID = report.prevTreeCID;
|
|
20
|
+
const previousReport = await fetchIPFS({
|
|
21
|
+
cid: previousReportCID,
|
|
22
|
+
gateway,
|
|
23
|
+
bigNumberType,
|
|
24
|
+
});
|
|
25
|
+
const vaultData = getVaultData(previousReport, vault, cid);
|
|
26
|
+
return vaultData;
|
|
27
|
+
};
|
|
28
|
+
export const getVaultData = (report, vault, cid) => {
|
|
29
|
+
const match = report.values.find((entry) => entry.value[0]?.toLowerCase() === vault.toLowerCase());
|
|
30
|
+
if (!match)
|
|
31
|
+
throw new Error('Vault not found');
|
|
32
|
+
const leaf = report.tree[Number(match.treeIndex)];
|
|
33
|
+
if (!leaf)
|
|
34
|
+
throw new Error('Leaf not found');
|
|
35
|
+
const data = {
|
|
36
|
+
vaultAddress: '',
|
|
37
|
+
fee: '',
|
|
38
|
+
totalValueWei: '',
|
|
39
|
+
liabilityShares: '',
|
|
40
|
+
slashingReserve: '',
|
|
41
|
+
};
|
|
42
|
+
// TODO: for old reports without extraValues
|
|
43
|
+
const extraData = report.extraValues?.[vault] || {
|
|
44
|
+
inOutDelta: '0',
|
|
45
|
+
prevFee: '0',
|
|
46
|
+
infraFee: '0',
|
|
47
|
+
liquidityFee: '0',
|
|
48
|
+
reservationFee: '0',
|
|
49
|
+
};
|
|
50
|
+
for (const [_key, _index] of Object.entries(report.leafIndexToData)) {
|
|
51
|
+
let index;
|
|
52
|
+
let fieldName;
|
|
53
|
+
// new report format
|
|
54
|
+
// leafIndexToData: { "vaultAddress": 0, ...
|
|
55
|
+
if (typeof _index === 'number') {
|
|
56
|
+
index = _index;
|
|
57
|
+
fieldName = _key;
|
|
58
|
+
}
|
|
59
|
+
// TODO: remove soon
|
|
60
|
+
// old report format
|
|
61
|
+
// leafIndexToData: { "0": "vaultAddress", ...
|
|
62
|
+
else {
|
|
63
|
+
index = Number(_key);
|
|
64
|
+
fieldName = _index;
|
|
65
|
+
}
|
|
66
|
+
const valueByIndex = match.value[index];
|
|
67
|
+
if (valueByIndex === undefined) {
|
|
68
|
+
throw new Error(`Missing value at index ${index} for field "${fieldName}"`);
|
|
69
|
+
}
|
|
70
|
+
const camelCaseFieldName = snakeToCamel(fieldName);
|
|
71
|
+
data[camelCaseFieldName] = valueByIndex.toString();
|
|
72
|
+
}
|
|
73
|
+
return {
|
|
74
|
+
data,
|
|
75
|
+
extraData,
|
|
76
|
+
leaf,
|
|
77
|
+
refSlot: report.refSlot,
|
|
78
|
+
blockNumber: Number(report.blockNumber),
|
|
79
|
+
timestamp: report.timestamp,
|
|
80
|
+
prevTreeCID: report.prevTreeCID,
|
|
81
|
+
cid,
|
|
82
|
+
};
|
|
83
|
+
};
|
|
84
|
+
export const getAllVaultsReports = async (args, cache = true) => {
|
|
85
|
+
const { cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
86
|
+
const report = await fetchIPFS({
|
|
87
|
+
cid,
|
|
88
|
+
gateway,
|
|
89
|
+
bigNumberType,
|
|
90
|
+
}, cache);
|
|
91
|
+
const vaultReports = report.values.map((value) => getVaultData(report, value.value[0], cid).data);
|
|
92
|
+
return {
|
|
93
|
+
vaultReports,
|
|
94
|
+
prevTreeCID: report.prevTreeCID,
|
|
95
|
+
};
|
|
96
|
+
};
|
|
97
|
+
/**
|
|
98
|
+
* Retrieves a chain of historical VaultReport entries using prevTreeCID, starting from the specified CID.
|
|
99
|
+
* @param args { vault, cid, gateway, bigNumberType, limit, direction }
|
|
100
|
+
* @returns Promise<VaultReport[]> — array from newest to oldest (default) or oldest to newest (if direction === 'asc')
|
|
101
|
+
*/
|
|
102
|
+
export const getVaultReportHistory = async (args, cache = true) => {
|
|
103
|
+
const { vault, gateway = IPFS_GATEWAY, bigNumberType = 'string', direction = 'desc', minTimestamp, } = args;
|
|
104
|
+
let cid = args.cid;
|
|
105
|
+
const limit = args.limit ?? 20;
|
|
106
|
+
const history = [];
|
|
107
|
+
for (let i = 0; i < limit; i++) {
|
|
108
|
+
try {
|
|
109
|
+
const report = await getVaultReport({
|
|
110
|
+
vault,
|
|
111
|
+
cid,
|
|
112
|
+
gateway,
|
|
113
|
+
bigNumberType,
|
|
114
|
+
}, cache);
|
|
115
|
+
if (minTimestamp && report.timestamp < minTimestamp) {
|
|
116
|
+
break;
|
|
117
|
+
}
|
|
118
|
+
history.push(report);
|
|
119
|
+
if (!report.prevTreeCID || report.prevTreeCID === cid)
|
|
120
|
+
break;
|
|
121
|
+
cid = report.prevTreeCID;
|
|
122
|
+
}
|
|
123
|
+
catch (e) {
|
|
124
|
+
break;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
logInfo('Report hostory cached', history.length);
|
|
128
|
+
if (direction === 'asc') {
|
|
129
|
+
return history.reverse();
|
|
130
|
+
}
|
|
131
|
+
return history;
|
|
132
|
+
};
|
|
133
|
+
//# sourceMappingURL=report.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report.js","sourceRoot":"","sources":["../../../utils/report/report.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
import type { VaultReport } from './types.js';
|
|
3
|
+
type StatisticDataArgs = {
|
|
4
|
+
dashboard: Address;
|
|
5
|
+
reports: {
|
|
6
|
+
current: VaultReport;
|
|
7
|
+
previous: VaultReport;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
export declare const getReportStatisticData: (args: StatisticDataArgs) => Promise<{
|
|
11
|
+
grossStakingRewards: bigint;
|
|
12
|
+
nodeOperatorRewards: bigint;
|
|
13
|
+
dailyLidoFees: bigint;
|
|
14
|
+
netStakingRewards: bigint;
|
|
15
|
+
grossStakingAPR: {
|
|
16
|
+
apr: bigint;
|
|
17
|
+
apr_bps: number;
|
|
18
|
+
apr_percent: number;
|
|
19
|
+
};
|
|
20
|
+
netStakingAPR: {
|
|
21
|
+
apr: bigint;
|
|
22
|
+
apr_bps: number;
|
|
23
|
+
apr_percent: number;
|
|
24
|
+
};
|
|
25
|
+
bottomLine: bigint;
|
|
26
|
+
carrySpread: {
|
|
27
|
+
apr: bigint;
|
|
28
|
+
apr_bps: number;
|
|
29
|
+
apr_percent: number;
|
|
30
|
+
};
|
|
31
|
+
}>;
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { getDashboardContract } from '../../contracts/index.js';
|
|
2
|
+
import { calculateRebaseReward, callReadMethodSilent, calculateShareRate, reportMetrics, } from '../index.js';
|
|
3
|
+
export const getReportStatisticData = async (args) => {
|
|
4
|
+
const { dashboard, reports } = args;
|
|
5
|
+
const dashboardContract = getDashboardContract(dashboard);
|
|
6
|
+
const reportRefBlockNumber = reports.current.blockNumber;
|
|
7
|
+
const reportPrevBlockNumber = reports.previous.blockNumber;
|
|
8
|
+
const nodeOperatorFeeRate = await callReadMethodSilent(dashboardContract, 'nodeOperatorFeeRate', {
|
|
9
|
+
blockNumber: BigInt(reportRefBlockNumber),
|
|
10
|
+
});
|
|
11
|
+
const [shareRatePrev, shareRateCurr] = await Promise.all([
|
|
12
|
+
calculateShareRate(reportPrevBlockNumber),
|
|
13
|
+
calculateShareRate(reportRefBlockNumber),
|
|
14
|
+
]);
|
|
15
|
+
const stEthLiabilityRebaseRewards = calculateRebaseReward({
|
|
16
|
+
shareRatePrev,
|
|
17
|
+
shareRateCurr,
|
|
18
|
+
sharesPrev: BigInt(reports.previous.data.liabilityShares),
|
|
19
|
+
sharesCurr: BigInt(reports.current.data.liabilityShares),
|
|
20
|
+
});
|
|
21
|
+
const metrics = reportMetrics({
|
|
22
|
+
reports: { current: reports.current, previous: reports.previous },
|
|
23
|
+
nodeOperatorFeeRate,
|
|
24
|
+
stEthLiabilityRebaseRewards,
|
|
25
|
+
});
|
|
26
|
+
return metrics;
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=statistic-data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"statistic-data.js","sourceRoot":"","sources":["../../../utils/report/statistic-data.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,EAClB,aAAa,GACd,MAAM,OAAO,CAAC;AASf,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EAAE,IAAuB,EAAE,EAAE;IACtE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACpC,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAC1D,MAAM,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC;IACzD,MAAM,qBAAqB,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;IAE3D,MAAM,mBAAmB,GAAG,MAAM,oBAAoB,CACpD,iBAAiB,EACjB,qBAAqB,EACrB;QACE,WAAW,EAAE,MAAM,CAAC,oBAAoB,CAAC;KAC1C,CACF,CAAC;IACF,MAAM,CAAC,aAAa,EAAE,aAAa,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACvD,kBAAkB,CAAC,qBAAqB,CAAC;QACzC,kBAAkB,CAAC,oBAAoB,CAAC;KACzC,CAAC,CAAC;IAEH,MAAM,2BAA2B,GAAG,qBAAqB,CAAC;QACxD,aAAa;QACb,aAAa;QACb,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC;QACzD,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC;KACzD,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,aAAa,CAAC;QAC5B,OAAO,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE;QACjE,mBAAmB;QACnB,2BAA2B;KAC5B,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { Address, Hex } from 'viem';
|
|
2
|
+
type BigNumberType = 'bigint' | 'string';
|
|
3
|
+
export type LeafDataFields = {
|
|
4
|
+
vaultAddress: string;
|
|
5
|
+
totalValueWei: string;
|
|
6
|
+
fee: string;
|
|
7
|
+
liabilityShares: string;
|
|
8
|
+
slashingReserve: string;
|
|
9
|
+
};
|
|
10
|
+
export type ExtraDataFields = {
|
|
11
|
+
inOutDelta: string;
|
|
12
|
+
prevFee: string;
|
|
13
|
+
infraFee: string;
|
|
14
|
+
liquidityFee: string;
|
|
15
|
+
reservationFee: string;
|
|
16
|
+
};
|
|
17
|
+
export type Report = {
|
|
18
|
+
format: 'standard-v1';
|
|
19
|
+
leafEncoding: ['address', 'uint256', 'uint256', 'uint256', 'uint256'];
|
|
20
|
+
tree: Hex[];
|
|
21
|
+
values: {
|
|
22
|
+
treeIndex: bigint;
|
|
23
|
+
value: [Address, string, string, string, string];
|
|
24
|
+
}[];
|
|
25
|
+
refSlot: number;
|
|
26
|
+
timestamp: number;
|
|
27
|
+
blockNumber: bigint;
|
|
28
|
+
prevTreeCID: string;
|
|
29
|
+
leafIndexToData: {
|
|
30
|
+
[key: string]: keyof LeafDataFields | number;
|
|
31
|
+
};
|
|
32
|
+
extraValues: {
|
|
33
|
+
[key: string]: ExtraDataFields;
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
export type VaultReport = {
|
|
37
|
+
data: LeafDataFields;
|
|
38
|
+
extraData: ExtraDataFields;
|
|
39
|
+
leaf: string;
|
|
40
|
+
refSlot: number;
|
|
41
|
+
blockNumber: number;
|
|
42
|
+
timestamp: number;
|
|
43
|
+
prevTreeCID: string;
|
|
44
|
+
cid: string;
|
|
45
|
+
};
|
|
46
|
+
export type VaultReportArgs = {
|
|
47
|
+
vault: Address;
|
|
48
|
+
cid: string;
|
|
49
|
+
gateway?: string;
|
|
50
|
+
bigNumberType?: BigNumberType;
|
|
51
|
+
};
|
|
52
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../utils/report/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const resolvePath: (pathString: string) => string;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import path from 'path';
|
|
2
|
+
import { homedir } from 'os';
|
|
3
|
+
export const resolvePath = (pathString) => {
|
|
4
|
+
return pathString.startsWith('~')
|
|
5
|
+
? path.join(homedir(), pathString.slice(1))
|
|
6
|
+
: path.isAbsolute(pathString)
|
|
7
|
+
? pathString
|
|
8
|
+
: path.resolve(pathString);
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=resolve-path.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-path.js","sourceRoot":"","sources":["../../utils/resolve-path.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,OAAO,EAAE,MAAM,IAAI,CAAC;AAE7B,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,UAAkB,EAAE,EAAE;IAChD,OAAO,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC;QAC/B,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAC3C,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;YAC3B,CAAC,CAAC,UAAU;YACZ,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;AACjC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const calculateShareRate: (blockNumber: number) => Promise<bigint>;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { getStethContract } from '../contracts/index.js';
|
|
2
|
+
import { callReadMethodSilent } from './index.js';
|
|
3
|
+
export const calculateShareRate = async (blockNumber) => {
|
|
4
|
+
const stEthContract = await getStethContract();
|
|
5
|
+
const [totalSupply, getTotalShares] = await Promise.all([
|
|
6
|
+
callReadMethodSilent(stEthContract, 'totalSupply', {
|
|
7
|
+
blockNumber: BigInt(blockNumber),
|
|
8
|
+
}),
|
|
9
|
+
callReadMethodSilent(stEthContract, 'getTotalShares', {
|
|
10
|
+
blockNumber: BigInt(blockNumber),
|
|
11
|
+
}),
|
|
12
|
+
]);
|
|
13
|
+
const shareRate = getTotalShares !== 0n ? (totalSupply * 10n ** 27n) / getTotalShares : 0n;
|
|
14
|
+
return shareRate;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=share-rate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"share-rate.js","sourceRoot":"","sources":["../../utils/share-rate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAE7C,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EACrC,WAAmB,EACF,EAAE;IACnB,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;IAE/C,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACtD,oBAAoB,CAAC,aAAa,EAAE,aAAa,EAAE;YACjD,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;SACjC,CAAC;QACF,oBAAoB,CAAC,aAAa,EAAE,gBAAgB,EAAE;YACpD,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;SACjC,CAAC;KACH,CAAC,CAAC;IACH,MAAM,SAAS,GACb,cAAc,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;IAE3E,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const sleep: (ms: number) => Promise<unknown>;
|