@lidofinance/lsv-cli 1.0.0-alpha.5 → 1.0.0-alpha.51
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 +41 -20
- package/dist/abi/BlsHarness.d.ts +178 -0
- package/dist/abi/BlsHarness.js +232 -0
- package/dist/abi/BlsHarness.js.map +1 -0
- package/dist/abi/CLProofVerifier.d.ts +188 -0
- package/dist/abi/CLProofVerifier.js +247 -0
- package/dist/abi/CLProofVerifier.js.map +1 -0
- package/dist/abi/Dashboard.d.ts +1866 -0
- package/dist/abi/Dashboard.js +1924 -0
- package/dist/abi/Dashboard.js.map +1 -0
- package/dist/abi/LidoLocator.d.ts +330 -0
- package/dist/abi/LidoLocator.js +426 -0
- package/dist/abi/LidoLocator.js.map +1 -0
- package/dist/abi/OperatorGrid.d.ts +1075 -0
- package/dist/abi/OperatorGrid.js +1188 -0
- package/dist/abi/OperatorGrid.js.map +1 -0
- package/dist/abi/PredepositGuarantee.d.ts +1382 -0
- package/dist/abi/PredepositGuarantee.js +1789 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -0
- package/dist/abi/ReportChecker.d.ts +83 -0
- package/dist/abi/ReportChecker.js +109 -0
- package/dist/abi/ReportChecker.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 +1085 -0
- package/dist/abi/StakingVault.js +1115 -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 +664 -0
- package/dist/abi/VaultFactory.js +213 -0
- package/dist/abi/VaultFactory.js.map +1 -0
- package/dist/abi/VaultHub.d.ts +1882 -0
- package/dist/abi/VaultHub.js +1259 -435
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +223 -0
- package/dist/abi/VaultViewer.js +297 -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 +15 -0
- package/dist/abi/index.js +17 -0
- package/dist/abi/index.js.map +1 -0
- package/dist/command/index.d.ts +2 -0
- package/dist/command/index.js +7 -5
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +34 -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/blsHarness.d.ts +947 -0
- package/dist/contracts/blsHarness.js +24 -0
- package/dist/contracts/blsHarness.js.map +1 -0
- package/dist/contracts/clProofVerifier.d.ts +2647 -0
- package/dist/contracts/clProofVerifier.js +23 -0
- package/dist/contracts/clProofVerifier.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 +15 -0
- package/dist/contracts/index.js +15 -17
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/locator.d.ts +6935 -0
- package/dist/contracts/locator.js +16 -0
- package/dist/contracts/locator.js.map +1 -0
- package/dist/contracts/operator-grid.d.ts +3 -0
- package/dist/contracts/operator-grid.js +17 -0
- package/dist/contracts/operator-grid.js.map +1 -0
- package/dist/contracts/pdg.d.ts +3 -0
- package/dist/contracts/pdg.js +17 -0
- package/dist/contracts/pdg.js.map +1 -0
- package/dist/contracts/reportChecker.d.ts +758 -0
- package/dist/contracts/reportChecker.js +23 -0
- package/dist/contracts/reportChecker.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 +10742 -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 +2681 -0
- package/dist/contracts/vault-viewer.js +23 -0
- package/dist/contracts/vault-viewer.js.map +1 -0
- package/dist/contracts/vault.d.ts +3 -0
- package/dist/contracts/vault.js +11 -0
- package/dist/contracts/vault.js.map +1 -0
- package/dist/contracts/voting.d.ts +6 -0
- package/dist/contracts/voting.js +19 -0
- package/dist/contracts/voting.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 +259 -0
- package/dist/features/dashboard.js.map +1 -0
- package/dist/features/index.d.ts +6 -0
- package/dist/features/index.js +7 -0
- package/dist/features/index.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 +116 -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/vault-factory.d.ts +13 -0
- package/dist/features/vault-factory.js +63 -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.d.ts +2 -0
- package/dist/features/vault.js +56 -0
- package/dist/features/vault.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +8 -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 +109 -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 +65 -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/dashboard/config.d.ts +2 -0
- package/dist/programs/dashboard/config.js +111 -0
- package/dist/programs/dashboard/config.js.map +1 -0
- package/dist/programs/dashboard/index.d.ts +3 -0
- package/dist/programs/dashboard/index.js +4 -0
- package/dist/programs/dashboard/index.js.map +1 -0
- package/dist/programs/dashboard/main.d.ts +1 -0
- package/dist/programs/dashboard/main.js +5 -0
- package/dist/programs/dashboard/main.js.map +1 -0
- package/dist/programs/dashboard/read.d.ts +1 -0
- package/dist/programs/dashboard/read.js +97 -0
- package/dist/programs/dashboard/read.js.map +1 -0
- package/dist/programs/dashboard/write.d.ts +1 -0
- package/dist/programs/dashboard/write.js +625 -0
- package/dist/programs/dashboard/write.js.map +1 -0
- package/dist/programs/hub/config.d.ts +2 -0
- package/dist/programs/hub/config.js +123 -0
- package/dist/programs/hub/config.js.map +1 -0
- package/dist/programs/hub/index.d.ts +3 -0
- package/dist/programs/hub/index.js +4 -0
- package/dist/programs/hub/index.js.map +1 -0
- package/dist/programs/hub/main.d.ts +1 -0
- package/dist/programs/hub/main.js +5 -0
- package/dist/programs/hub/main.js.map +1 -0
- package/dist/programs/hub/read.d.ts +1 -0
- package/dist/programs/hub/read.js +59 -0
- package/dist/programs/hub/read.js.map +1 -0
- package/dist/programs/hub/write.d.ts +1 -0
- package/dist/programs/hub/write.js +246 -0
- package/dist/programs/hub/write.js.map +1 -0
- package/dist/programs/index.d.ts +11 -0
- package/dist/programs/index.js +11 -17
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/metrics/index.d.ts +2 -0
- package/dist/programs/metrics/index.js +3 -0
- package/dist/programs/metrics/index.js.map +1 -0
- package/dist/programs/metrics/main.d.ts +1 -0
- package/dist/programs/metrics/main.js +3 -0
- package/dist/programs/metrics/main.js.map +1 -0
- package/dist/programs/metrics/read.d.ts +1 -0
- package/dist/programs/metrics/read.js +110 -0
- package/dist/programs/metrics/read.js.map +1 -0
- package/dist/programs/operator-grid/config.d.ts +2 -0
- package/dist/programs/operator-grid/config.js +81 -0
- package/dist/programs/operator-grid/config.js.map +1 -0
- package/dist/programs/operator-grid/index.d.ts +3 -0
- package/dist/programs/operator-grid/index.js +4 -0
- package/dist/programs/operator-grid/index.js.map +1 -0
- package/dist/programs/operator-grid/main.d.ts +1 -0
- package/dist/programs/operator-grid/main.js +5 -0
- package/dist/programs/operator-grid/main.js.map +1 -0
- package/dist/programs/operator-grid/read.d.ts +1 -0
- package/dist/programs/operator-grid/read.js +30 -0
- package/dist/programs/operator-grid/read.js.map +1 -0
- package/dist/programs/operator-grid/write.d.ts +1 -0
- package/dist/programs/operator-grid/write.js +124 -0
- package/dist/programs/operator-grid/write.js.map +1 -0
- package/dist/programs/pdg/config.d.ts +2 -0
- package/dist/programs/pdg/config.js +134 -0
- package/dist/programs/pdg/config.js.map +1 -0
- package/dist/programs/pdg/index.d.ts +3 -0
- package/dist/programs/pdg/index.js +4 -0
- package/dist/programs/pdg/index.js.map +1 -0
- package/dist/programs/pdg/main.d.ts +1 -0
- package/dist/programs/pdg/main.js +5 -0
- package/dist/programs/pdg/main.js.map +1 -0
- package/dist/programs/pdg/read.d.ts +1 -0
- package/dist/programs/pdg/read.js +38 -0
- package/dist/programs/pdg/read.js.map +1 -0
- package/dist/programs/pdg/write.d.ts +1 -0
- package/dist/programs/pdg/write.js +370 -0
- package/dist/programs/pdg/write.js.map +1 -0
- package/dist/programs/pdg-helpers.d.ts +1 -0
- package/dist/programs/pdg-helpers.js +221 -0
- package/dist/programs/pdg-helpers.js.map +1 -0
- package/dist/programs/report/index.d.ts +3 -0
- package/dist/programs/report/index.js +4 -0
- package/dist/programs/report/index.js.map +1 -0
- package/dist/programs/report/main.d.ts +1 -0
- package/dist/programs/report/main.js +3 -0
- package/dist/programs/report/main.js.map +1 -0
- package/dist/programs/report/read.d.ts +1 -0
- package/dist/programs/report/read.js +93 -0
- package/dist/programs/report/read.js.map +1 -0
- package/dist/programs/report/write.d.ts +1 -0
- package/dist/programs/report/write.js +125 -0
- package/dist/programs/report/write.js.map +1 -0
- package/dist/programs/vault/config.d.ts +2 -0
- package/dist/programs/vault/config.js +70 -0
- package/dist/programs/vault/config.js.map +1 -0
- package/dist/programs/vault/index.d.ts +3 -0
- package/dist/programs/vault/index.js +4 -0
- package/dist/programs/vault/index.js.map +1 -0
- package/dist/programs/vault/main.d.ts +1 -0
- package/dist/programs/vault/main.js +3 -0
- package/dist/programs/vault/main.js.map +1 -0
- package/dist/programs/vault/read.d.ts +1 -0
- package/dist/programs/vault/read.js +25 -0
- package/dist/programs/vault/read.js.map +1 -0
- package/dist/programs/vault/write.d.ts +1 -0
- package/dist/programs/vault/write.js +247 -0
- package/dist/programs/vault/write.js.map +1 -0
- package/dist/programs/vault-factory/config.d.ts +2 -0
- package/dist/programs/vault-factory/config.js +2 -0
- package/dist/programs/vault-factory/config.js.map +1 -0
- package/dist/programs/vault-factory/index.d.ts +3 -0
- package/dist/programs/vault-factory/index.js +4 -0
- package/dist/programs/vault-factory/index.js.map +1 -0
- package/dist/programs/vault-factory/main.d.ts +1 -0
- package/dist/programs/vault-factory/main.js +5 -0
- package/dist/programs/vault-factory/main.js.map +1 -0
- package/dist/programs/vault-factory/read.d.ts +1 -0
- package/dist/programs/vault-factory/read.js +24 -0
- package/dist/programs/vault-factory/read.js.map +1 -0
- package/dist/programs/vault-factory/write.d.ts +1 -0
- package/dist/programs/vault-factory/write.js +86 -0
- package/dist/programs/vault-factory/write.js.map +1 -0
- package/dist/programs/vault-viewer/config.d.ts +2 -0
- package/dist/programs/vault-viewer/config.js +120 -0
- package/dist/programs/vault-viewer/config.js.map +1 -0
- package/dist/programs/vault-viewer/index.d.ts +2 -0
- package/dist/programs/vault-viewer/index.js +3 -0
- package/dist/programs/vault-viewer/index.js.map +1 -0
- package/dist/programs/vault-viewer/main.d.ts +1 -0
- package/dist/programs/vault-viewer/main.js +10 -0
- package/dist/programs/vault-viewer/main.js.map +1 -0
- package/dist/programs/vault-viewer/read.d.ts +1 -0
- package/dist/programs/vault-viewer/read.js +121 -0
- package/dist/programs/vault-viewer/read.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 +6897 -0
- package/dist/providers/wallet.js +44 -28
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/__mocks__/@lodestar/types.d.ts +1 -0
- package/dist/tests/__mocks__/@lodestar/types.js +6 -0
- package/dist/tests/__mocks__/@lodestar/types.js.map +1 -0
- 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 +51 -0
- package/dist/tests/utils/error-handler.test.js.map +1 -0
- package/dist/tests/utils/fetchCL.test.d.ts +1 -0
- package/dist/tests/utils/fetchCL.test.js +57 -0
- package/dist/tests/utils/fetchCL.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 +98 -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/report-proof.test.d.ts +1 -0
- package/dist/tests/utils/report-proof.test.js +29 -0
- package/dist/tests/utils/report-proof.test.js.map +1 -0
- package/dist/tests/utils/report-statistic.test.d.ts +1 -0
- package/dist/tests/utils/report-statistic.test.js +247 -0
- package/dist/tests/utils/report-statistic.test.js.map +1 -0
- package/dist/tests/utils/required-lock.test.d.ts +1 -0
- package/dist/tests/utils/required-lock.test.js +26 -0
- package/dist/tests/utils/required-lock.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 +31 -0
- package/dist/types/common.js +2 -0
- package/dist/types/common.js.map +1 -0
- package/dist/types/config.d.ts +25 -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 +14 -0
- package/dist/utils/arguments.js +70 -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 +28 -0
- package/dist/utils/calculate-overview-v2.js +57 -0
- package/dist/utils/calculate-overview-v2.js.map +1 -0
- package/dist/utils/calculate-overview.d.ts +29 -0
- package/dist/utils/calculate-overview.js +59 -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 +118 -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 +34 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/efficiency.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/efficiency.js +33 -0
- package/dist/utils/charts/blessed/datasets/efficiency.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 +33 -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 +39 -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 +34 -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 +33 -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 +33 -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 +39 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +33 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +133 -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 +62 -0
- package/dist/utils/charts/blessed/utils.js +84 -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 +2 -0
- package/dist/utils/charts/simple/simple-charts.js +81 -0
- package/dist/utils/charts/simple/simple-charts.js.map +1 -0
- package/dist/utils/commands/confirmations.d.ts +21 -0
- package/dist/utils/commands/confirmations.js +99 -0
- package/dist/utils/commands/confirmations.js.map +1 -0
- package/dist/utils/commands/dashboard.d.ts +6 -0
- package/dist/utils/commands/dashboard.js +145 -0
- package/dist/utils/commands/dashboard.js.map +1 -0
- package/dist/utils/commands/index.d.ts +4 -0
- package/dist/utils/commands/index.js +5 -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 +43 -0
- package/dist/utils/commands/report.js.map +1 -0
- package/dist/utils/commands/utils.d.ts +6 -0
- package/dist/utils/commands/utils.js +57 -0
- package/dist/utils/commands/utils.js.map +1 -0
- package/dist/utils/contract.d.ts +57 -0
- package/dist/utils/contract.js +212 -0
- package/dist/utils/contract.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 +14 -0
- package/dist/utils/fetchCL.js +57 -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 +11 -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 +30 -0
- package/dist/utils/index.js +30 -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 +14 -0
- package/dist/utils/ipfs.js +94 -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 +15 -0
- package/dist/utils/logging/console.js +36 -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/dashboard.d.ts +33 -0
- package/dist/utils/prompts/dashboard.js +45 -0
- package/dist/utils/prompts/dashboard.js.map +1 -0
- package/dist/utils/prompts/default.d.ts +4 -0
- package/dist/utils/prompts/default.js +20 -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/operations.d.ts +9 -0
- package/dist/utils/prompts/operations.js +45 -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 +22 -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 +11 -0
- package/dist/utils/proof/create-proof.js +38 -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 +4 -0
- package/dist/utils/proof/index.js +5 -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/proof/report-proof.d.ts +5 -0
- package/dist/utils/proof/report-proof.js +26 -0
- package/dist/utils/proof/report-proof.js.map +1 -0
- package/dist/utils/read-programs-by-abi.d.ts +20 -0
- package/dist/utils/read-programs-by-abi.js +91 -0
- package/dist/utils/read-programs-by-abi.js.map +1 -0
- package/dist/utils/rebase-rewards.d.ts +8 -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 +3 -0
- package/dist/utils/report/index.js +4 -0
- package/dist/utils/report/index.js.map +1 -0
- package/dist/utils/report/report-statistic.d.ts +52 -0
- package/dist/utils/report/report-statistic.js +128 -0
- package/dist/utils/report/report-statistic.js.map +1 -0
- package/dist/utils/report/report.d.ts +106 -0
- package/dist/utils/report/report.js +146 -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 +29 -0
- package/dist/utils/report/statistic-data.js.map +1 -0
- package/dist/utils/required-lock.d.ts +5 -0
- package/dist/utils/required-lock.js +21 -0
- package/dist/utils/required-lock.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/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/version/index.d.ts +1 -0
- package/dist/version/index.js +1 -0
- package/dist/version/index.js.map +1 -0
- package/package.json +76 -27
- package/dist/programs/vault-hub.js +0 -137
- package/dist/programs/vault-hub.js.map +0 -1
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { program } from 'commander';
|
|
2
|
+
import { isAddress, parseEther } from 'viem';
|
|
3
|
+
import { toHex } from './proof/merkle-utils.js';
|
|
4
|
+
const toCamelCase = (str) => str.replace(/_([a-z])/g, (_, char) => char.toUpperCase());
|
|
5
|
+
export const stringToBigIntArray = (value) => {
|
|
6
|
+
return value.split(',').map(BigInt);
|
|
7
|
+
};
|
|
8
|
+
export const stringToBigIntArrayWei = (value) => {
|
|
9
|
+
return value.split(',').map(etherToWei);
|
|
10
|
+
};
|
|
11
|
+
export const stringToHexArray = (value) => {
|
|
12
|
+
return value.split(',').map(toHex);
|
|
13
|
+
};
|
|
14
|
+
export const jsonToPermit = (value) => {
|
|
15
|
+
return JSON.parse(value);
|
|
16
|
+
};
|
|
17
|
+
export const jsonToRoleAssignment = (value) => {
|
|
18
|
+
return JSON.parse(value);
|
|
19
|
+
};
|
|
20
|
+
export const stringToBigInt = (value) => {
|
|
21
|
+
return BigInt(value);
|
|
22
|
+
};
|
|
23
|
+
export const etherToWei = (value) => {
|
|
24
|
+
return parseEther(value, 'wei');
|
|
25
|
+
};
|
|
26
|
+
export const stringToNumber = (value) => {
|
|
27
|
+
if (isNaN(Number(value)) || Number(value) < 0) {
|
|
28
|
+
program.error('value must be a positive number', { exitCode: 1 });
|
|
29
|
+
}
|
|
30
|
+
return parseInt(value);
|
|
31
|
+
};
|
|
32
|
+
export const parseTiers = (value) => {
|
|
33
|
+
return JSON.parse(value);
|
|
34
|
+
};
|
|
35
|
+
export const parseTier = (value) => {
|
|
36
|
+
return JSON.parse(value);
|
|
37
|
+
};
|
|
38
|
+
export const parseDepositArray = (str) => {
|
|
39
|
+
const trimmed = str.trim();
|
|
40
|
+
if (!trimmed) {
|
|
41
|
+
return [];
|
|
42
|
+
}
|
|
43
|
+
const parsed = JSON.parse(trimmed, (key, value) => {
|
|
44
|
+
if (key === '')
|
|
45
|
+
return value; // root array
|
|
46
|
+
if (key === 'amount')
|
|
47
|
+
return BigInt(value) * BigInt(10 ** 9); // to wei
|
|
48
|
+
if (typeof value === 'string') {
|
|
49
|
+
return toHex(value);
|
|
50
|
+
}
|
|
51
|
+
return value;
|
|
52
|
+
});
|
|
53
|
+
// Convert keys to camelCase
|
|
54
|
+
const camelCased = parsed.map((obj) => {
|
|
55
|
+
const newObj = {};
|
|
56
|
+
for (const key in obj) {
|
|
57
|
+
const camelKey = toCamelCase(key);
|
|
58
|
+
newObj[camelKey] = obj[key];
|
|
59
|
+
}
|
|
60
|
+
return newObj;
|
|
61
|
+
});
|
|
62
|
+
return camelCased;
|
|
63
|
+
};
|
|
64
|
+
export const stringToAddress = (value) => {
|
|
65
|
+
if (!isAddress(value)) {
|
|
66
|
+
program.error('Address value must be a valid address', { exitCode: 1 });
|
|
67
|
+
}
|
|
68
|
+
return value;
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=arguments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"arguments.js","sourceRoot":"","sources":["../../utils/arguments.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { type Hex } from 'viem';
|
|
2
|
+
type DepositStruct = {
|
|
3
|
+
pubkey: Hex;
|
|
4
|
+
signature: Hex;
|
|
5
|
+
amount: bigint;
|
|
6
|
+
depositDataRoot: Hex;
|
|
7
|
+
};
|
|
8
|
+
export declare const computeDepositDomainByForkVersion: (forkVersion: string) => Uint8Array<ArrayBufferLike>;
|
|
9
|
+
export declare const computeDepositDomain: () => Uint8Array<ArrayBufferLike>;
|
|
10
|
+
export declare const isValidBLSDeposit: (deposit: DepositStruct, withdrawalCredentials: Hex) => boolean;
|
|
11
|
+
export declare const expandBLSSignature: (signature: Hex, pubkey: Hex) => {
|
|
12
|
+
pubkey: `0x${string}`;
|
|
13
|
+
pubkeyY_a: `0x${string}`;
|
|
14
|
+
pubkeyY_b: `0x${string}`;
|
|
15
|
+
signature: `0x${string}`;
|
|
16
|
+
sigY_c0_a: `0x${string}`;
|
|
17
|
+
sigY_c0_b: `0x${string}`;
|
|
18
|
+
sigY_c1_a: `0x${string}`;
|
|
19
|
+
sigY_c1_b: `0x${string}`;
|
|
20
|
+
};
|
|
21
|
+
export {};
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { pad, bytesToHex } from 'viem';
|
|
2
|
+
import { mainnet, sepolia, hoodi } from 'viem/chains';
|
|
3
|
+
import { fromHexString, ByteVectorType, ContainerType, UintNumberType, } from '@chainsafe/ssz';
|
|
4
|
+
import { PublicKey, Signature, verify } from '@chainsafe/blst';
|
|
5
|
+
import { toHex } from './proof/merkle-utils.js';
|
|
6
|
+
import { getChain } from '../configs/index.js';
|
|
7
|
+
const FORK_VERSION_BY_CHAIN = {
|
|
8
|
+
[sepolia.id]: '0x90000069', // https://github.com/eth-clients/sepolia
|
|
9
|
+
[hoodi.id]: '0x10000910', // https://github.com/eth-clients/hoodi
|
|
10
|
+
[mainnet.id]: '0x00000000', // https://github.com/eth-clients/mainnet
|
|
11
|
+
};
|
|
12
|
+
export const computeDepositDomainByForkVersion = (forkVersion) => {
|
|
13
|
+
const ZERO_HASH = Buffer.alloc(32, 0);
|
|
14
|
+
const DOMAIN_DEPOSIT = Uint8Array.from([3, 0, 0, 0]);
|
|
15
|
+
const forkVersionUint8Array = fromHexString(forkVersion);
|
|
16
|
+
const Root = new ByteVectorType(32);
|
|
17
|
+
const Bytes4 = new ByteVectorType(4);
|
|
18
|
+
const Version = Bytes4;
|
|
19
|
+
const ForkData = new ContainerType({
|
|
20
|
+
currentVersion: Version,
|
|
21
|
+
genesisValidatorsRoot: Root,
|
|
22
|
+
}, { typeName: 'ForkData', jsonCase: 'eth2' });
|
|
23
|
+
const computeDomain = (domainType, forkVersion, genesisValidatorRoot) => {
|
|
24
|
+
const forkDataRoot = computeForkDataRoot(forkVersion, genesisValidatorRoot);
|
|
25
|
+
const domain = new Uint8Array(32);
|
|
26
|
+
domain.set(domainType, 0);
|
|
27
|
+
domain.set(forkDataRoot.slice(0, 28), 4);
|
|
28
|
+
return domain;
|
|
29
|
+
};
|
|
30
|
+
const computeForkDataRoot = (currentVersion, genesisValidatorsRoot) => {
|
|
31
|
+
return ForkData.hashTreeRoot({ currentVersion, genesisValidatorsRoot });
|
|
32
|
+
};
|
|
33
|
+
return computeDomain(DOMAIN_DEPOSIT, forkVersionUint8Array, ZERO_HASH);
|
|
34
|
+
};
|
|
35
|
+
export const computeDepositDomain = () => {
|
|
36
|
+
const forkByChain = FORK_VERSION_BY_CHAIN[getChain().id];
|
|
37
|
+
if (!forkByChain) {
|
|
38
|
+
throw new Error(`Fork version not found for chain ${getChain().id}`);
|
|
39
|
+
}
|
|
40
|
+
return computeDepositDomainByForkVersion(forkByChain);
|
|
41
|
+
};
|
|
42
|
+
const computeDepositMessageRoot = (pubkey, withdrawalCredentials, amount) => {
|
|
43
|
+
const Bytes48 = new ByteVectorType(48);
|
|
44
|
+
const Bytes32 = new ByteVectorType(32);
|
|
45
|
+
const UintNum64 = new UintNumberType(8);
|
|
46
|
+
const Root = new ByteVectorType(32);
|
|
47
|
+
const Domain = Bytes32;
|
|
48
|
+
const BLSPubkey = Bytes48;
|
|
49
|
+
const DepositMessage = new ContainerType({ pubkey: BLSPubkey, withdrawalCredentials: Bytes32, amount: UintNum64 }, { typeName: 'DepositMessage', jsonCase: 'eth2' });
|
|
50
|
+
const SigningData = new ContainerType({
|
|
51
|
+
objectRoot: Root,
|
|
52
|
+
domain: Domain,
|
|
53
|
+
}, { typeName: 'SigningData', jsonCase: 'eth2' });
|
|
54
|
+
const depositMessage = {
|
|
55
|
+
pubkey: BLSPubkey.fromJson(toHex(pubkey)),
|
|
56
|
+
withdrawalCredentials: Bytes32.fromJson(toHex(withdrawalCredentials)),
|
|
57
|
+
amount: UintNum64.fromJson(amount / 1000000000n),
|
|
58
|
+
};
|
|
59
|
+
const domain = computeDepositDomain();
|
|
60
|
+
return SigningData.hashTreeRoot({
|
|
61
|
+
objectRoot: DepositMessage.hashTreeRoot(depositMessage),
|
|
62
|
+
domain,
|
|
63
|
+
});
|
|
64
|
+
};
|
|
65
|
+
export const isValidBLSDeposit = (deposit, withdrawalCredentials) => {
|
|
66
|
+
const signningRoot = computeDepositMessageRoot(deposit.pubkey, withdrawalCredentials, deposit.amount);
|
|
67
|
+
const isBLSValid = verify(signningRoot, PublicKey.fromHex(deposit.pubkey), Signature.fromHex(deposit.signature), true, true);
|
|
68
|
+
return isBLSValid;
|
|
69
|
+
};
|
|
70
|
+
export const expandBLSSignature = (signature, pubkey) => {
|
|
71
|
+
const pubkeyY = PublicKey.fromHex(pubkey).toBytes(false).slice(48);
|
|
72
|
+
// pad Y.a to 32 bytes to match Fp struct
|
|
73
|
+
const pubkeyY_a = bytesToHex(pad(pubkeyY.slice(0, 16), { dir: 'left', size: 32 }));
|
|
74
|
+
const pubkeyY_b = bytesToHex(pad(pubkeyY.slice(16), { dir: 'left', size: 32 }));
|
|
75
|
+
const signatureY = Signature.fromHex(signature).toBytes(false).slice(96);
|
|
76
|
+
// first Fp of Y coordinate is last 48 bytes of signature
|
|
77
|
+
const sigY_c0 = signatureY.slice(48);
|
|
78
|
+
const sigY_c0_a = bytesToHex(pad(sigY_c0.slice(0, 16), {
|
|
79
|
+
dir: 'left',
|
|
80
|
+
size: 32,
|
|
81
|
+
}));
|
|
82
|
+
const sigY_c0_b = bytesToHex(pad(sigY_c0.slice(16), { dir: 'left', size: 32 }));
|
|
83
|
+
// second Fp is 48 bytes before first one
|
|
84
|
+
const sigY_c1 = signatureY.slice(0, 48);
|
|
85
|
+
const sigY_c1_a = bytesToHex(pad(sigY_c1.slice(0, 16), {
|
|
86
|
+
dir: 'left',
|
|
87
|
+
size: 32,
|
|
88
|
+
}));
|
|
89
|
+
const sigY_c1_b = bytesToHex(pad(sigY_c1.slice(16), { dir: 'left', size: 32 }));
|
|
90
|
+
return {
|
|
91
|
+
pubkey,
|
|
92
|
+
pubkeyY_a,
|
|
93
|
+
pubkeyY_b,
|
|
94
|
+
signature,
|
|
95
|
+
sigY_c0_a,
|
|
96
|
+
sigY_c0_b,
|
|
97
|
+
sigY_c1_a,
|
|
98
|
+
sigY_c1_b,
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
//# sourceMappingURL=bls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bls.js","sourceRoot":"","sources":["../../utils/bls.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare const cache: {
|
|
2
|
+
getShareRate(blockNumber: number): Promise<bigint | null>;
|
|
3
|
+
setShareRate(blockNumber: number, value: bigint): Promise<void>;
|
|
4
|
+
getRebaseReward(vaultAddress: string, cacheKey: string): Promise<bigint | null>;
|
|
5
|
+
setRebaseReward(vaultAddress: string, cacheKey: string, value: bigint): Promise<void>;
|
|
6
|
+
getNodeOperatorFeeBP(vaultAddress: string, blockNumber: number): Promise<bigint | null>;
|
|
7
|
+
setNodeOperatorFeeBP(vaultAddress: string, blockNumber: number, value: bigint): Promise<void>;
|
|
8
|
+
};
|
|
9
|
+
export declare const getShareRateFromCache: (blockNumber: number) => Promise<bigint>;
|
|
10
|
+
type GetRebaseRewardFromCacheArgs = {
|
|
11
|
+
vaultAddress: string;
|
|
12
|
+
blockNumberPrev: number;
|
|
13
|
+
blockNumberCurr: number;
|
|
14
|
+
liabilitySharesPrev: bigint;
|
|
15
|
+
liabilitySharesCurr: bigint;
|
|
16
|
+
};
|
|
17
|
+
export declare const getRebaseRewardFromCache: (args: GetRebaseRewardFromCacheArgs) => Promise<bigint>;
|
|
18
|
+
export {};
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import fs from 'fs/promises';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import { calculateShareRate, calculateRebaseReward } from './index.js';
|
|
4
|
+
const getShareRateCacheFile = () => path.resolve('ipfs-cache', `share-rate-cache-global.json`);
|
|
5
|
+
const getRebaseRewardCacheFile = (vaultAddress) => path.resolve('ipfs-cache', `rebase-rewards-cache-${vaultAddress}.json`);
|
|
6
|
+
const getNodeOperatorFeeBPCacheFile = (vaultAddress) => path.resolve('ipfs-cache', `node-operator-fee-bp-cache-${vaultAddress}.json`);
|
|
7
|
+
export const cache = {
|
|
8
|
+
async getShareRate(blockNumber) {
|
|
9
|
+
try {
|
|
10
|
+
const data = JSON.parse(await fs.readFile(getShareRateCacheFile(), 'utf-8'));
|
|
11
|
+
if (data[blockNumber] !== undefined)
|
|
12
|
+
return BigInt(data[blockNumber]);
|
|
13
|
+
}
|
|
14
|
+
catch {
|
|
15
|
+
/* ignore */
|
|
16
|
+
}
|
|
17
|
+
return null;
|
|
18
|
+
},
|
|
19
|
+
async setShareRate(blockNumber, value) {
|
|
20
|
+
let data = {};
|
|
21
|
+
try {
|
|
22
|
+
data = JSON.parse(await fs.readFile(getShareRateCacheFile(), 'utf-8'));
|
|
23
|
+
}
|
|
24
|
+
catch {
|
|
25
|
+
/* ignore */
|
|
26
|
+
}
|
|
27
|
+
data[blockNumber] = value.toString();
|
|
28
|
+
await fs.mkdir(path.dirname(getShareRateCacheFile()), {
|
|
29
|
+
recursive: true,
|
|
30
|
+
});
|
|
31
|
+
await fs.writeFile(getShareRateCacheFile(), JSON.stringify(data), 'utf-8');
|
|
32
|
+
},
|
|
33
|
+
async getRebaseReward(vaultAddress, cacheKey) {
|
|
34
|
+
try {
|
|
35
|
+
const data = JSON.parse(await fs.readFile(getRebaseRewardCacheFile(vaultAddress), 'utf-8'));
|
|
36
|
+
if (data[cacheKey] !== undefined)
|
|
37
|
+
return BigInt(data[cacheKey]);
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
/* ignore */
|
|
41
|
+
}
|
|
42
|
+
return null;
|
|
43
|
+
},
|
|
44
|
+
async setRebaseReward(vaultAddress, cacheKey, value) {
|
|
45
|
+
let data = {};
|
|
46
|
+
try {
|
|
47
|
+
data = JSON.parse(await fs.readFile(getRebaseRewardCacheFile(vaultAddress), 'utf-8'));
|
|
48
|
+
}
|
|
49
|
+
catch {
|
|
50
|
+
/* ignore */
|
|
51
|
+
}
|
|
52
|
+
data[cacheKey] = value.toString();
|
|
53
|
+
await fs.mkdir(path.dirname(getRebaseRewardCacheFile(vaultAddress)), {
|
|
54
|
+
recursive: true,
|
|
55
|
+
});
|
|
56
|
+
await fs.writeFile(getRebaseRewardCacheFile(vaultAddress), JSON.stringify(data), 'utf-8');
|
|
57
|
+
},
|
|
58
|
+
async getNodeOperatorFeeBP(vaultAddress, blockNumber) {
|
|
59
|
+
try {
|
|
60
|
+
const data = JSON.parse(await fs.readFile(getNodeOperatorFeeBPCacheFile(vaultAddress), 'utf-8'));
|
|
61
|
+
if (data[blockNumber] !== undefined)
|
|
62
|
+
return BigInt(data[blockNumber]);
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
/* ignore */
|
|
66
|
+
}
|
|
67
|
+
return null;
|
|
68
|
+
},
|
|
69
|
+
async setNodeOperatorFeeBP(vaultAddress, blockNumber, value) {
|
|
70
|
+
let data = {};
|
|
71
|
+
try {
|
|
72
|
+
data = JSON.parse(await fs.readFile(getNodeOperatorFeeBPCacheFile(vaultAddress), 'utf-8'));
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
/* ignore */
|
|
76
|
+
}
|
|
77
|
+
data[blockNumber] = value.toString();
|
|
78
|
+
await fs.mkdir(path.dirname(getNodeOperatorFeeBPCacheFile(vaultAddress)), {
|
|
79
|
+
recursive: true,
|
|
80
|
+
});
|
|
81
|
+
await fs.writeFile(getNodeOperatorFeeBPCacheFile(vaultAddress), JSON.stringify(data), 'utf-8');
|
|
82
|
+
},
|
|
83
|
+
};
|
|
84
|
+
export const getShareRateFromCache = async (blockNumber) => {
|
|
85
|
+
const cached = await cache.getShareRate(blockNumber);
|
|
86
|
+
if (cached !== null)
|
|
87
|
+
return cached;
|
|
88
|
+
const shareRate = await calculateShareRate(blockNumber);
|
|
89
|
+
await cache.setShareRate(blockNumber, shareRate);
|
|
90
|
+
return shareRate;
|
|
91
|
+
};
|
|
92
|
+
export const getRebaseRewardFromCache = async (args) => {
|
|
93
|
+
const { vaultAddress, blockNumberPrev, blockNumberCurr, liabilitySharesPrev, liabilitySharesCurr, } = args;
|
|
94
|
+
const cacheKey = `${blockNumberPrev}_${blockNumberCurr}`;
|
|
95
|
+
const cached = await cache.getRebaseReward(vaultAddress, cacheKey);
|
|
96
|
+
if (cached !== null)
|
|
97
|
+
return cached;
|
|
98
|
+
const shareRatePrev = await getShareRateFromCache(blockNumberPrev);
|
|
99
|
+
const shareRateCurr = await getShareRateFromCache(blockNumberCurr);
|
|
100
|
+
const reward = calculateRebaseReward({
|
|
101
|
+
shareRatePrev,
|
|
102
|
+
shareRateCurr,
|
|
103
|
+
sharesPrev: liabilitySharesPrev,
|
|
104
|
+
sharesCurr: liabilitySharesCurr,
|
|
105
|
+
});
|
|
106
|
+
await cache.setRebaseReward(vaultAddress, cacheKey, reward);
|
|
107
|
+
return reward;
|
|
108
|
+
};
|
|
109
|
+
//# sourceMappingURL=cache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../utils/cache.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
type OverviewArgs = {
|
|
2
|
+
totalValue: bigint;
|
|
3
|
+
reserveRatioBP: number;
|
|
4
|
+
liabilitySharesInStethWei: bigint;
|
|
5
|
+
liabilitySharesInWei: bigint;
|
|
6
|
+
forceRebalanceThresholdBP: number;
|
|
7
|
+
withdrawableEther: bigint;
|
|
8
|
+
balance: bigint;
|
|
9
|
+
locked: bigint;
|
|
10
|
+
nodeOperatorUnclaimedFee: bigint;
|
|
11
|
+
totalMintingCapacityStethWei: bigint;
|
|
12
|
+
totalMintingCapacitySharesInWei: bigint;
|
|
13
|
+
};
|
|
14
|
+
export declare const calculateOverviewV2: (args: OverviewArgs) => {
|
|
15
|
+
healthRatio: number;
|
|
16
|
+
isHealthy: boolean;
|
|
17
|
+
AvailableToWithdrawal: bigint;
|
|
18
|
+
idleCapital: bigint;
|
|
19
|
+
totalLocked: bigint;
|
|
20
|
+
collateral: bigint;
|
|
21
|
+
PendingUnlock: bigint;
|
|
22
|
+
utilizationRatio: number;
|
|
23
|
+
reserved: bigint;
|
|
24
|
+
totalMintingCapacityStethWei: bigint;
|
|
25
|
+
remainingMintingCapacitySteth: bigint;
|
|
26
|
+
remainingMintingCapacityShares: bigint;
|
|
27
|
+
};
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { parseEther } from 'viem';
|
|
2
|
+
import { calculateHealth } from './health/calculate-health.js';
|
|
3
|
+
const BASIS_POINTS_DENOMINATOR = 10000n;
|
|
4
|
+
const DECIMALS = 18n;
|
|
5
|
+
const SCALING_FACTOR = 10n ** DECIMALS;
|
|
6
|
+
const bigIntMax = (...args) => args.reduce((a, b) => (a > b ? a : b));
|
|
7
|
+
const bigIntMin = (...args) => args.reduce((a, b) => (a < b ? a : b));
|
|
8
|
+
export const calculateOverviewV2 = (args) => {
|
|
9
|
+
const { totalValue, reserveRatioBP, liabilitySharesInStethWei, liabilitySharesInWei, forceRebalanceThresholdBP, withdrawableEther, balance, locked, nodeOperatorUnclaimedFee, totalMintingCapacityStethWei, totalMintingCapacitySharesInWei, } = args;
|
|
10
|
+
const { healthRatio, isHealthy } = calculateHealth({
|
|
11
|
+
totalValue,
|
|
12
|
+
liabilitySharesInStethWei,
|
|
13
|
+
forceRebalanceThresholdBP,
|
|
14
|
+
});
|
|
15
|
+
const AvailableToWithdrawal = withdrawableEther;
|
|
16
|
+
const idleCapital = balance;
|
|
17
|
+
const UnsettledLidoFees = 0n;
|
|
18
|
+
// TODO: add Lido Unclaimed Fees
|
|
19
|
+
const totalLocked = locked + nodeOperatorUnclaimedFee + UnsettledLidoFees;
|
|
20
|
+
const RR = (BigInt(reserveRatioBP) * SCALING_FACTOR) / BASIS_POINTS_DENOMINATOR; // RR with SCALING_FACTOR
|
|
21
|
+
const oneMinusRR = SCALING_FACTOR - RR; // (1 - RR) with SCALING_FACTOR
|
|
22
|
+
const liabilityDivOneMinusRR = oneMinusRR === 0n
|
|
23
|
+
? 0n
|
|
24
|
+
: (liabilitySharesInStethWei * SCALING_FACTOR) / oneMinusRR;
|
|
25
|
+
const collateral = bigIntMax(parseEther('1'), liabilityDivOneMinusRR);
|
|
26
|
+
const PendingUnlock = liabilityDivOneMinusRR <= parseEther('1')
|
|
27
|
+
? bigIntMax(locked - parseEther('1'), 0n)
|
|
28
|
+
: bigIntMax(locked - liabilityDivOneMinusRR, 0n);
|
|
29
|
+
const remainingMintingCapacityShares = totalMintingCapacitySharesInWei - liabilitySharesInWei;
|
|
30
|
+
const remainingMintingCapacitySteth = totalMintingCapacityStethWei - liabilitySharesInStethWei;
|
|
31
|
+
const reservedByFormula = oneMinusRR === 0n
|
|
32
|
+
? 0n
|
|
33
|
+
: (liabilitySharesInStethWei * SCALING_FACTOR) / oneMinusRR -
|
|
34
|
+
liabilitySharesInStethWei;
|
|
35
|
+
const reserved = bigIntMin(totalValue - liabilitySharesInStethWei, reservedByFormula);
|
|
36
|
+
// Prevent division by 0
|
|
37
|
+
const utilizationRatio = totalMintingCapacityStethWei === 0n
|
|
38
|
+
? 0
|
|
39
|
+
: Number(((liabilitySharesInStethWei * SCALING_FACTOR) /
|
|
40
|
+
totalMintingCapacityStethWei) *
|
|
41
|
+
100n) / Number(SCALING_FACTOR);
|
|
42
|
+
return {
|
|
43
|
+
healthRatio,
|
|
44
|
+
isHealthy,
|
|
45
|
+
AvailableToWithdrawal,
|
|
46
|
+
idleCapital,
|
|
47
|
+
totalLocked,
|
|
48
|
+
collateral,
|
|
49
|
+
PendingUnlock,
|
|
50
|
+
utilizationRatio,
|
|
51
|
+
reserved,
|
|
52
|
+
totalMintingCapacityStethWei,
|
|
53
|
+
remainingMintingCapacitySteth,
|
|
54
|
+
remainingMintingCapacityShares,
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=calculate-overview-v2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calculate-overview-v2.js","sourceRoot":"","sources":["../../utils/calculate-overview-v2.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
type OverviewArgs = {
|
|
2
|
+
totalValue: bigint;
|
|
3
|
+
reserveRatioBP: number;
|
|
4
|
+
liabilitySharesInStethWei: bigint;
|
|
5
|
+
forceRebalanceThresholdBP: number;
|
|
6
|
+
withdrawableEther: bigint;
|
|
7
|
+
balance: bigint;
|
|
8
|
+
locked: bigint;
|
|
9
|
+
nodeOperatorUnclaimedFee: bigint;
|
|
10
|
+
totalMintingCapacityStethWei: bigint;
|
|
11
|
+
};
|
|
12
|
+
export declare const BASIS_POINTS_DENOMINATOR = 10000n;
|
|
13
|
+
export declare const formatBP: (bp: number | bigint) => string;
|
|
14
|
+
export declare const formatRatio: (r: number) => string;
|
|
15
|
+
export declare const calculateOverview: (args: OverviewArgs) => {
|
|
16
|
+
healthRatio: number;
|
|
17
|
+
isHealthy: boolean;
|
|
18
|
+
AvailableToWithdrawal: bigint;
|
|
19
|
+
idleCapital: bigint;
|
|
20
|
+
totalLocked: bigint;
|
|
21
|
+
collateral: bigint;
|
|
22
|
+
PendingUnlock: bigint;
|
|
23
|
+
utilizationRatio: number;
|
|
24
|
+
totalReservable: bigint;
|
|
25
|
+
reserved: bigint;
|
|
26
|
+
totalMintingCapacityStethWei: bigint;
|
|
27
|
+
remainingMintingCapacity: bigint;
|
|
28
|
+
};
|
|
29
|
+
export {};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { parseEther } from 'viem';
|
|
2
|
+
import { calculateHealth } from './health/calculate-health.js';
|
|
3
|
+
export const BASIS_POINTS_DENOMINATOR = 10000n;
|
|
4
|
+
const DECIMALS = 18n;
|
|
5
|
+
const SCALING_FACTOR = 10n ** DECIMALS;
|
|
6
|
+
const bigIntMax = (...args) => args.reduce((a, b) => (a > b ? a : b));
|
|
7
|
+
const bigIntMin = (...args) => args.reduce((a, b) => (a < b ? a : b));
|
|
8
|
+
// Percent helper (basis points → percentage)
|
|
9
|
+
export const formatBP = (bp) => `${((Number(bp) / Number(BASIS_POINTS_DENOMINATOR)) * 100).toFixed(2)}%`;
|
|
10
|
+
export const formatRatio = (r) => isFinite(r) ? `${r.toFixed(4)}%` : '∞';
|
|
11
|
+
export const calculateOverview = (args) => {
|
|
12
|
+
const { totalValue, reserveRatioBP, liabilitySharesInStethWei, forceRebalanceThresholdBP, withdrawableEther, balance, locked, nodeOperatorUnclaimedFee, totalMintingCapacityStethWei, } = args;
|
|
13
|
+
const { healthRatio, isHealthy } = calculateHealth({
|
|
14
|
+
totalValue,
|
|
15
|
+
liabilitySharesInStethWei,
|
|
16
|
+
forceRebalanceThresholdBP,
|
|
17
|
+
});
|
|
18
|
+
const AvailableToWithdrawal = withdrawableEther;
|
|
19
|
+
const idleCapital = balance;
|
|
20
|
+
// TODO: add Lido Unclaimed Fees
|
|
21
|
+
const totalLocked = locked + nodeOperatorUnclaimedFee;
|
|
22
|
+
// ---------- Computed values ---------- //
|
|
23
|
+
const totalReservable = (totalValue * BigInt(reserveRatioBP)) / BASIS_POINTS_DENOMINATOR;
|
|
24
|
+
// Prevent division by 0
|
|
25
|
+
const utilizationRatio = totalMintingCapacityStethWei === 0n
|
|
26
|
+
? 0
|
|
27
|
+
: Number(((liabilitySharesInStethWei * SCALING_FACTOR) /
|
|
28
|
+
totalMintingCapacityStethWei) *
|
|
29
|
+
100n) / Number(SCALING_FACTOR);
|
|
30
|
+
const reservedRaw = totalMintingCapacityStethWei === 0n
|
|
31
|
+
? 0n
|
|
32
|
+
: (liabilitySharesInStethWei * totalReservable * SCALING_FACTOR) /
|
|
33
|
+
totalMintingCapacityStethWei;
|
|
34
|
+
const reserved = bigIntMax(bigIntMax(reservedRaw / SCALING_FACTOR, totalValue - liabilitySharesInStethWei), 0n);
|
|
35
|
+
const collateral = bigIntMin(bigIntMax(liabilitySharesInStethWei + reserved, parseEther('1')), totalValue);
|
|
36
|
+
const PendingUnlock = locked - nodeOperatorUnclaimedFee - liabilitySharesInStethWei - reserved <
|
|
37
|
+
parseEther('1')
|
|
38
|
+
? 0n
|
|
39
|
+
: locked -
|
|
40
|
+
nodeOperatorUnclaimedFee -
|
|
41
|
+
liabilitySharesInStethWei -
|
|
42
|
+
reserved;
|
|
43
|
+
const remainingMintingCapacity = totalMintingCapacityStethWei - liabilitySharesInStethWei;
|
|
44
|
+
return {
|
|
45
|
+
healthRatio,
|
|
46
|
+
isHealthy,
|
|
47
|
+
AvailableToWithdrawal,
|
|
48
|
+
idleCapital,
|
|
49
|
+
totalLocked,
|
|
50
|
+
collateral,
|
|
51
|
+
PendingUnlock,
|
|
52
|
+
utilizationRatio,
|
|
53
|
+
totalReservable,
|
|
54
|
+
reserved,
|
|
55
|
+
totalMintingCapacityStethWei,
|
|
56
|
+
remainingMintingCapacity,
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
//# sourceMappingURL=calculate-overview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calculate-overview.js","sourceRoot":"","sources":["../../utils/calculate-overview.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAc/D,MAAM,CAAC,MAAM,wBAAwB,GAAG,MAAO,CAAC;AAChD,MAAM,QAAQ,GAAG,GAAG,CAAC;AACrB,MAAM,cAAc,GAAG,GAAG,IAAI,QAAQ,CAAC;AAEvC,MAAM,SAAS,GAAG,CAAC,GAAG,IAAc,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChF,MAAM,SAAS,GAAG,CAAC,GAAG,IAAc,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChF,6CAA6C;AAC7C,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EAAmB,EAAE,EAAE,CAC9C,GAAG,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;AAC3E,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,CAAS,EAAE,EAAE,CACvC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;AAEzC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,IAAkB,EAAE,EAAE;IACtD,MAAM,EACJ,UAAU,EACV,cAAc,EACd,yBAAyB,EACzB,yBAAyB,EACzB,iBAAiB,EACjB,OAAO,EACP,MAAM,EACN,wBAAwB,EACxB,4BAA4B,GAC7B,GAAG,IAAI,CAAC;IAET,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,GAAG,eAAe,CAAC;QACjD,UAAU;QACV,yBAAyB;QACzB,yBAAyB;KAC1B,CAAC,CAAC;IACH,MAAM,qBAAqB,GAAG,iBAAiB,CAAC;IAChD,MAAM,WAAW,GAAG,OAAO,CAAC;IAC5B,gCAAgC;IAChC,MAAM,WAAW,GAAG,MAAM,GAAG,wBAAwB,CAAC;IAEtD,2CAA2C;IAC3C,MAAM,eAAe,GACnB,CAAC,UAAU,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC,GAAG,wBAAwB,CAAC;IAEnE,wBAAwB;IACxB,MAAM,gBAAgB,GACpB,4BAA4B,KAAK,EAAE;QACjC,CAAC,CAAC,CAAC;QACH,CAAC,CAAC,MAAM,CACJ,CAAC,CAAC,yBAAyB,GAAG,cAAc,CAAC;YAC3C,4BAA4B,CAAC;YAC7B,IAAI,CACP,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;IAEjC,MAAM,WAAW,GACf,4BAA4B,KAAK,EAAE;QACjC,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,CAAC,yBAAyB,GAAG,eAAe,GAAG,cAAc,CAAC;YAC9D,4BAA4B,CAAC;IACnC,MAAM,QAAQ,GAAG,SAAS,CACxB,SAAS,CACP,WAAW,GAAG,cAAc,EAC5B,UAAU,GAAG,yBAAyB,CACvC,EACD,EAAE,CACH,CAAC;IAEF,MAAM,UAAU,GAAG,SAAS,CAC1B,SAAS,CAAC,yBAAyB,GAAG,QAAQ,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,EAChE,UAAU,CACX,CAAC;IACF,MAAM,aAAa,GACjB,MAAM,GAAG,wBAAwB,GAAG,yBAAyB,GAAG,QAAQ;QACxE,UAAU,CAAC,GAAG,CAAC;QACb,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,MAAM;YACN,wBAAwB;YACxB,yBAAyB;YACzB,QAAQ,CAAC;IACf,MAAM,wBAAwB,GAC5B,4BAA4B,GAAG,yBAAyB,CAAC;IAE3D,OAAO;QACL,WAAW;QACX,SAAS;QACT,qBAAqB;QACrB,WAAW;QACX,WAAW;QACX,UAAU;QACV,aAAa;QACb,gBAAgB;QAChB,eAAe;QACf,QAAQ;QACR,4BAA4B;QAC5B,wBAAwB;KACzB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
type FetchAprChartsDataArgs = {
|
|
3
|
+
cid: string;
|
|
4
|
+
dashboard: Address;
|
|
5
|
+
limit?: number;
|
|
6
|
+
cacheUse?: boolean;
|
|
7
|
+
};
|
|
8
|
+
export declare const fetchAprChartsData: ({ cid, dashboard, limit, cacheUse, }: FetchAprChartsDataArgs) => Promise<{
|
|
9
|
+
grossStakingAPRChart: {
|
|
10
|
+
range: {
|
|
11
|
+
min: number;
|
|
12
|
+
max: number;
|
|
13
|
+
minY: number;
|
|
14
|
+
maxY: number;
|
|
15
|
+
};
|
|
16
|
+
dataset: {
|
|
17
|
+
title: string;
|
|
18
|
+
label: string;
|
|
19
|
+
x: string[];
|
|
20
|
+
y: number[];
|
|
21
|
+
style: {
|
|
22
|
+
line: string;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
netStakingAPRChart: {
|
|
27
|
+
range: {
|
|
28
|
+
min: number;
|
|
29
|
+
max: number;
|
|
30
|
+
minY: number;
|
|
31
|
+
maxY: number;
|
|
32
|
+
};
|
|
33
|
+
dataset: {
|
|
34
|
+
title: string;
|
|
35
|
+
label: string;
|
|
36
|
+
x: string[];
|
|
37
|
+
y: number[];
|
|
38
|
+
style: {
|
|
39
|
+
line: string;
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
efficiencyChart: {
|
|
44
|
+
range: {
|
|
45
|
+
min: number;
|
|
46
|
+
max: number;
|
|
47
|
+
minY: number;
|
|
48
|
+
maxY: number;
|
|
49
|
+
};
|
|
50
|
+
dataset: {
|
|
51
|
+
title: string;
|
|
52
|
+
label: string;
|
|
53
|
+
x: string[];
|
|
54
|
+
y: number[];
|
|
55
|
+
style: {
|
|
56
|
+
line: string;
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
};
|
|
60
|
+
bottomLineChart: {
|
|
61
|
+
range: {
|
|
62
|
+
min: number;
|
|
63
|
+
max: number;
|
|
64
|
+
minY: number;
|
|
65
|
+
maxY: number;
|
|
66
|
+
};
|
|
67
|
+
dataset: {
|
|
68
|
+
title: string;
|
|
69
|
+
label: string;
|
|
70
|
+
x: string[];
|
|
71
|
+
y: number[];
|
|
72
|
+
style: {
|
|
73
|
+
line: string;
|
|
74
|
+
};
|
|
75
|
+
yLabel: string;
|
|
76
|
+
};
|
|
77
|
+
};
|
|
78
|
+
lidoAPRChart: {
|
|
79
|
+
range: {
|
|
80
|
+
min: number;
|
|
81
|
+
max: number;
|
|
82
|
+
minY: number;
|
|
83
|
+
maxY: number;
|
|
84
|
+
};
|
|
85
|
+
dataset: {
|
|
86
|
+
title: string;
|
|
87
|
+
label: string;
|
|
88
|
+
x: string[];
|
|
89
|
+
y: number[];
|
|
90
|
+
style: {
|
|
91
|
+
line: string;
|
|
92
|
+
};
|
|
93
|
+
yLabel: string;
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
}>;
|
|
97
|
+
export declare const renderAprCharts: ({ grossStakingAPRChart, netStakingAPRChart, efficiencyChart, bottomLineChart, lidoAPRChart, }: any) => void;
|
|
98
|
+
export {};
|