@lidofinance/lsv-cli 1.0.0-alpha.6 → 1.0.0-alpha.60
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/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 +604 -0
- package/dist/abi/LazyOracle.js +782 -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 +530 -0
- package/dist/abi/VaultViewer.js +695 -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 +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/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 +9075 -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 +62 -0
- package/dist/features/vault-operations/vault-roles.js.map +1 -0
- package/dist/features/vault-operations/vaults-by-role.d.ts +3 -0
- package/dist/features/vault-operations/vaults-by-role.js +46 -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 +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/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 +621 -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 +8 -0
- package/dist/programs/contracts/index.js +9 -0
- package/dist/programs/contracts/index.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 +181 -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 +116 -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 +198 -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 +6897 -0
- package/dist/providers/wallet.js +44 -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 +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/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 +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 +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 +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 +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 +118 -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/contract.d.ts +59 -0
- package/dist/utils/contract.js +214 -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 +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 +33 -0
- package/dist/utils/index.js +33 -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 +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/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 +36 -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 +132 -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 +51 -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 +10 -0
- package/dist/utils/timestamp.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 +77 -19
- package/dist/programs/vault-hub.js +0 -137
- package/dist/programs/vault-hub.js.map +0 -1
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { describe, test, expect, jest, beforeEach } from '@jest/globals';
|
|
2
|
+
jest.mock('../../utils/logging/constants.js', () => ({
|
|
3
|
+
getColoredLog: (_t, m) => m,
|
|
4
|
+
TABLE_PARAMS: {},
|
|
5
|
+
}));
|
|
6
|
+
import { createConsole } from '../../utils/logging/console.js';
|
|
7
|
+
beforeEach(() => {
|
|
8
|
+
jest.spyOn(console, 'info').mockImplementation(() => { });
|
|
9
|
+
jest.spyOn(console, 'error').mockImplementation(() => { });
|
|
10
|
+
});
|
|
11
|
+
describe('createConsole', () => {
|
|
12
|
+
test('logs info', () => {
|
|
13
|
+
const log = createConsole('LOG');
|
|
14
|
+
log('hello');
|
|
15
|
+
expect(console.info).toHaveBeenCalled();
|
|
16
|
+
});
|
|
17
|
+
test('logs error', () => {
|
|
18
|
+
const err = createConsole('Error', 'error');
|
|
19
|
+
err('oops');
|
|
20
|
+
expect(console.error).toHaveBeenCalled();
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
//# sourceMappingURL=logging.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logging.test.js","sourceRoot":"","sources":["../../../tests/utils/logging.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACzE,IAAI,CAAC,IAAI,CAAC,kCAAkC,EAAE,GAAG,EAAE,CAAC,CAAC;IACnD,aAAa,EAAE,CAAC,EAAO,EAAE,CAAM,EAAE,EAAE,CAAC,CAAC;IACrC,YAAY,EAAE,EAAE;CACjB,CAAC,CAAC,CAAC;AACJ,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAE/D,UAAU,CAAC,GAAG,EAAE;IACd,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACzD,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,kBAAkB,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;AAC5D,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE;QACrB,MAAM,GAAG,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;QACjC,GAAG,CAAC,OAAO,CAAC,CAAC;QACb,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,YAAY,EAAE,GAAG,EAAE;QACtB,MAAM,GAAG,GAAG,aAAa,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAC5C,GAAG,CAAC,MAAM,CAAC,CAAC;QACZ,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { describe, expect, test } from '@jest/globals';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import { homedir } from 'os';
|
|
4
|
+
import { resolvePath } from '../../utils/resolve-path.js';
|
|
5
|
+
describe('resolvePath', () => {
|
|
6
|
+
test('resolves relative path', () => {
|
|
7
|
+
const rel = 'folder/file';
|
|
8
|
+
expect(resolvePath(rel)).toBe(path.resolve(rel));
|
|
9
|
+
});
|
|
10
|
+
test('returns absolute path as is', () => {
|
|
11
|
+
const abs = path.resolve('file');
|
|
12
|
+
expect(resolvePath(abs)).toBe(abs);
|
|
13
|
+
});
|
|
14
|
+
test('expands tilde to home directory', () => {
|
|
15
|
+
expect(resolvePath('~/test')).toBe(path.join(homedir(), 'test'));
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
//# sourceMappingURL=resove-path.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resove-path.test.js","sourceRoot":"","sources":["../../../tests/utils/resove-path.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,OAAO,EAAE,MAAM,IAAI,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAE1D,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,IAAI,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAClC,MAAM,GAAG,GAAG,aAAa,CAAC;QAC1B,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6BAA6B,EAAE,GAAG,EAAE;QACvC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACjC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC3C,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { describe, test, expect, jest } from '@jest/globals';
|
|
2
|
+
import { sleep } from '../../utils/sleep.js';
|
|
3
|
+
describe('sleep', () => {
|
|
4
|
+
test('waits specified time', async () => {
|
|
5
|
+
jest.useFakeTimers();
|
|
6
|
+
const spy = jest.fn();
|
|
7
|
+
const p = sleep(500).then(spy);
|
|
8
|
+
jest.advanceTimersByTime(500);
|
|
9
|
+
await p;
|
|
10
|
+
expect(spy).toHaveBeenCalled();
|
|
11
|
+
jest.useRealTimers();
|
|
12
|
+
});
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=sleep.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sleep.test.js","sourceRoot":"","sources":["../../../tests/utils/sleep.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAE7C,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE;IACrB,IAAI,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;QACtC,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;QACtB,MAAM,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/B,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAC9B,MAAM,CAAC,CAAC;QACR,MAAM,CAAC,GAAG,CAAC,CAAC,gBAAgB,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Address, Hex } from 'viem';
|
|
2
|
+
export interface VaultWithDashboard {
|
|
3
|
+
defaultAdmin: Address;
|
|
4
|
+
nodeOperator: Address;
|
|
5
|
+
nodeOperatorManager: Address;
|
|
6
|
+
nodeOperatorFeeRate: bigint;
|
|
7
|
+
confirmExpiry: bigint;
|
|
8
|
+
}
|
|
9
|
+
export interface Permit {
|
|
10
|
+
value: bigint;
|
|
11
|
+
deadline: bigint;
|
|
12
|
+
v: number;
|
|
13
|
+
r: Address;
|
|
14
|
+
s: Address;
|
|
15
|
+
}
|
|
16
|
+
export interface RoleAssignment {
|
|
17
|
+
account: Address;
|
|
18
|
+
role: `0x${string}`;
|
|
19
|
+
}
|
|
20
|
+
export interface Tier {
|
|
21
|
+
operator: Address;
|
|
22
|
+
shareLimit: bigint;
|
|
23
|
+
minDepositAmount: bigint;
|
|
24
|
+
reserveRatioBP: bigint;
|
|
25
|
+
forcedRebalanceThresholdBP: bigint;
|
|
26
|
+
infraFeeBP: bigint;
|
|
27
|
+
liquidityFeeBP: bigint;
|
|
28
|
+
reservationFeeBP: bigint;
|
|
29
|
+
}
|
|
30
|
+
export type Deposit = {
|
|
31
|
+
pubkey: Hex;
|
|
32
|
+
signature: Hex;
|
|
33
|
+
amount: bigint;
|
|
34
|
+
depositDataRoot: Hex;
|
|
35
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../types/common.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
export interface Config {
|
|
3
|
+
DEPLOYED: string;
|
|
4
|
+
EL_URL?: string;
|
|
5
|
+
CL_URL?: string;
|
|
6
|
+
PRIVATE_KEY?: string;
|
|
7
|
+
ACCOUNT_FILE?: string;
|
|
8
|
+
ACCOUNT_FILE_PASSWORD?: string;
|
|
9
|
+
CHAIN_ID: number;
|
|
10
|
+
TOKEN_MANAGER?: Address;
|
|
11
|
+
VOTING?: Address;
|
|
12
|
+
}
|
|
13
|
+
export type Vote = readonly [
|
|
14
|
+
boolean,
|
|
15
|
+
boolean,
|
|
16
|
+
bigint,
|
|
17
|
+
bigint,
|
|
18
|
+
bigint,
|
|
19
|
+
bigint,
|
|
20
|
+
bigint,
|
|
21
|
+
bigint,
|
|
22
|
+
bigint,
|
|
23
|
+
`0x${string}`,
|
|
24
|
+
number
|
|
25
|
+
];
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../types/config.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../types/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Permit, RoleAssignment, Tier, Deposit } from '../types/index.js';
|
|
2
|
+
import { Address } from 'viem';
|
|
3
|
+
export declare const stringToBigIntArray: (value: string) => bigint[];
|
|
4
|
+
export declare const stringToBigIntArrayWei: (value: string) => bigint[];
|
|
5
|
+
export declare const stringToHexArray: (value: string) => `0x${string}`[];
|
|
6
|
+
export declare const jsonToPermit: (value: string) => Permit;
|
|
7
|
+
export declare const jsonToRoleAssignment: (value: string) => RoleAssignment[];
|
|
8
|
+
export declare const stringToBigInt: (value: string) => bigint;
|
|
9
|
+
export declare const stringToNumberArray: (value: string) => number[];
|
|
10
|
+
export declare const etherToWei: (value: string) => bigint;
|
|
11
|
+
export declare const stringToNumber: (value: string) => number;
|
|
12
|
+
export declare const parseTiers: (value: string) => Tier[];
|
|
13
|
+
export declare const parseTier: (value: string) => Tier;
|
|
14
|
+
export declare const parseDepositArray: (str: string) => Deposit[];
|
|
15
|
+
export declare const stringToAddress: (value: string) => Address;
|
|
@@ -0,0 +1,73 @@
|
|
|
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 stringToNumberArray = (value) => {
|
|
24
|
+
return value.split(',').map(Number);
|
|
25
|
+
};
|
|
26
|
+
export const etherToWei = (value) => {
|
|
27
|
+
return parseEther(value, 'wei');
|
|
28
|
+
};
|
|
29
|
+
export const stringToNumber = (value) => {
|
|
30
|
+
if (isNaN(Number(value)) || Number(value) < 0) {
|
|
31
|
+
program.error('value must be a positive number', { exitCode: 1 });
|
|
32
|
+
}
|
|
33
|
+
return parseInt(value);
|
|
34
|
+
};
|
|
35
|
+
export const parseTiers = (value) => {
|
|
36
|
+
return JSON.parse(value);
|
|
37
|
+
};
|
|
38
|
+
export const parseTier = (value) => {
|
|
39
|
+
return JSON.parse(value);
|
|
40
|
+
};
|
|
41
|
+
export const parseDepositArray = (str) => {
|
|
42
|
+
const trimmed = str.trim();
|
|
43
|
+
if (!trimmed) {
|
|
44
|
+
return [];
|
|
45
|
+
}
|
|
46
|
+
const parsed = JSON.parse(trimmed, (key, value) => {
|
|
47
|
+
if (key === '')
|
|
48
|
+
return value; // root array
|
|
49
|
+
if (key === 'amount')
|
|
50
|
+
return BigInt(value) * BigInt(10 ** 9); // to wei
|
|
51
|
+
if (typeof value === 'string') {
|
|
52
|
+
return toHex(value);
|
|
53
|
+
}
|
|
54
|
+
return value;
|
|
55
|
+
});
|
|
56
|
+
// Convert keys to camelCase
|
|
57
|
+
const camelCased = parsed.map((obj) => {
|
|
58
|
+
const newObj = {};
|
|
59
|
+
for (const key in obj) {
|
|
60
|
+
const camelKey = toCamelCase(key);
|
|
61
|
+
newObj[camelKey] = obj[key];
|
|
62
|
+
}
|
|
63
|
+
return newObj;
|
|
64
|
+
});
|
|
65
|
+
return camelCased;
|
|
66
|
+
};
|
|
67
|
+
export const stringToAddress = (value) => {
|
|
68
|
+
if (!isAddress(value)) {
|
|
69
|
+
program.error('Address value must be a valid address', { exitCode: 1 });
|
|
70
|
+
}
|
|
71
|
+
return value;
|
|
72
|
+
};
|
|
73
|
+
//# 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
|
+
getNodeOperatorFeeRate(vaultAddress: string, blockNumber: number): Promise<bigint | null>;
|
|
7
|
+
setNodeOperatorFeeRate(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 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":"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"}
|
|
@@ -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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"}
|