@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,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 getNodeOperatorFeeRateCacheFile = (vaultAddress) => path.resolve('ipfs-cache', `node-operator-fee-rate-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 getNodeOperatorFeeRate(vaultAddress, blockNumber) {
|
|
59
|
+
try {
|
|
60
|
+
const data = JSON.parse(await fs.readFile(getNodeOperatorFeeRateCacheFile(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 setNodeOperatorFeeRate(vaultAddress, blockNumber, value) {
|
|
70
|
+
let data = {};
|
|
71
|
+
try {
|
|
72
|
+
data = JSON.parse(await fs.readFile(getNodeOperatorFeeRateCacheFile(vaultAddress), 'utf-8'));
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
/* ignore */
|
|
76
|
+
}
|
|
77
|
+
data[blockNumber] = value.toString();
|
|
78
|
+
await fs.mkdir(path.dirname(getNodeOperatorFeeRateCacheFile(vaultAddress)), {
|
|
79
|
+
recursive: true,
|
|
80
|
+
});
|
|
81
|
+
await fs.writeFile(getNodeOperatorFeeRateCacheFile(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":"AAAA,OAAO,EAAE,MAAM,aAAa,CAAC;AAC7B,OAAO,IAAI,MAAM,MAAM,CAAC;AAExB,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,OAAO,CAAC;AAElE,MAAM,qBAAqB,GAAG,GAAG,EAAE,CACjC,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,8BAA8B,CAAC,CAAC;AAC7D,MAAM,wBAAwB,GAAG,CAAC,YAAoB,EAAE,EAAE,CACxD,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,wBAAwB,YAAY,OAAO,CAAC,CAAC;AAC1E,MAAM,+BAA+B,GAAG,CAAC,YAAoB,EAAE,EAAE,CAC/D,IAAI,CAAC,OAAO,CACV,YAAY,EACZ,gCAAgC,YAAY,OAAO,CACpD,CAAC;AAEJ,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,KAAK,CAAC,YAAY,CAAC,WAAmB;QACpC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CACrB,MAAM,EAAE,CAAC,QAAQ,CAAC,qBAAqB,EAAE,EAAE,OAAO,CAAC,CACpD,CAAC;YACF,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,SAAS;gBAAE,OAAO,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,KAAK,CAAC,YAAY,CAAC,WAAmB,EAAE,KAAa;QACnD,IAAI,IAAI,GAA2B,EAAE,CAAC;QACtC,IAAI,CAAC;YACH,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,qBAAqB,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC;QACzE,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QACrC,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,qBAAqB,EAAE,CAAC,EAAE;YACpD,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;QACH,MAAM,EAAE,CAAC,SAAS,CAAC,qBAAqB,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IAC7E,CAAC;IACD,KAAK,CAAC,eAAe,CACnB,YAAoB,EACpB,QAAgB;QAEhB,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CACrB,MAAM,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC,YAAY,CAAC,EAAE,OAAO,CAAC,CACnE,CAAC;YACF,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,SAAS;gBAAE,OAAO,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAClE,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,KAAK,CAAC,eAAe,CAAC,YAAoB,EAAE,QAAgB,EAAE,KAAa;QACzE,IAAI,IAAI,GAA2B,EAAE,CAAC;QACtC,IAAI,CAAC;YACH,IAAI,GAAG,IAAI,CAAC,KAAK,CACf,MAAM,EAAE,CAAC,QAAQ,CAAC,wBAAwB,CAAC,YAAY,CAAC,EAAE,OAAO,CAAC,CACnE,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QAClC,MAAM,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAAC,EAAE;YACnE,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;QACH,MAAM,EAAE,CAAC,SAAS,CAChB,wBAAwB,CAAC,YAAY,CAAC,EACtC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EACpB,OAAO,CACR,CAAC;IACJ,CAAC;IACD,KAAK,CAAC,sBAAsB,CAC1B,YAAoB,EACpB,WAAmB;QAEnB,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CACrB,MAAM,EAAE,CAAC,QAAQ,CACf,+BAA+B,CAAC,YAAY,CAAC,EAC7C,OAAO,CACR,CACF,CAAC;YACF,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,SAAS;gBAAE,OAAO,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,KAAK,CAAC,sBAAsB,CAC1B,YAAoB,EACpB,WAAmB,EACnB,KAAa;QAEb,IAAI,IAAI,GAA2B,EAAE,CAAC;QACtC,IAAI,CAAC;YACH,IAAI,GAAG,IAAI,CAAC,KAAK,CACf,MAAM,EAAE,CAAC,QAAQ,CACf,+BAA+B,CAAC,YAAY,CAAC,EAC7C,OAAO,CACR,CACF,CAAC;QACJ,CAAC;QAAC,MAAM,CAAC;YACP,YAAY;QACd,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QACrC,MAAM,EAAE,CAAC,KAAK,CACZ,IAAI,CAAC,OAAO,CAAC,+BAA+B,CAAC,YAAY,CAAC,CAAC,EAC3D;YACE,SAAS,EAAE,IAAI;SAChB,CACF,CAAC;QACF,MAAM,EAAE,CAAC,SAAS,CAChB,+BAA+B,CAAC,YAAY,CAAC,EAC7C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EACpB,OAAO,CACR,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,EACxC,WAAmB,EACF,EAAE;IACnB,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;IACrD,IAAI,MAAM,KAAK,IAAI;QAAE,OAAO,MAAM,CAAC;IACnC,MAAM,SAAS,GAAG,MAAM,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAExD,MAAM,KAAK,CAAC,YAAY,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IAEjD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAUF,MAAM,CAAC,MAAM,wBAAwB,GAAG,KAAK,EAC3C,IAAkC,EACjB,EAAE;IACnB,MAAM,EACJ,YAAY,EACZ,eAAe,EACf,eAAe,EACf,mBAAmB,EACnB,mBAAmB,GACpB,GAAG,IAAI,CAAC;IAET,MAAM,QAAQ,GAAG,GAAG,eAAe,IAAI,eAAe,EAAE,CAAC;IACzD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,eAAe,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;IACnE,IAAI,MAAM,KAAK,IAAI;QAAE,OAAO,MAAM,CAAC;IAEnC,MAAM,aAAa,GAAG,MAAM,qBAAqB,CAAC,eAAe,CAAC,CAAC;IACnE,MAAM,aAAa,GAAG,MAAM,qBAAqB,CAAC,eAAe,CAAC,CAAC;IAEnE,MAAM,MAAM,GAAG,qBAAqB,CAAC;QACnC,aAAa;QACb,aAAa;QACb,UAAU,EAAE,mBAAmB;QAC/B,UAAU,EAAE,mBAAmB;KAChC,CAAC,CAAC;IAEH,MAAM,KAAK,CAAC,eAAe,CAAC,YAAY,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;IAC5D,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
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
|
+
nodeOperatorDisbursableFee: bigint;
|
|
10
|
+
totalMintingCapacityStethWei: bigint;
|
|
11
|
+
unsettledLidoFees: bigint;
|
|
12
|
+
};
|
|
13
|
+
export declare const calculateOverviewV2: (args: OverviewArgs) => {
|
|
14
|
+
healthRatio: number;
|
|
15
|
+
isHealthy: boolean;
|
|
16
|
+
availableToWithdrawal: bigint;
|
|
17
|
+
idleCapital: bigint;
|
|
18
|
+
totalLocked: bigint;
|
|
19
|
+
collateral: bigint;
|
|
20
|
+
recentlyRepaid: bigint;
|
|
21
|
+
utilizationRatio: number;
|
|
22
|
+
reserved: bigint;
|
|
23
|
+
totalMintingCapacityStethWei: bigint;
|
|
24
|
+
};
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { parseEther } from 'viem';
|
|
2
|
+
import { calculateHealth } from './health/calculate-health.js';
|
|
3
|
+
const BASIS_POINTS = 10000n;
|
|
4
|
+
const bigIntMax = (...args) => args.reduce((a, b) => (a > b ? a : b));
|
|
5
|
+
const bigIntMin = (...args) => args.reduce((a, b) => (a < b ? a : b));
|
|
6
|
+
/**
|
|
7
|
+
* Performs division with rounding up (ceiling division) for bigint values
|
|
8
|
+
* @param numerator - The dividend
|
|
9
|
+
* @param denominator - The divisor
|
|
10
|
+
* @returns The result of division rounded up
|
|
11
|
+
*/
|
|
12
|
+
const ceilDiv = (numerator, denominator) => {
|
|
13
|
+
const result = numerator / denominator;
|
|
14
|
+
return numerator % denominator === 0n ? result : result + 1n;
|
|
15
|
+
};
|
|
16
|
+
export const calculateOverviewV2 = (args) => {
|
|
17
|
+
const { totalValue, reserveRatioBP, liabilitySharesInStethWei, forceRebalanceThresholdBP, withdrawableEther, balance, locked, nodeOperatorDisbursableFee, totalMintingCapacityStethWei, unsettledLidoFees, } = args;
|
|
18
|
+
const { healthRatio, isHealthy } = calculateHealth({
|
|
19
|
+
totalValue,
|
|
20
|
+
liabilitySharesInStethWei,
|
|
21
|
+
forceRebalanceThresholdBP,
|
|
22
|
+
});
|
|
23
|
+
const availableToWithdrawal = withdrawableEther;
|
|
24
|
+
const idleCapital = balance;
|
|
25
|
+
const totalLocked = locked + nodeOperatorDisbursableFee + unsettledLidoFees;
|
|
26
|
+
const RR = BigInt(reserveRatioBP);
|
|
27
|
+
const oneMinusRR = BASIS_POINTS - RR;
|
|
28
|
+
const liabilityDivOneMinusRR = oneMinusRR === 0n
|
|
29
|
+
? 0n
|
|
30
|
+
: ceilDiv(liabilitySharesInStethWei * BASIS_POINTS, oneMinusRR);
|
|
31
|
+
const collateral = bigIntMax(parseEther('1'), liabilityDivOneMinusRR);
|
|
32
|
+
const recentlyRepaid = liabilityDivOneMinusRR <= parseEther('1')
|
|
33
|
+
? bigIntMax(locked - parseEther('1'), 0n)
|
|
34
|
+
: bigIntMax(locked - liabilityDivOneMinusRR, 0n);
|
|
35
|
+
const reservedByFormula = oneMinusRR === 0n
|
|
36
|
+
? 0n
|
|
37
|
+
: ceilDiv(liabilitySharesInStethWei * BASIS_POINTS, oneMinusRR) -
|
|
38
|
+
liabilitySharesInStethWei;
|
|
39
|
+
const reserved = bigIntMin(totalValue - liabilitySharesInStethWei, reservedByFormula);
|
|
40
|
+
// Prevent division by 0
|
|
41
|
+
const utilizationRatio = totalMintingCapacityStethWei === 0n
|
|
42
|
+
? 0
|
|
43
|
+
: Number(((liabilitySharesInStethWei * BASIS_POINTS) /
|
|
44
|
+
totalMintingCapacityStethWei) *
|
|
45
|
+
100n) / Number(BASIS_POINTS);
|
|
46
|
+
return {
|
|
47
|
+
healthRatio,
|
|
48
|
+
isHealthy,
|
|
49
|
+
availableToWithdrawal,
|
|
50
|
+
idleCapital,
|
|
51
|
+
totalLocked,
|
|
52
|
+
collateral,
|
|
53
|
+
recentlyRepaid,
|
|
54
|
+
utilizationRatio,
|
|
55
|
+
reserved,
|
|
56
|
+
totalMintingCapacityStethWei,
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
//# 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,28 @@
|
|
|
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 formatBP: (bp: number | bigint) => string;
|
|
13
|
+
export declare const formatRatio: (r: number) => string;
|
|
14
|
+
export declare const calculateOverview: (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
|
+
totalReservable: bigint;
|
|
24
|
+
reserved: bigint;
|
|
25
|
+
totalMintingCapacityStethWei: bigint;
|
|
26
|
+
remainingMintingCapacity: bigint;
|
|
27
|
+
};
|
|
28
|
+
export {};
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { parseEther } from 'viem';
|
|
2
|
+
import { calculateHealth } from './health/calculate-health.js';
|
|
3
|
+
import { BASIS_POINTS_DENOMINATOR, SCALING_FACTOR } from './consts.js';
|
|
4
|
+
const bigIntMax = (...args) => args.reduce((a, b) => (a > b ? a : b));
|
|
5
|
+
const bigIntMin = (...args) => args.reduce((a, b) => (a < b ? a : b));
|
|
6
|
+
// Percent helper (basis points → percentage)
|
|
7
|
+
export const formatBP = (bp) => `${((Number(bp) / Number(BASIS_POINTS_DENOMINATOR)) * 100).toFixed(2)}%`;
|
|
8
|
+
export const formatRatio = (r) => isFinite(r) ? `${r.toFixed(4)}%` : '∞';
|
|
9
|
+
export const calculateOverview = (args) => {
|
|
10
|
+
const { totalValue, reserveRatioBP, liabilitySharesInStethWei, forceRebalanceThresholdBP, withdrawableEther, balance, locked, nodeOperatorUnclaimedFee, totalMintingCapacityStethWei, } = args;
|
|
11
|
+
const { healthRatio, isHealthy } = calculateHealth({
|
|
12
|
+
totalValue,
|
|
13
|
+
liabilitySharesInStethWei,
|
|
14
|
+
forceRebalanceThresholdBP,
|
|
15
|
+
});
|
|
16
|
+
const AvailableToWithdrawal = withdrawableEther;
|
|
17
|
+
const idleCapital = balance;
|
|
18
|
+
// TODO: add Lido Unclaimed Fees
|
|
19
|
+
const totalLocked = locked + nodeOperatorUnclaimedFee;
|
|
20
|
+
// ---------- Computed values ---------- //
|
|
21
|
+
const totalReservable = (totalValue * BigInt(reserveRatioBP)) / BASIS_POINTS_DENOMINATOR;
|
|
22
|
+
// Prevent division by 0
|
|
23
|
+
const utilizationRatio = totalMintingCapacityStethWei === 0n
|
|
24
|
+
? 0
|
|
25
|
+
: Number(((liabilitySharesInStethWei * SCALING_FACTOR) /
|
|
26
|
+
totalMintingCapacityStethWei) *
|
|
27
|
+
100n) / Number(SCALING_FACTOR);
|
|
28
|
+
const reservedRaw = totalMintingCapacityStethWei === 0n
|
|
29
|
+
? 0n
|
|
30
|
+
: (liabilitySharesInStethWei * totalReservable * SCALING_FACTOR) /
|
|
31
|
+
totalMintingCapacityStethWei;
|
|
32
|
+
const reserved = bigIntMax(bigIntMax(reservedRaw / SCALING_FACTOR, totalValue - liabilitySharesInStethWei), 0n);
|
|
33
|
+
const collateral = bigIntMin(bigIntMax(liabilitySharesInStethWei + reserved, parseEther('1')), totalValue);
|
|
34
|
+
const PendingUnlock = locked - nodeOperatorUnclaimedFee - liabilitySharesInStethWei - reserved <
|
|
35
|
+
parseEther('1')
|
|
36
|
+
? 0n
|
|
37
|
+
: locked -
|
|
38
|
+
nodeOperatorUnclaimedFee -
|
|
39
|
+
liabilitySharesInStethWei -
|
|
40
|
+
reserved;
|
|
41
|
+
const remainingMintingCapacity = totalMintingCapacityStethWei - liabilitySharesInStethWei;
|
|
42
|
+
return {
|
|
43
|
+
healthRatio,
|
|
44
|
+
isHealthy,
|
|
45
|
+
AvailableToWithdrawal,
|
|
46
|
+
idleCapital,
|
|
47
|
+
totalLocked,
|
|
48
|
+
collateral,
|
|
49
|
+
PendingUnlock,
|
|
50
|
+
utilizationRatio,
|
|
51
|
+
totalReservable,
|
|
52
|
+
reserved,
|
|
53
|
+
totalMintingCapacityStethWei,
|
|
54
|
+
remainingMintingCapacity,
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=calculate-overview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calculate-overview.js","sourceRoot":"","sources":["../../utils/calculate-overview.ts"],"names":[],"mappings":"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"}
|
|
@@ -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
|
+
carrySpreadChart: {
|
|
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, carrySpreadChart, bottomLineChart, lidoAPRChart, }: any) => void;
|
|
98
|
+
export {};
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import blessed from 'blessed';
|
|
2
|
+
import contrib from 'blessed-contrib';
|
|
3
|
+
import { callReadMethodSilent, cache, getVaultReportHistory } from '../../index.js';
|
|
4
|
+
import { getDashboardContract } from '../../../contracts/index.js';
|
|
5
|
+
import { lineOpts, getMinMax } from './utils.js';
|
|
6
|
+
import { LIMIT } from './constants.js';
|
|
7
|
+
import { prepareCarrySpread, prepareBottomLine, prepareGrossStakingAPR, prepareLidoAPR, prepareNetStakingAPR, buildLidoAPRChart, buildNetStakingAPRChart, buildCarrySpreadChart, buildBottomLineChart, buildGrossStakingAPRChart, } from './datasets/index.js';
|
|
8
|
+
// Reports rework - adding inOutDelta
|
|
9
|
+
const MIN_REPORT_TIMESTAMP = 1750699020;
|
|
10
|
+
export const fetchAprChartsData = async ({ cid, dashboard, limit = LIMIT, cacheUse = true, }) => {
|
|
11
|
+
const dashboardContract = getDashboardContract(dashboard);
|
|
12
|
+
const vault = await callReadMethodSilent(dashboardContract, 'stakingVault');
|
|
13
|
+
const history = await getVaultReportHistory({
|
|
14
|
+
vault,
|
|
15
|
+
cid,
|
|
16
|
+
limit,
|
|
17
|
+
minTimestamp: MIN_REPORT_TIMESTAMP,
|
|
18
|
+
direction: 'asc',
|
|
19
|
+
}, cacheUse);
|
|
20
|
+
if (!history || history.length < 2)
|
|
21
|
+
throw new Error('Not enough data');
|
|
22
|
+
// Get nodeOperatorFeeBP for each report block with caching
|
|
23
|
+
const nodeOperatorFeeBPs = [];
|
|
24
|
+
for (const r of history) {
|
|
25
|
+
let fee = await cache.getNodeOperatorFeeRate(vault, r.blockNumber);
|
|
26
|
+
if (fee === null) {
|
|
27
|
+
fee = await callReadMethodSilent(dashboardContract, 'nodeOperatorFeeRate', {
|
|
28
|
+
blockNumber: BigInt(r.blockNumber),
|
|
29
|
+
});
|
|
30
|
+
await cache.setNodeOperatorFeeRate(vault, r.blockNumber, fee);
|
|
31
|
+
}
|
|
32
|
+
nodeOperatorFeeBPs.push(fee);
|
|
33
|
+
}
|
|
34
|
+
const grossStakingAPR = prepareGrossStakingAPR(history);
|
|
35
|
+
const netStakingAPR = prepareNetStakingAPR(history, nodeOperatorFeeBPs);
|
|
36
|
+
const carrySpread = await prepareCarrySpread(history, nodeOperatorFeeBPs, vault);
|
|
37
|
+
const bottomLine = await prepareBottomLine(history, nodeOperatorFeeBPs, vault);
|
|
38
|
+
const lidoAPR = await prepareLidoAPR(history);
|
|
39
|
+
const grossStakingAPRChart = buildGrossStakingAPRChart(grossStakingAPR);
|
|
40
|
+
const netStakingAPRChart = buildNetStakingAPRChart(netStakingAPR);
|
|
41
|
+
const carrySpreadChart = buildCarrySpreadChart(carrySpread);
|
|
42
|
+
const bottomLineChart = buildBottomLineChart(bottomLine);
|
|
43
|
+
const lidoAPRChart = buildLidoAPRChart(lidoAPR);
|
|
44
|
+
return {
|
|
45
|
+
grossStakingAPRChart,
|
|
46
|
+
netStakingAPRChart,
|
|
47
|
+
carrySpreadChart,
|
|
48
|
+
bottomLineChart,
|
|
49
|
+
lidoAPRChart,
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
export const renderAprCharts = ({ grossStakingAPRChart, netStakingAPRChart, carrySpreadChart, bottomLineChart, lidoAPRChart, }) => {
|
|
53
|
+
const screen = blessed.screen({
|
|
54
|
+
smartCSR: true,
|
|
55
|
+
title: 'Vault Metrics Charts',
|
|
56
|
+
});
|
|
57
|
+
const grid = new contrib.grid({ rows: 3, cols: 2, screen });
|
|
58
|
+
const charts = [
|
|
59
|
+
grid.set(0, 0, 1, 1, contrib.line, lineOpts({
|
|
60
|
+
title: grossStakingAPRChart.dataset.title,
|
|
61
|
+
label: grossStakingAPRChart.dataset.label,
|
|
62
|
+
yLabel: grossStakingAPRChart.dataset.yLabel,
|
|
63
|
+
range: grossStakingAPRChart.range,
|
|
64
|
+
})),
|
|
65
|
+
grid.set(0, 1, 1, 1, contrib.line, lineOpts({
|
|
66
|
+
title: netStakingAPRChart.dataset.title,
|
|
67
|
+
label: netStakingAPRChart.dataset.label,
|
|
68
|
+
yLabel: netStakingAPRChart.dataset.yLabel,
|
|
69
|
+
range: netStakingAPRChart.range,
|
|
70
|
+
})),
|
|
71
|
+
grid.set(1, 0, 1, 1, contrib.line, lineOpts({
|
|
72
|
+
title: carrySpreadChart.dataset.title,
|
|
73
|
+
label: carrySpreadChart.dataset.label,
|
|
74
|
+
yLabel: carrySpreadChart.dataset.yLabel,
|
|
75
|
+
range: carrySpreadChart.range,
|
|
76
|
+
})),
|
|
77
|
+
grid.set(1, 1, 1, 1, contrib.line, lineOpts({
|
|
78
|
+
title: bottomLineChart.dataset.title,
|
|
79
|
+
label: bottomLineChart.dataset.label,
|
|
80
|
+
yLabel: bottomLineChart.dataset.yLabel,
|
|
81
|
+
range: bottomLineChart.range,
|
|
82
|
+
})),
|
|
83
|
+
grid.set(2, 0, 1, 1, contrib.line, lineOpts({
|
|
84
|
+
title: lidoAPRChart.dataset.title,
|
|
85
|
+
label: lidoAPRChart.dataset.label,
|
|
86
|
+
yLabel: lidoAPRChart.dataset.yLabel,
|
|
87
|
+
range: lidoAPRChart.range,
|
|
88
|
+
})),
|
|
89
|
+
grid.set(2, 1, 1, 1, contrib.line, lineOpts({
|
|
90
|
+
title: lidoAPRChart.dataset.title,
|
|
91
|
+
label: lidoAPRChart.dataset.label,
|
|
92
|
+
yLabel: lidoAPRChart.dataset.yLabel,
|
|
93
|
+
range: getMinMax([
|
|
94
|
+
...netStakingAPRChart.dataset.y,
|
|
95
|
+
...lidoAPRChart.dataset.y,
|
|
96
|
+
]),
|
|
97
|
+
})),
|
|
98
|
+
];
|
|
99
|
+
const datasets = [
|
|
100
|
+
grossStakingAPRChart.dataset,
|
|
101
|
+
netStakingAPRChart.dataset,
|
|
102
|
+
carrySpreadChart.dataset,
|
|
103
|
+
bottomLineChart.dataset,
|
|
104
|
+
lidoAPRChart.dataset,
|
|
105
|
+
[netStakingAPRChart.dataset, lidoAPRChart.dataset],
|
|
106
|
+
];
|
|
107
|
+
charts.forEach((chart, i) => {
|
|
108
|
+
if (chart.type === 'stackedBar' || chart.type === 'bar') {
|
|
109
|
+
chart.setData(datasets[i]);
|
|
110
|
+
}
|
|
111
|
+
else if (Array.isArray(datasets[i])) {
|
|
112
|
+
chart.setData(datasets[i]);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
chart.setData([datasets[i]]);
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
screen.key(['escape', 'q', 'C-c'], () => process.exit(0));
|
|
119
|
+
screen.render();
|
|
120
|
+
};
|
|
121
|
+
//# sourceMappingURL=charts-apr.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"charts-apr.js","sourceRoot":"","sources":["../../../../utils/charts/blessed/charts-apr.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
type FetchRewardsChartsDataArgs = {
|
|
3
|
+
cid: string;
|
|
4
|
+
dashboard: Address;
|
|
5
|
+
limit?: number;
|
|
6
|
+
cacheUse?: boolean;
|
|
7
|
+
};
|
|
8
|
+
export declare const fetchRewardsChartsData: ({ cid, dashboard, limit, cacheUse, }: FetchRewardsChartsDataArgs) => Promise<{
|
|
9
|
+
grossStakingRewardsChart: {
|
|
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
|
+
bar: {
|
|
26
|
+
data: {
|
|
27
|
+
barCategory: string[];
|
|
28
|
+
y: number[];
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
nodeOperatorRewardsChart: {
|
|
33
|
+
range: {
|
|
34
|
+
min: number;
|
|
35
|
+
max: number;
|
|
36
|
+
minY: number;
|
|
37
|
+
maxY: number;
|
|
38
|
+
};
|
|
39
|
+
dataset: {
|
|
40
|
+
title: string;
|
|
41
|
+
label: string;
|
|
42
|
+
x: string[];
|
|
43
|
+
y: number[];
|
|
44
|
+
style: {
|
|
45
|
+
line: number[];
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
bar: {
|
|
49
|
+
data: {
|
|
50
|
+
barCategory: string[];
|
|
51
|
+
y: number[];
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
};
|
|
55
|
+
netStakingRewardsChart: {
|
|
56
|
+
range: {
|
|
57
|
+
min: number;
|
|
58
|
+
max: number;
|
|
59
|
+
minY: number;
|
|
60
|
+
maxY: number;
|
|
61
|
+
};
|
|
62
|
+
dataset: {
|
|
63
|
+
title: string;
|
|
64
|
+
label: string;
|
|
65
|
+
x: string[];
|
|
66
|
+
y: number[];
|
|
67
|
+
style: {
|
|
68
|
+
line: number[];
|
|
69
|
+
};
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
}>;
|
|
73
|
+
export declare const renderRewardsCharts: ({ grossStakingRewardsChart, nodeOperatorRewardsChart, netStakingRewardsChart, }: any) => void;
|
|
74
|
+
export {};
|