@lidofinance/lsv-cli 1.0.0-alpha.8 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +1 -1
- package/README.md +49 -232
- 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 +2542 -0
- package/dist/abi/Dashboard.js +1699 -971
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.d.ts +843 -0
- package/dist/abi/LazyOracle.js +1091 -0
- package/dist/abi/LazyOracle.js.map +1 -0
- package/dist/abi/LidoLocator.d.ts +386 -0
- package/dist/abi/LidoLocator.js +383 -273
- package/dist/abi/LidoLocator.js.map +1 -1
- package/dist/abi/OperatorGrid.d.ts +1973 -0
- package/dist/abi/OperatorGrid.js +1574 -0
- package/dist/abi/OperatorGrid.js.map +1 -0
- package/dist/abi/PredepositGuarantee.d.ts +1710 -0
- package/dist/abi/PredepositGuarantee.js +2004 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -0
- package/dist/abi/StEth.d.ts +372 -0
- package/dist/abi/StEth.js +342 -345
- package/dist/abi/StEth.js.map +1 -1
- package/dist/abi/StakingVault.d.ts +901 -0
- package/dist/abi/StakingVault.js +712 -547
- package/dist/abi/StakingVault.js.map +1 -1
- package/dist/abi/VaultFactory.d.ts +1147 -0
- package/dist/abi/VaultFactory.js +252 -171
- package/dist/abi/VaultFactory.js.map +1 -1
- package/dist/abi/VaultHub.d.ts +2538 -0
- package/dist/abi/VaultHub.js +2226 -845
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +649 -0
- package/dist/abi/VaultViewer.js +847 -0
- package/dist/abi/VaultViewer.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 +12 -0
- package/dist/abi/index.js +12 -25
- package/dist/abi/index.js.map +1 -1
- package/dist/command/index.d.ts +2 -0
- package/dist/command/index.js +9 -21
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +35 -0
- package/dist/configs/constants.js +2 -5
- package/dist/configs/constants.js.map +1 -1
- package/dist/configs/deployed.d.ts +17 -0
- package/dist/configs/deployed.js +67 -126
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/envs.d.ts +2 -0
- package/dist/configs/envs.js +13 -45
- package/dist/configs/envs.js.map +1 -1
- package/dist/configs/index.d.ts +3 -0
- package/dist/configs/index.js +3 -19
- package/dist/configs/index.js.map +1 -1
- package/dist/configs/utils.d.ts +4 -0
- package/dist/configs/utils.js +13 -23
- package/dist/configs/utils.js.map +1 -1
- package/dist/contracts/dashboard.d.ts +4 -0
- package/dist/contracts/dashboard.js +7 -15
- package/dist/contracts/dashboard.js.map +1 -1
- package/dist/contracts/index.d.ts +11 -0
- package/dist/contracts/index.js +11 -25
- 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 +9655 -0
- package/dist/contracts/locator.js +11 -15
- package/dist/contracts/locator.js.map +1 -1
- 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 +14 -15
- package/dist/contracts/steth.js.map +1 -1
- package/dist/contracts/vault-factory.d.ts +27674 -0
- package/dist/contracts/vault-factory.js +11 -19
- package/dist/contracts/vault-factory.js.map +1 -1
- package/dist/contracts/vault-hub.d.ts +3 -0
- package/dist/contracts/vault-hub.js +13 -17
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +11789 -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 +7 -14
- package/dist/contracts/vault.js.map +1 -1
- 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 +11 -0
- package/dist/features/index.js +11 -19
- package/dist/features/index.js.map +1 -1
- package/dist/features/lazy-oracle.d.ts +1 -0
- package/dist/features/lazy-oracle.js +42 -0
- package/dist/features/lazy-oracle.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 +5 -4
- package/dist/features/token-manager.js.map +1 -1
- 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 +6 -0
- package/dist/features/utils/index.js +7 -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/utils/settled-growth.d.ts +1 -0
- package/dist/features/utils/settled-growth.js +16 -0
- package/dist/features/utils/settled-growth.js.map +1 -0
- package/dist/features/vault-factory.d.ts +29 -0
- package/dist/features/vault-factory.js +88 -25
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-hub.d.ts +2 -0
- package/dist/features/vault-hub.js +84 -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 +12 -0
- package/dist/features/vault-operations/dashboard-by-vault.js +36 -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 +108 -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 +150 -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 +50 -0
- package/dist/features/vault.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +26 -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 +12 -14
- package/dist/programs/config.js.map +1 -1
- package/dist/programs/contracts/dashboard/config.d.ts +3 -0
- package/dist/programs/contracts/dashboard/config.js +120 -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 +133 -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 +723 -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 +155 -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 +363 -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 +62 -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 +24 -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 +98 -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 +50 -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 +161 -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 +167 -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 +53 -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 +325 -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 +54 -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 +278 -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 +15 -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 -22
- 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 +94 -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 +202 -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 +240 -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 +111 -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 +99 -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 +133 -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 +315 -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 +63 -29
- 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 +39 -0
- package/dist/types/common.js +1 -2
- package/dist/types/config.d.ts +26 -0
- package/dist/types/config.js +1 -2
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.js +2 -18
- package/dist/types/index.js.map +1 -1
- package/dist/utils/arguments.d.ts +17 -0
- package/dist/utils/arguments.js +112 -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 +27 -0
- package/dist/utils/calculate-overview-v2.js +56 -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 +122 -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 +107 -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 +79 -0
- package/dist/utils/charts/simple/simple-charts.js.map +1 -0
- package/dist/utils/commands/confirmations.d.ts +39 -0
- package/dist/utils/commands/confirmations.js +127 -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 +43 -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 +28 -25
- package/dist/utils/data-validators.js.map +1 -1
- 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 +75 -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 -20
- 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 +134 -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 +60 -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 +9 -12
- package/dist/utils/resolve-path.js.map +1 -1
- 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 +1 -5
- package/dist/utils/sleep.js.map +1 -1
- 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 +124 -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 +187 -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 +88 -13
- package/dist/abi/Delegation.js +0 -1658
- package/dist/abi/Delegation.js.map +0 -1
- package/dist/abi/TokenManager.js +0 -759
- package/dist/abi/TokenManager.js.map +0 -1
- package/dist/abi/Voting.js +0 -887
- package/dist/abi/Voting.js.map +0 -1
- package/dist/contracts/delegation.js +0 -19
- package/dist/contracts/delegation.js.map +0 -1
- package/dist/contracts/token-manager.js +0 -20
- package/dist/contracts/token-manager.js.map +0 -1
- package/dist/contracts/voting.js +0 -22
- package/dist/contracts/voting.js.map +0 -1
- package/dist/features/advanced-config.js +0 -21
- package/dist/features/advanced-config.js.map +0 -1
- package/dist/features/voting.js +0 -136
- package/dist/features/voting.js.map +0 -1
- package/dist/programs/dashboard.js +0 -688
- package/dist/programs/dashboard.js.map +0 -1
- package/dist/programs/delegation.js +0 -539
- package/dist/programs/delegation.js.map +0 -1
- package/dist/programs/vault-factory.js +0 -84
- package/dist/programs/vault-factory.js.map +0 -1
- package/dist/programs/vault-hub.js +0 -352
- package/dist/programs/vault-hub.js.map +0 -1
- package/dist/programs/vault.js +0 -378
- package/dist/programs/vault.js.map +0 -1
- package/dist/programs/voting.js +0 -53
- package/dist/programs/voting.js.map +0 -1
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
// Console line chart for metrics
|
|
2
|
+
const ALMOST_ZERO_THRESHOLD = 1e-6;
|
|
3
|
+
// Returns min and max for an array, with a fallback if all values are equal
|
|
4
|
+
const getMinMax = function (values) {
|
|
5
|
+
let min = Math.min(...values);
|
|
6
|
+
let max = Math.max(...values);
|
|
7
|
+
if (min === max) {
|
|
8
|
+
min -= 1;
|
|
9
|
+
max += 1;
|
|
10
|
+
}
|
|
11
|
+
return { min, max };
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* Draws a line chart in the console for a given array of values.
|
|
15
|
+
* If all values are almost the same or close to zero, draws a single line in the center.
|
|
16
|
+
*/
|
|
17
|
+
export const logLineChart = function (values, { label, height = 15, width = 60, valueLabel = '', timeLabels, pointSpacing = 3, }) {
|
|
18
|
+
if (values.length === 0) {
|
|
19
|
+
console.info(`${label}: No data`);
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const { min, max } = getMinMax(values);
|
|
23
|
+
const range = max - min;
|
|
24
|
+
const step = Math.max(1, Math.floor(values.length / width));
|
|
25
|
+
const points = values.filter((_, i) => i % step === 0);
|
|
26
|
+
const chartWidth = points.length * pointSpacing - (pointSpacing - 1);
|
|
27
|
+
const isAllAlmostZero = values.every((v) => Math.abs(v) < ALMOST_ZERO_THRESHOLD);
|
|
28
|
+
// Helper to create an empty chart
|
|
29
|
+
const createEmptyChart = () => Array.from({ length: height }, () => Array.from({ length: chartWidth }, () => ' '));
|
|
30
|
+
let chart;
|
|
31
|
+
if (range < ALMOST_ZERO_THRESHOLD || isAllAlmostZero) {
|
|
32
|
+
// Draw a single line in the center if all values are almost the same or close to zero
|
|
33
|
+
const center = Math.floor((height - 1) / 2);
|
|
34
|
+
chart = createEmptyChart();
|
|
35
|
+
for (let x = 0; x < points.length; x++) {
|
|
36
|
+
const x0 = x * pointSpacing;
|
|
37
|
+
if (chart[center] && x0 < chart[center].length)
|
|
38
|
+
chart[center][x0] = '•';
|
|
39
|
+
}
|
|
40
|
+
console.info('(all values ≈ 0, center line)');
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
// Normal mode: scale values to chart height
|
|
44
|
+
const scaled = points.map((v) => Math.round(((v - min) / (max - min)) * (height - 1)));
|
|
45
|
+
chart = createEmptyChart();
|
|
46
|
+
for (let x = 1; x < points.length; x++) {
|
|
47
|
+
const x0 = (x - 1) * pointSpacing;
|
|
48
|
+
const x1 = x * pointSpacing;
|
|
49
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
50
|
+
const y0 = height - 1 - scaled[x - 1];
|
|
51
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
52
|
+
const y1 = height - 1 - scaled[x];
|
|
53
|
+
if (chart[y0] && y0 >= 0 && y0 < height && x0 < chart[y0].length)
|
|
54
|
+
chart[y0][x0] = '•';
|
|
55
|
+
// Draw a line between points
|
|
56
|
+
const dx = x1 - x0;
|
|
57
|
+
const dy = y1 - y0;
|
|
58
|
+
const steps = Math.max(Math.abs(dx), Math.abs(dy));
|
|
59
|
+
for (let s = 1; s <= steps; s++) {
|
|
60
|
+
const y = Math.round(y0 + (dy * s) / steps);
|
|
61
|
+
const xi = x0 + Math.round((dx * s) / steps);
|
|
62
|
+
if (chart[y] &&
|
|
63
|
+
y >= 0 &&
|
|
64
|
+
y < height &&
|
|
65
|
+
xi >= 0 &&
|
|
66
|
+
xi < chart[y].length) {
|
|
67
|
+
chart[y][xi] = '•';
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
// Draw the last point
|
|
72
|
+
const lastX = (points.length - 1) * pointSpacing;
|
|
73
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
74
|
+
const lastY = height - 1 - scaled[points.length - 1];
|
|
75
|
+
if (chart[lastY] &&
|
|
76
|
+
lastY >= 0 &&
|
|
77
|
+
lastY < height &&
|
|
78
|
+
lastX < chart[lastY].length)
|
|
79
|
+
chart[lastY][lastX] = '•';
|
|
80
|
+
}
|
|
81
|
+
// Convert chart to string rows
|
|
82
|
+
const chartRows = chart.map((row) => row.join(''));
|
|
83
|
+
console.info(`${label}${valueLabel ? ' (' + valueLabel + ')' : ''}`);
|
|
84
|
+
for (let i = 0; i < height; i++) {
|
|
85
|
+
const yValue = max - ((max - min) * i) / (height - 1);
|
|
86
|
+
console.info(`${yValue.toFixed(2).padStart(8)} | ${chartRows[i]}`);
|
|
87
|
+
}
|
|
88
|
+
// X axis
|
|
89
|
+
if (chart[0] && chart[0].length > 0) {
|
|
90
|
+
console.info(' ' + '-'.repeat(chart[0].length));
|
|
91
|
+
let axisRow = ' ';
|
|
92
|
+
for (let i = 0; i < points.length; i++) {
|
|
93
|
+
axisRow += '|'.padEnd(pointSpacing, ' ');
|
|
94
|
+
}
|
|
95
|
+
console.info(axisRow);
|
|
96
|
+
}
|
|
97
|
+
// Time or index labels
|
|
98
|
+
if (timeLabels && timeLabels.length > 0) {
|
|
99
|
+
const labelStep = Math.ceil(points.length / 6); // max 6 labels
|
|
100
|
+
let timeRow = ' ';
|
|
101
|
+
for (let i = 0; i < points.length; i++) {
|
|
102
|
+
if (i % labelStep === 0 && timeLabels[i * step]) {
|
|
103
|
+
const label = timeLabels[i * step]?.slice(0, pointSpacing * 2 - 1);
|
|
104
|
+
timeRow += label?.padEnd(pointSpacing, ' ');
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
timeRow += ''.padEnd(pointSpacing, ' ');
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
console.info(timeRow);
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
let idxRow = ' ';
|
|
114
|
+
for (let i = 0; i < points.length; i++) {
|
|
115
|
+
idxRow += (i % 5 === 0 ? String(i).padStart(2, ' ') : ' ').padEnd(pointSpacing, ' ');
|
|
116
|
+
}
|
|
117
|
+
console.info(idxRow);
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
export const logGrossStakingAPRChart = function (values, timeLabels, pointSpacing = 3) {
|
|
121
|
+
logLineChart(values, {
|
|
122
|
+
label: 'Gross Staking APR',
|
|
123
|
+
valueLabel: '%',
|
|
124
|
+
height: 15,
|
|
125
|
+
width: 60,
|
|
126
|
+
timeLabels,
|
|
127
|
+
pointSpacing,
|
|
128
|
+
});
|
|
129
|
+
};
|
|
130
|
+
export const logNetStakingAPRChart = function (values, timeLabels, pointSpacing = 3) {
|
|
131
|
+
logLineChart(values, {
|
|
132
|
+
label: 'Net Staking APR',
|
|
133
|
+
valueLabel: '%',
|
|
134
|
+
height: 15,
|
|
135
|
+
width: 60,
|
|
136
|
+
timeLabels,
|
|
137
|
+
pointSpacing,
|
|
138
|
+
});
|
|
139
|
+
};
|
|
140
|
+
export const logBottomLineChart = function (values, timeLabels, pointSpacing = 3) {
|
|
141
|
+
logLineChart(values, {
|
|
142
|
+
label: 'Bottom Line',
|
|
143
|
+
valueLabel: 'ETH',
|
|
144
|
+
height: 15,
|
|
145
|
+
width: 60,
|
|
146
|
+
timeLabels,
|
|
147
|
+
pointSpacing,
|
|
148
|
+
});
|
|
149
|
+
};
|
|
150
|
+
export const logCarrySpreadChart = function (values, timeLabels, pointSpacing = 3) {
|
|
151
|
+
logLineChart(values, {
|
|
152
|
+
label: 'Carry Spread',
|
|
153
|
+
valueLabel: '%',
|
|
154
|
+
height: 15,
|
|
155
|
+
width: 60,
|
|
156
|
+
timeLabels,
|
|
157
|
+
pointSpacing,
|
|
158
|
+
});
|
|
159
|
+
};
|
|
160
|
+
//# sourceMappingURL=metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../../utils/charts/metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
interface LiabilityOverview {
|
|
2
|
+
totalValue: bigint;
|
|
3
|
+
stETHLiability: bigint;
|
|
4
|
+
reserveRatioBP: number;
|
|
5
|
+
forcedRebalanceThresholdBP: number;
|
|
6
|
+
stETHTotalMintingCapacity: bigint;
|
|
7
|
+
}
|
|
8
|
+
export declare const logLiabilityBar: (data: LiabilityOverview, barLength?: number) => void;
|
|
9
|
+
export declare const logVaultHealthBar: (healthFactor: number) => void;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
export const logLiabilityBar = (data, barLength = 68) => {
|
|
3
|
+
const totalValueEth = parseFloat(formatEther(data.totalValue));
|
|
4
|
+
const liabilitySteth = parseFloat(formatEther(data.stETHLiability));
|
|
5
|
+
const totalMintingCapacitySteth = parseFloat(formatEther(data.stETHTotalMintingCapacity));
|
|
6
|
+
const liabilityPercentage = liabilitySteth / totalValueEth;
|
|
7
|
+
const reserveRatioPercentage = data.reserveRatioBP / 10000;
|
|
8
|
+
const rebalanceThresholdPercentage = data.forcedRebalanceThresholdBP / 10000;
|
|
9
|
+
const totalMintingCapacityPercentage = totalMintingCapacitySteth / totalValueEth;
|
|
10
|
+
const positions = {
|
|
11
|
+
liabilityEnd: Math.round(liabilityPercentage * barLength),
|
|
12
|
+
RR: barLength - Math.round(reserveRatioPercentage * barLength),
|
|
13
|
+
FR: barLength - Math.round(rebalanceThresholdPercentage * barLength),
|
|
14
|
+
TMC: Math.round(totalMintingCapacityPercentage * barLength),
|
|
15
|
+
};
|
|
16
|
+
const barArray = ['['];
|
|
17
|
+
for (let i = 0; i < barLength; i++) {
|
|
18
|
+
if (i === positions.TMC || i === positions.FR || i === positions.RR)
|
|
19
|
+
barArray.push('|');
|
|
20
|
+
else if (i < positions.liabilityEnd)
|
|
21
|
+
barArray.push('=');
|
|
22
|
+
else
|
|
23
|
+
barArray.push('-');
|
|
24
|
+
}
|
|
25
|
+
barArray.push(']');
|
|
26
|
+
const bar = barArray.join('');
|
|
27
|
+
const labels = Array.from({ length: barLength + 2 }).fill(' ');
|
|
28
|
+
const collisions = [];
|
|
29
|
+
const setLabel = (pos, char) => {
|
|
30
|
+
if (labels[pos] === ' ')
|
|
31
|
+
labels[pos] = char;
|
|
32
|
+
else {
|
|
33
|
+
const existingChar = labels[pos];
|
|
34
|
+
labels[pos] = 'X';
|
|
35
|
+
collisions.push(`${existingChar}/${char}`);
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
setLabel(positions.FR + 1, 'F');
|
|
39
|
+
setLabel(positions.RR + 1, 'R');
|
|
40
|
+
setLabel(positions.TMC + 1, 'T');
|
|
41
|
+
console.info(labels.join(''));
|
|
42
|
+
console.info(bar);
|
|
43
|
+
console.info(` ${'^'.repeat(positions.liabilityEnd)} Liability\n`);
|
|
44
|
+
console.info(`Liability: ${(liabilityPercentage * 100).toFixed(2)}%`);
|
|
45
|
+
console.info(`R - Reserve ratio: ${(reserveRatioPercentage * 100).toFixed(0)}%`);
|
|
46
|
+
console.info(`F - Forced rebalance threshold: ${(rebalanceThresholdPercentage * 100).toFixed(0)}%`);
|
|
47
|
+
console.info(`T - Total minting capacity: ${(totalMintingCapacityPercentage * 100).toFixed(0)}%`);
|
|
48
|
+
if (collisions.length > 0) {
|
|
49
|
+
console.info(`X - Collisions: ${collisions.join(', ')} (positions coincide)`);
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
const VAULT_HEALTH_PERCENT_GREEN = 125;
|
|
53
|
+
const VAULT_HEALTH_PERCENT_YELLOW = 105;
|
|
54
|
+
const VAULT_HEALTH_PERCENT_RED = 100;
|
|
55
|
+
export const logVaultHealthBar = (healthFactor) => {
|
|
56
|
+
const totalBarLength = 25;
|
|
57
|
+
const maxHealthFactor = 200;
|
|
58
|
+
const filledLength = Math.round((healthFactor / maxHealthFactor) * totalBarLength);
|
|
59
|
+
let bar = '[';
|
|
60
|
+
for (let i = 0; i < totalBarLength; i++) {
|
|
61
|
+
const positionPercentage = (i / totalBarLength) * maxHealthFactor;
|
|
62
|
+
if (i >= filledLength) {
|
|
63
|
+
bar += '·'; // unfilled
|
|
64
|
+
}
|
|
65
|
+
else if (positionPercentage >= VAULT_HEALTH_PERCENT_GREEN) {
|
|
66
|
+
bar += '█'; // green zone
|
|
67
|
+
}
|
|
68
|
+
else if (positionPercentage >= VAULT_HEALTH_PERCENT_YELLOW) {
|
|
69
|
+
bar += '▓'; // yellow zone
|
|
70
|
+
}
|
|
71
|
+
else if (positionPercentage >= VAULT_HEALTH_PERCENT_RED) {
|
|
72
|
+
bar += '▒'; // red zone
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
bar += '░'; // critical zone below 100%
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
bar += ']';
|
|
79
|
+
const statusEmoji = healthFactor >= VAULT_HEALTH_PERCENT_GREEN
|
|
80
|
+
? '🟢'
|
|
81
|
+
: healthFactor >= VAULT_HEALTH_PERCENT_YELLOW
|
|
82
|
+
? '🟡'
|
|
83
|
+
: healthFactor >= VAULT_HEALTH_PERCENT_RED
|
|
84
|
+
? '🔴'
|
|
85
|
+
: '🔥';
|
|
86
|
+
console.info('Vault Health');
|
|
87
|
+
console.info(`${bar} ${healthFactor}% ${statusEmoji}`);
|
|
88
|
+
};
|
|
89
|
+
//# sourceMappingURL=overview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"overview.js","sourceRoot":"","sources":["../../../utils/charts/overview.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './simple-charts.js';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../utils/charts/simple/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
import { getDashboardContract } from '../../../contracts/index.js';
|
|
3
|
+
import { logError, logInfo, callReadMethodSilent, getVaultReportHistory, cache, getGrossStakingAPR, getGrossStakingRewards, getNetStakingAPR, getCarrySpread, getBottomLine, getRebaseRewardFromCache, formatTimestamp, } from '../../index.js';
|
|
4
|
+
import { logGrossStakingAPRChart, logNetStakingAPRChart, logCarrySpreadChart, logBottomLineChart, } from '../metrics.js';
|
|
5
|
+
// TODO: Refactor this file
|
|
6
|
+
// Render simple charts for APR metrics
|
|
7
|
+
export const renderSimpleCharts = async ({ dashboard, cid, limit = 20, cacheUse = true, }) => {
|
|
8
|
+
const dashboardContract = getDashboardContract(dashboard);
|
|
9
|
+
const vault = await callReadMethodSilent(dashboardContract, 'stakingVault');
|
|
10
|
+
logInfo(`\n=== Getting report history for vault ${vault} (CID: ${cid}) ===\n`);
|
|
11
|
+
let history;
|
|
12
|
+
try {
|
|
13
|
+
history = await getVaultReportHistory({
|
|
14
|
+
vault,
|
|
15
|
+
cid,
|
|
16
|
+
limit,
|
|
17
|
+
direction: 'asc',
|
|
18
|
+
}, cacheUse);
|
|
19
|
+
}
|
|
20
|
+
catch (e) {
|
|
21
|
+
logError('Error getting report history:', e);
|
|
22
|
+
process.exit(1);
|
|
23
|
+
}
|
|
24
|
+
if (!history || history.length < 2) {
|
|
25
|
+
logError('Not enough data for plotting (at least 2 reports needed)');
|
|
26
|
+
process.exit(1);
|
|
27
|
+
}
|
|
28
|
+
// Calculate metrics for each pair (current, previous)
|
|
29
|
+
const grossStakingAPRPercent = [];
|
|
30
|
+
const netStakingAPRPercent = [];
|
|
31
|
+
const carrySpreadPercent = [];
|
|
32
|
+
const bottomLine = [];
|
|
33
|
+
// TODO: log chart
|
|
34
|
+
// eslint-disable-next-line sonarjs/no-unused-collection
|
|
35
|
+
const grossStakingRewards = [];
|
|
36
|
+
const timeLabels = [];
|
|
37
|
+
// Get nodeOperatorFeeBP for each report block with caching
|
|
38
|
+
const nodeOperatorFeeBPs = [];
|
|
39
|
+
for (const r of history) {
|
|
40
|
+
let fee = await cache.getNodeOperatorFeeRate(vault, r.blockNumber);
|
|
41
|
+
if (fee === null) {
|
|
42
|
+
const feeRate = await callReadMethodSilent(dashboardContract, 'feeRate', {
|
|
43
|
+
blockNumber: BigInt(r.blockNumber),
|
|
44
|
+
});
|
|
45
|
+
fee = BigInt(feeRate);
|
|
46
|
+
await cache.setNodeOperatorFeeRate(vault, r.blockNumber, fee);
|
|
47
|
+
}
|
|
48
|
+
nodeOperatorFeeBPs.push(fee);
|
|
49
|
+
}
|
|
50
|
+
for (let i = 1; i < history.length; i++) {
|
|
51
|
+
const current = history[i];
|
|
52
|
+
const previous = history[i - 1];
|
|
53
|
+
if (!current || !previous)
|
|
54
|
+
continue;
|
|
55
|
+
const stEthLiabilityRebaseRewards = await getRebaseRewardFromCache({
|
|
56
|
+
vaultAddress: vault,
|
|
57
|
+
blockNumberCurr: current.blockNumber,
|
|
58
|
+
blockNumberPrev: previous.blockNumber,
|
|
59
|
+
liabilitySharesCurr: BigInt(current.data.liabilityShares),
|
|
60
|
+
liabilitySharesPrev: BigInt(previous.data.liabilityShares),
|
|
61
|
+
});
|
|
62
|
+
grossStakingRewards.push(Number(formatEther(getGrossStakingRewards(current, previous), 'gwei')));
|
|
63
|
+
grossStakingAPRPercent.push(getGrossStakingAPR(current, previous).apr_percent);
|
|
64
|
+
netStakingAPRPercent.push(getNetStakingAPR(current, previous, nodeOperatorFeeBPs[i] ?? 0n)
|
|
65
|
+
.apr_percent);
|
|
66
|
+
carrySpreadPercent.push(getCarrySpread(current, previous, nodeOperatorFeeBPs[i] ?? 0n, stEthLiabilityRebaseRewards).apr_percent);
|
|
67
|
+
bottomLine.push(Number(getBottomLine(current, previous, nodeOperatorFeeBPs[i] ?? 0n, stEthLiabilityRebaseRewards)));
|
|
68
|
+
timeLabels.push(formatTimestamp(current.timestamp, 'dd.mm hh:mm'));
|
|
69
|
+
}
|
|
70
|
+
logGrossStakingAPRChart(grossStakingAPRPercent, timeLabels);
|
|
71
|
+
logInfo('\n');
|
|
72
|
+
logNetStakingAPRChart(netStakingAPRPercent, timeLabels);
|
|
73
|
+
logInfo('\n');
|
|
74
|
+
logCarrySpreadChart(carrySpreadPercent, timeLabels);
|
|
75
|
+
logInfo('\n');
|
|
76
|
+
logBottomLineChart(bottomLine, timeLabels);
|
|
77
|
+
logInfo('\n');
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=simple-charts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"simple-charts.js","sourceRoot":"","sources":["../../../../utils/charts/simple/simple-charts.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Address, type Hex, type GetContractReturnType, WalletClient, Abi } from 'viem';
|
|
2
|
+
import { AccessControlConfirmableAbi } from '../../abi/index.js';
|
|
3
|
+
type FunctionArgsMap = {
|
|
4
|
+
setConfirmExpiry: readonly [bigint];
|
|
5
|
+
setNodeOperatorFeeRate: readonly [bigint];
|
|
6
|
+
changeTier: readonly [Address, bigint, bigint];
|
|
7
|
+
transferVaultOwnership: readonly [Address];
|
|
8
|
+
};
|
|
9
|
+
export declare const CONFIRM_METHODS_MAP: {
|
|
10
|
+
readonly setConfirmExpiry: (args: FunctionArgsMap["setConfirmExpiry"]) => string;
|
|
11
|
+
readonly setNodeOperatorFeeRate: (args: FunctionArgsMap["setNodeOperatorFeeRate"]) => string;
|
|
12
|
+
readonly changeTier: (args: FunctionArgsMap["changeTier"]) => string;
|
|
13
|
+
readonly transferVaultOwnership: (args: FunctionArgsMap["transferVaultOwnership"]) => string;
|
|
14
|
+
};
|
|
15
|
+
type FunctionName = keyof typeof CONFIRM_METHODS_MAP;
|
|
16
|
+
type DecodedData = {
|
|
17
|
+
[K in FunctionName]: {
|
|
18
|
+
functionName: K;
|
|
19
|
+
args: FunctionArgsMap[K];
|
|
20
|
+
};
|
|
21
|
+
}[FunctionName];
|
|
22
|
+
type ConfirmationsInfo = {
|
|
23
|
+
member: Address;
|
|
24
|
+
roleOrAddress: Hex;
|
|
25
|
+
expiryTimestamp: bigint;
|
|
26
|
+
expiryDate: string;
|
|
27
|
+
data: Hex;
|
|
28
|
+
decodedData: DecodedData;
|
|
29
|
+
};
|
|
30
|
+
export type LogsData = Record<Hex, ConfirmationsInfo>;
|
|
31
|
+
type ConfirmationContract = GetContractReturnType<typeof AccessControlConfirmableAbi, WalletClient>;
|
|
32
|
+
export declare const formatConfirmationArgs: (args: readonly [bigint] | readonly [Address, bigint, bigint] | readonly [Address], functionName: FunctionName) => string;
|
|
33
|
+
export declare const getConfirmationsInfo: <T extends ConfirmationContract>(contract: T, abi: Abi) => Promise<LogsData | undefined>;
|
|
34
|
+
export declare const confirmProposal: <T extends ConfirmationContract>({ contract, additionalContracts, vault, }: {
|
|
35
|
+
contract: T;
|
|
36
|
+
additionalContracts?: T[];
|
|
37
|
+
vault?: Address;
|
|
38
|
+
}) => Promise<ConfirmationsInfo | undefined>;
|
|
39
|
+
export {};
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { decodeFunctionData, formatEther, } from 'viem';
|
|
2
|
+
import { getPublicClient } from '../../providers/index.js';
|
|
3
|
+
import { confirmOperation, formatBP, selectProposalEvent } from '../index.js';
|
|
4
|
+
const AVG_BLOCK_TIME_SEC = 12n;
|
|
5
|
+
// Type-safe function map
|
|
6
|
+
export const CONFIRM_METHODS_MAP = {
|
|
7
|
+
setConfirmExpiry: (args) => `${Number(args[0]) / 3600} hours`,
|
|
8
|
+
setNodeOperatorFeeRate: (args) => formatBP(args[0]),
|
|
9
|
+
changeTier: (args) => `vault: ${args[0]}, tier: ${args[1]}, requested share limit: ${formatEther(args[2])} shares`,
|
|
10
|
+
transferVaultOwnership: (args) => `new owner: ${args[0]}`,
|
|
11
|
+
};
|
|
12
|
+
export const formatConfirmationArgs = (args, functionName) => {
|
|
13
|
+
switch (functionName) {
|
|
14
|
+
case 'setConfirmExpiry':
|
|
15
|
+
return CONFIRM_METHODS_MAP.setConfirmExpiry(args);
|
|
16
|
+
case 'setNodeOperatorFeeRate':
|
|
17
|
+
return CONFIRM_METHODS_MAP.setNodeOperatorFeeRate(args);
|
|
18
|
+
case 'changeTier':
|
|
19
|
+
return CONFIRM_METHODS_MAP.changeTier(args);
|
|
20
|
+
case 'transferVaultOwnership':
|
|
21
|
+
return CONFIRM_METHODS_MAP.transferVaultOwnership(args);
|
|
22
|
+
default:
|
|
23
|
+
throw new Error(`Unknown function: ${functionName}`);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
export const getConfirmationsInfo = async (contract, abi) => {
|
|
27
|
+
const publicClient = getPublicClient();
|
|
28
|
+
const confirmExpire = await contract.read.getConfirmExpiry();
|
|
29
|
+
const currentBlock = await publicClient.getBlockNumber();
|
|
30
|
+
const confirmExpireInBlocks = confirmExpire / AVG_BLOCK_TIME_SEC;
|
|
31
|
+
const logs = await publicClient.getContractEvents({
|
|
32
|
+
address: contract.address,
|
|
33
|
+
abi: contract.abi,
|
|
34
|
+
eventName: 'RoleMemberConfirmed',
|
|
35
|
+
fromBlock: currentBlock - confirmExpireInBlocks,
|
|
36
|
+
strict: true,
|
|
37
|
+
});
|
|
38
|
+
if (logs.length === 0) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const logsData = logs
|
|
42
|
+
.sort((a, b) => Number(a.blockNumber - b.blockNumber))
|
|
43
|
+
.reduce((acc, log) => {
|
|
44
|
+
const { args } = log;
|
|
45
|
+
const decodedData = decodeFunctionData({
|
|
46
|
+
abi,
|
|
47
|
+
data: args.data,
|
|
48
|
+
});
|
|
49
|
+
acc[args.data] = {
|
|
50
|
+
member: args.member,
|
|
51
|
+
roleOrAddress: args.roleOrAddress,
|
|
52
|
+
expiryTimestamp: args.expiryTimestamp,
|
|
53
|
+
expiryDate: new Date(Number(args.expiryTimestamp) * 1000).toLocaleString(),
|
|
54
|
+
data: args.data,
|
|
55
|
+
decodedData,
|
|
56
|
+
};
|
|
57
|
+
return acc;
|
|
58
|
+
}, {});
|
|
59
|
+
await Promise.all(Object.entries(logsData).map(async ([data, { roleOrAddress }]) => {
|
|
60
|
+
const confirmations = await contract.read.confirmation([
|
|
61
|
+
data,
|
|
62
|
+
roleOrAddress,
|
|
63
|
+
]);
|
|
64
|
+
if (confirmations === 0n)
|
|
65
|
+
delete logsData[data];
|
|
66
|
+
}));
|
|
67
|
+
return logsData;
|
|
68
|
+
};
|
|
69
|
+
const filterLogsByVault = (logsData, vault) => {
|
|
70
|
+
if (!vault)
|
|
71
|
+
return logsData;
|
|
72
|
+
const entries = Object.entries(logsData).filter(([, info]) => {
|
|
73
|
+
const { decodedData } = info;
|
|
74
|
+
switch (decodedData.functionName) {
|
|
75
|
+
case 'changeTier':
|
|
76
|
+
case 'transferVaultOwnership': {
|
|
77
|
+
const argVault = decodedData.args[0];
|
|
78
|
+
return argVault.toLowerCase() === vault.toLowerCase();
|
|
79
|
+
}
|
|
80
|
+
default:
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
return entries.reduce((acc, [key, value]) => {
|
|
85
|
+
acc[key] = value;
|
|
86
|
+
return acc;
|
|
87
|
+
}, {});
|
|
88
|
+
};
|
|
89
|
+
export const confirmProposal = async ({ contract, additionalContracts, vault, }) => {
|
|
90
|
+
const logsData = await getConfirmationsInfo(contract, contract.abi);
|
|
91
|
+
const additionalLogsData = await Promise.all(additionalContracts?.map((additionalContract) => getConfirmationsInfo(additionalContract, additionalContract.abi)) ?? []);
|
|
92
|
+
if (!logsData && additionalLogsData.length === 0)
|
|
93
|
+
return;
|
|
94
|
+
const allLogsData = {
|
|
95
|
+
...(logsData ?? {}),
|
|
96
|
+
...additionalLogsData.reduce((acc, curr) => ({ ...acc, ...curr }), {}),
|
|
97
|
+
};
|
|
98
|
+
if (Object.keys(allLogsData).length === 0) {
|
|
99
|
+
console.error('No proposals found');
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
const filteredLogsData = filterLogsByVault(allLogsData, vault);
|
|
103
|
+
if (Object.keys(filteredLogsData).length === 0) {
|
|
104
|
+
console.error('No proposals found for the specified vault');
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
const answer = await selectProposalEvent(filteredLogsData);
|
|
108
|
+
if (!answer || !answer.event) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
const log = filteredLogsData[answer.event];
|
|
112
|
+
if (!log) {
|
|
113
|
+
console.error('No proposal found');
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
// Type-safe function call using discriminated union
|
|
117
|
+
const formattedArgs = formatConfirmationArgs(log.decodedData.args, log.decodedData.functionName);
|
|
118
|
+
const confirm = await confirmOperation(`Are you sure you want to confirm this proposal?
|
|
119
|
+
${log.decodedData.functionName} (${log.decodedData.args.join(', ')} - ${formattedArgs})
|
|
120
|
+
Member: ${log.member}
|
|
121
|
+
Role/Address: ${log.roleOrAddress}
|
|
122
|
+
Expiry: ${log.expiryDate}`);
|
|
123
|
+
if (!confirm)
|
|
124
|
+
return;
|
|
125
|
+
return log;
|
|
126
|
+
};
|
|
127
|
+
//# sourceMappingURL=confirmations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"confirmations.js","sourceRoot":"","sources":["../../../utils/commands/confirmations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../utils/commands/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,aAAa,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { program } from '../../command/index.js';
|
|
2
|
+
import { getLazyOracleContract, getVaultHubContract } from '../../contracts/index.js';
|
|
3
|
+
import { callReadMethod, callReadMethodSilent, logCancel, callWriteMethodWithReceipt, confirmOperation, getReportProofByVault, } from '../index.js';
|
|
4
|
+
export const submitReport = async ({ vault, gateway, }) => {
|
|
5
|
+
const lazyOracleContract = await getLazyOracleContract();
|
|
6
|
+
const vaultHubContract = await getVaultHubContract();
|
|
7
|
+
const [_vaultsDataTimestamp, _vaultsDataRefSlot, _vaultsDataTreeRoot, vaultsDataReportCid,] = await callReadMethod(lazyOracleContract, 'latestReportData');
|
|
8
|
+
const isReportFresh = await callReadMethodSilent(vaultHubContract, 'isReportFresh', [vault]);
|
|
9
|
+
if (isReportFresh) {
|
|
10
|
+
logCancel('Report is fresh. You dont need to submit it again');
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const { cacheUse } = program.opts();
|
|
14
|
+
const proof = await getReportProofByVault({
|
|
15
|
+
vault,
|
|
16
|
+
cid: vaultsDataReportCid,
|
|
17
|
+
gateway,
|
|
18
|
+
}, cacheUse);
|
|
19
|
+
const confirm = await confirmOperation(`Are you sure you want to submit report for vault ${vault}?
|
|
20
|
+
Total value wei: ${proof.data.totalValueWei}
|
|
21
|
+
Fee: ${proof.data.fee}
|
|
22
|
+
Liability shares: ${proof.data.liabilityShares}
|
|
23
|
+
Slashing reserve: ${proof.data.slashingReserve}
|
|
24
|
+
`);
|
|
25
|
+
if (!confirm) {
|
|
26
|
+
logCancel('Report not submitted');
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
await callWriteMethodWithReceipt({
|
|
30
|
+
contract: lazyOracleContract,
|
|
31
|
+
methodName: 'updateVaultData',
|
|
32
|
+
payload: [
|
|
33
|
+
vault,
|
|
34
|
+
BigInt(proof.data.totalValueWei),
|
|
35
|
+
BigInt(proof.data.fee),
|
|
36
|
+
BigInt(proof.data.liabilityShares),
|
|
37
|
+
BigInt(proof.data.maxLiabilityShares),
|
|
38
|
+
BigInt(proof.data.slashingReserve),
|
|
39
|
+
proof.proof,
|
|
40
|
+
],
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=report.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report.js","sourceRoot":"","sources":["../../../utils/commands/report.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AACvE,OAAO,EACL,cAAc,EACd,oBAAoB,EACpB,SAAS,EACT,0BAA0B,EAC1B,gBAAgB,EAChB,qBAAqB,GACtB,MAAM,OAAO,CAAC;AAOf,MAAM,CAAC,MAAM,YAAY,GAAG,KAAK,EAAE,EACjC,KAAK,EACL,OAAO,GACU,EAAiB,EAAE;IACpC,MAAM,kBAAkB,GAAG,MAAM,qBAAqB,EAAE,CAAC;IACzD,MAAM,gBAAgB,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAErD,MAAM,CACJ,oBAAoB,EACpB,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,EACpB,GAAG,MAAM,cAAc,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;IACjE,MAAM,aAAa,GAAG,MAAM,oBAAoB,CAC9C,gBAAgB,EAChB,eAAe,EACf,CAAC,KAAK,CAAC,CACR,CAAC;IAEF,IAAI,aAAa,EAAE,CAAC;QAClB,SAAS,CAAC,mDAAmD,CAAC,CAAC;QAC/D,OAAO;IACT,CAAC;IAED,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IACpC,MAAM,KAAK,GAAG,MAAM,qBAAqB,CACvC;QACE,KAAK;QACL,GAAG,EAAE,mBAAmB;QACxB,OAAO;KACR,EACD,QAAQ,CACT,CAAC;IAEF,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oDAAoD,KAAK;2BAClC,KAAK,CAAC,IAAI,CAAC,aAAa;eACpC,KAAK,CAAC,IAAI,CAAC,GAAG;4BACD,KAAK,CAAC,IAAI,CAAC,eAAe;4BAC1B,KAAK,CAAC,IAAI,CAAC,eAAe;SAC7C,CACN,CAAC;IACF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,SAAS,CAAC,sBAAsB,CAAC,CAAC;QAClC,OAAO;IACT,CAAC;IAED,MAAM,0BAA0B,CAAC;QAC/B,QAAQ,EAAE,kBAAkB;QAC5B,UAAU,EAAE,iBAAiB;QAC7B,OAAO,EAAE;YACP,KAAK;YACL,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC;YAChC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC;YACtB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;YAClC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC;YACrC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC;YAClC,KAAK,CAAC,KAAK;SACZ;KACF,CAAC,CAAC;AACL,CAAC,CAAC"}
|