@lidofinance/lsv-cli 1.0.0-alpha.60 → 1.0.0-alpha.62
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 +26 -14
- package/dist/abi/Dashboard.d.ts +706 -445
- package/dist/abi/Dashboard.js +331 -300
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.d.ts +286 -47
- package/dist/abi/LazyOracle.js +357 -48
- package/dist/abi/LazyOracle.js.map +1 -1
- package/dist/abi/LidoLocator.d.ts +28 -0
- package/dist/abi/LidoLocator.js +36 -0
- package/dist/abi/LidoLocator.js.map +1 -1
- package/dist/abi/OperatorGrid.d.ts +166 -1
- package/dist/abi/OperatorGrid.js +174 -1
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/PredepositGuarantee.d.ts +181 -139
- package/dist/abi/PredepositGuarantee.js +191 -166
- package/dist/abi/PredepositGuarantee.js.map +1 -1
- package/dist/abi/StEth.d.ts +1 -1
- package/dist/abi/StEth.js +1 -1
- package/dist/abi/StEth.js.map +1 -1
- package/dist/abi/StakingVault.d.ts +184 -32
- package/dist/abi/StakingVault.js +203 -37
- package/dist/abi/StakingVault.js.map +1 -1
- package/dist/abi/VaultFactory.d.ts +470 -72
- package/dist/abi/VaultFactory.js +24 -1
- package/dist/abi/VaultFactory.js.map +1 -1
- package/dist/abi/VaultHub.d.ts +416 -420
- package/dist/abi/VaultHub.js +349 -398
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +215 -96
- package/dist/abi/VaultViewer.js +258 -106
- package/dist/abi/VaultViewer.js.map +1 -1
- package/dist/abi/index.d.ts +0 -2
- package/dist/abi/index.js +0 -2
- package/dist/abi/index.js.map +1 -1
- package/dist/command/index.js +2 -0
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +1 -0
- package/dist/contracts/index.d.ts +0 -1
- package/dist/contracts/index.js +0 -1
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/locator.d.ts +1428 -12
- package/dist/contracts/steth.d.ts +74 -74
- package/dist/contracts/vault-factory.d.ts +15731 -5838
- package/dist/contracts/vault-viewer.d.ts +4458 -1744
- package/dist/contracts/vault-viewer.js +1 -1
- package/dist/features/deposits/no-pdg.js +5 -5
- package/dist/features/deposits/no-pdg.js.map +1 -1
- package/dist/features/index.d.ts +1 -0
- package/dist/features/index.js +1 -0
- 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.js +1 -1
- package/dist/features/mint-burn/allowance.js.map +1 -1
- package/dist/features/utils/get-address.js +1 -1
- package/dist/features/utils/get-address.js.map +1 -1
- package/dist/features/vault-hub.js +0 -4
- package/dist/features/vault-hub.js.map +1 -1
- package/dist/features/vault-operations/create-vault.js +2 -2
- package/dist/features/vault-operations/create-vault.js.map +1 -1
- package/dist/features/vault-operations/dashboard-by-vault.d.ts +2 -1
- package/dist/features/vault-operations/dashboard-by-vault.js +3 -1
- package/dist/features/vault-operations/dashboard-by-vault.js.map +1 -1
- package/dist/features/vault-operations/vault-health.js +2 -2
- package/dist/features/vault-operations/vault-health.js.map +1 -1
- package/dist/features/vault-operations/vault-info.js +29 -32
- package/dist/features/vault-operations/vault-info.js.map +1 -1
- package/dist/features/vault-operations/vault-overview.js +35 -28
- package/dist/features/vault-operations/vault-overview.js.map +1 -1
- package/dist/features/vault-operations/vault-roles.d.ts +1 -1
- package/dist/features/vault-operations/vault-roles.js +10 -8
- package/dist/features/vault-operations/vault-roles.js.map +1 -1
- package/dist/features/vault-operations/vaults-by-role.d.ts +0 -2
- package/dist/features/vault-operations/vaults-by-role.js +8 -6
- package/dist/features/vault-operations/vaults-by-role.js.map +1 -1
- package/dist/features/vault.js +4 -2
- package/dist/features/vault.js.map +1 -1
- package/dist/index.js +8 -3
- package/dist/index.js.map +1 -1
- package/dist/programs/account/read.js +3 -3
- package/dist/programs/account/read.js.map +1 -1
- package/dist/programs/account/write.js +13 -5
- package/dist/programs/account/write.js.map +1 -1
- package/dist/programs/contracts/dashboard/config.js +49 -40
- package/dist/programs/contracts/dashboard/config.js.map +1 -1
- package/dist/programs/contracts/dashboard/read.js +38 -3
- package/dist/programs/contracts/dashboard/read.js.map +1 -1
- package/dist/programs/contracts/dashboard/write.js +128 -74
- package/dist/programs/contracts/dashboard/write.js.map +1 -1
- package/dist/programs/contracts/hub/config.js +7 -17
- package/dist/programs/contracts/hub/config.js.map +1 -1
- package/dist/programs/contracts/hub/write.js +7 -69
- package/dist/programs/contracts/hub/write.js.map +1 -1
- package/dist/programs/contracts/index.d.ts +1 -0
- package/dist/programs/contracts/index.js +1 -0
- package/dist/programs/contracts/index.js.map +1 -1
- 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/operator-grid/config.js +21 -10
- package/dist/programs/contracts/operator-grid/config.js.map +1 -1
- package/dist/programs/contracts/operator-grid/read.js +21 -1
- package/dist/programs/contracts/operator-grid/read.js.map +1 -1
- package/dist/programs/contracts/operator-grid/write.js +51 -9
- package/dist/programs/contracts/operator-grid/write.js.map +1 -1
- package/dist/programs/contracts/pdg/config.js +9 -2
- package/dist/programs/contracts/pdg/config.js.map +1 -1
- package/dist/programs/contracts/pdg/read.js +16 -1
- package/dist/programs/contracts/pdg/read.js.map +1 -1
- package/dist/programs/contracts/pdg/write.js +28 -91
- package/dist/programs/contracts/pdg/write.js.map +1 -1
- package/dist/programs/contracts/vault/config.js +12 -0
- package/dist/programs/contracts/vault/config.js.map +1 -1
- package/dist/programs/contracts/vault/write.js +84 -20
- package/dist/programs/contracts/vault/write.js.map +1 -1
- package/dist/programs/contracts/vault-viewer/read.js +4 -4
- package/dist/programs/contracts/vault-viewer/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/read.js +20 -3
- package/dist/programs/use-cases/deposits/read.js.map +1 -1
- package/dist/programs/use-cases/deposits/write.js +22 -32
- package/dist/programs/use-cases/deposits/write.js.map +1 -1
- package/dist/programs/use-cases/metrics/read.js +70 -11
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/report/read.js +14 -7
- package/dist/programs/use-cases/report/read.js.map +1 -1
- package/dist/programs/use-cases/report/write.js +47 -64
- package/dist/programs/use-cases/report/write.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/create-vault.js +6 -2
- package/dist/programs/use-cases/vault-operations/create-vault.js.map +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +127 -15
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/wallet.d.ts +7690 -23
- package/dist/providers/wallet.js +25 -5
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/utils/calculate-overview.test.js +1 -1
- package/dist/tests/utils/calculate-overview.test.js.map +1 -1
- package/dist/tests/utils/health.test.js +2 -2
- package/dist/tests/utils/health.test.js.map +1 -1
- package/dist/tests/utils/ipfs.test.js +22 -10
- package/dist/tests/utils/ipfs.test.js.map +1 -1
- package/dist/types/common.d.ts +4 -0
- package/dist/types/config.d.ts +1 -0
- package/dist/utils/arguments.d.ts +3 -1
- package/dist/utils/arguments.js +39 -0
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/calculate-overview-v2.d.ts +4 -2
- package/dist/utils/calculate-overview-v2.js +5 -8
- package/dist/utils/calculate-overview-v2.js.map +1 -1
- package/dist/utils/calculate-overview.d.ts +1 -1
- package/dist/utils/calculate-overview.js +2 -2
- package/dist/utils/calculate-overview.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +2 -1
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +2 -1
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +4 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +15 -1
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
- package/dist/utils/charts/overview.d.ts +1 -1
- package/dist/utils/charts/overview.js +1 -1
- package/dist/utils/charts/overview.js.map +1 -1
- package/dist/utils/charts/simple/simple-charts.js +2 -1
- package/dist/utils/charts/simple/simple-charts.js.map +1 -1
- package/dist/utils/commands/confirmations.d.ts +9 -5
- package/dist/utils/commands/confirmations.js +42 -33
- package/dist/utils/commands/confirmations.js.map +1 -1
- package/dist/utils/commands/report.js +2 -1
- package/dist/utils/commands/report.js.map +1 -1
- 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/health/calculate-health.d.ts +1 -1
- package/dist/utils/health/calculate-health.js +2 -2
- package/dist/utils/health/calculate-health.js.map +1 -1
- package/dist/utils/health/health-utils.d.ts +77 -77
- package/dist/utils/health/health-utils.js +11 -10
- package/dist/utils/health/health-utils.js.map +1 -1
- package/dist/utils/index.d.ts +3 -1
- package/dist/utils/index.js +3 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/ipfs.js +1 -1
- package/dist/utils/ipfs.js.map +1 -1
- package/dist/utils/logging/console.d.ts +1 -0
- package/dist/utils/logging/console.js +9 -1
- package/dist/utils/logging/console.js.map +1 -1
- package/dist/utils/report/report-proof.d.ts +3 -0
- package/dist/utils/report/report-proof.js +2 -2
- package/dist/utils/report/report-proof.js.map +1 -1
- package/dist/utils/report/report.d.ts +1 -1
- package/dist/utils/report/report.js +6 -4
- package/dist/utils/report/report.js.map +1 -1
- package/dist/utils/report/statistic-data.js +2 -2
- package/dist/utils/report/statistic-data.js.map +1 -1
- package/dist/utils/report/types.d.ts +11 -2
- package/dist/utils/statistic/report-statistic.js +13 -14
- package/dist/utils/statistic/report-statistic.js.map +1 -1
- package/dist/utils/timestamp.d.ts +1 -1
- package/dist/utils/timestamp.js +9 -2
- package/dist/utils/timestamp.js.map +1 -1
- 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/{contract.js → transactions/tx-private-key.js} +105 -9
- 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.js +1 -1
- package/package.json +19 -5
- package/dist/abi/TokenManager.d.ts +0 -577
- package/dist/abi/TokenManager.js +0 -756
- package/dist/abi/TokenManager.js.map +0 -1
- package/dist/abi/Voting.d.ts +0 -676
- package/dist/abi/Voting.js +0 -884
- package/dist/abi/Voting.js.map +0 -1
- package/dist/contracts/token-manager.d.ts +0 -3
- package/dist/contracts/token-manager.js +0 -13
- package/dist/contracts/token-manager.js.map +0 -1
- package/dist/utils/contract.d.ts +0 -59
- package/dist/utils/contract.js.map +0 -1
|
@@ -3,7 +3,7 @@ import { hoodi } from 'viem/chains';
|
|
|
3
3
|
import { VaultViewerAbi } from '../abi/index.js';
|
|
4
4
|
import { getChain, getElUrl } from '../configs/index.js';
|
|
5
5
|
const VaultViewerAddresses = {
|
|
6
|
-
[hoodi.id]: '
|
|
6
|
+
[hoodi.id]: '0x069f5f448475c843e099198b5e9F9977bF84FDd0',
|
|
7
7
|
};
|
|
8
8
|
export const getVaultViewerContract = () => {
|
|
9
9
|
const chainId = getChain().id;
|
|
@@ -2,7 +2,7 @@ import { formatEther } from 'viem';
|
|
|
2
2
|
import { callReadMethodSilent, confirmOperation, logInfo, numberPrompt, addressPrompt, } from '../../utils/index.js';
|
|
3
3
|
import { getAccount } from '../../providers/index.js';
|
|
4
4
|
export const checkNOBalancePDGforDeposit = async (pdgContract, nodeOperator) => {
|
|
5
|
-
const currentAccount = getAccount();
|
|
5
|
+
const currentAccount = await getAccount();
|
|
6
6
|
const balance = await callReadMethodSilent(pdgContract, 'nodeOperatorBalance', [nodeOperator]);
|
|
7
7
|
const unlockedBalance = await callReadMethodSilent(pdgContract, 'unlockedBalance', [nodeOperator]);
|
|
8
8
|
const nodeOperatorGuarantor = await callReadMethodSilent(pdgContract, 'nodeOperatorGuarantor', [nodeOperator]);
|
|
@@ -38,7 +38,7 @@ export const checkNOBalancePDGforDeposits = async (pdgContract, nodeOperator, co
|
|
|
38
38
|
return { amountToTopUp, isNeedTopUp };
|
|
39
39
|
};
|
|
40
40
|
export const checkNodeOperatorForDeposit = async (vault) => {
|
|
41
|
-
const currentAccount = getAccount();
|
|
41
|
+
const currentAccount = await getAccount();
|
|
42
42
|
const vaultNodeOperator = await callReadMethodSilent(vault, 'nodeOperator');
|
|
43
43
|
if (vaultNodeOperator.toLocaleLowerCase() !==
|
|
44
44
|
currentAccount.address.toLocaleLowerCase()) {
|
|
@@ -47,7 +47,7 @@ export const checkNodeOperatorForDeposit = async (vault) => {
|
|
|
47
47
|
return vaultNodeOperator;
|
|
48
48
|
};
|
|
49
49
|
export const checkAndSpecifyNodeOperatorForTopUpOrWithdraw = async (vault, pdg, isTopUp) => {
|
|
50
|
-
const currentAccount = getAccount();
|
|
50
|
+
const currentAccount = await getAccount();
|
|
51
51
|
const vaultNodeOperator = await callReadMethodSilent(vault, 'nodeOperator');
|
|
52
52
|
const noGuarantor = await callReadMethodSilent(pdg, 'nodeOperatorGuarantor', [
|
|
53
53
|
vaultNodeOperator,
|
|
@@ -69,7 +69,7 @@ export const checkAndSpecifyNodeOperatorForTopUpOrWithdraw = async (vault, pdg,
|
|
|
69
69
|
return vaultNodeOperator;
|
|
70
70
|
};
|
|
71
71
|
export const getGuarantor = async (pdgContract) => {
|
|
72
|
-
const currentAccount = getAccount();
|
|
72
|
+
const currentAccount = await getAccount();
|
|
73
73
|
const balance = await callReadMethodSilent(pdgContract, 'nodeOperatorBalance', [currentAccount.address]);
|
|
74
74
|
if (balance.locked > 0n) {
|
|
75
75
|
throw new Error(`You have locked balance in PDG. You can't change the guarantor.`);
|
|
@@ -90,7 +90,7 @@ export const getGuarantor = async (pdgContract) => {
|
|
|
90
90
|
};
|
|
91
91
|
};
|
|
92
92
|
export const specifyNodeOperatorAddress = async () => {
|
|
93
|
-
const currentAccount = getAccount();
|
|
93
|
+
const currentAccount = await getAccount();
|
|
94
94
|
const confirm = await confirmOperation(`Do you want to use your address to check the balance ${currentAccount.address}?`);
|
|
95
95
|
if (!confirm) {
|
|
96
96
|
const otherAddress = await addressPrompt('Enter the address', 'value');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"no-pdg.js","sourceRoot":"","sources":["../../../features/deposits/no-pdg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,EAAE,MAAM,MAAM,CAAC;AAG5C,OAAO,EACL,oBAAoB,EACpB,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,aAAa,GACd,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAEvC,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,EAC9C,WAAwC,EACxC,YAAqB,EACrB,EAAE;IACF,MAAM,cAAc,GAAG,UAAU,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"no-pdg.js","sourceRoot":"","sources":["../../../features/deposits/no-pdg.ts"],"names":[],"mappings":"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"}
|
package/dist/features/index.d.ts
CHANGED
package/dist/features/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../features/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../features/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,6BAA6B,CAAC;AAC5C,cAAc,kBAAkB,CAAC;AACjC,cAAc,sBAAsB,CAAC;AACrC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const getLazyOracleBaseInfo: () => Promise<void>;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
import { printError, showSpinner, logResult } from '../utils/index.js';
|
|
3
|
+
import { getLazyOracleContract } from '../contracts/index.js';
|
|
4
|
+
export const getLazyOracleBaseInfo = async () => {
|
|
5
|
+
const hideSpinner = showSpinner();
|
|
6
|
+
try {
|
|
7
|
+
const contract = await getLazyOracleContract();
|
|
8
|
+
const LIDO_LOCATOR = await contract.read.LIDO_LOCATOR();
|
|
9
|
+
const DEFAULT_ADMIN_ROLE = await contract.read.DEFAULT_ADMIN_ROLE();
|
|
10
|
+
const UPDATE_SANITY_PARAMS_ROLE = await contract.read.UPDATE_SANITY_PARAMS_ROLE();
|
|
11
|
+
const MAX_QUARANTINE_PERIOD = await contract.read.MAX_QUARANTINE_PERIOD();
|
|
12
|
+
const MAX_REWARD_RATIO = await contract.read.MAX_REWARD_RATIO();
|
|
13
|
+
const MAX_LIDO_FEE_RATE_PER_SECOND = await contract.read.MAX_LIDO_FEE_RATE_PER_SECOND();
|
|
14
|
+
const latestReportTimestamp = await contract.read.latestReportTimestamp();
|
|
15
|
+
const quarantinePeriod = await contract.read.quarantinePeriod();
|
|
16
|
+
const maxRewardRatioBP = await contract.read.maxRewardRatioBP();
|
|
17
|
+
const maxLidoFeeRatePerSecond = await contract.read.maxLidoFeeRatePerSecond();
|
|
18
|
+
const CONTRACT_ADDRESS = contract.address;
|
|
19
|
+
hideSpinner();
|
|
20
|
+
const payload = {
|
|
21
|
+
CONTRACT_ADDRESS,
|
|
22
|
+
LIDO_LOCATOR,
|
|
23
|
+
DEFAULT_ADMIN_ROLE,
|
|
24
|
+
UPDATE_SANITY_PARAMS_ROLE,
|
|
25
|
+
MAX_QUARANTINE_PERIOD: `${MAX_QUARANTINE_PERIOD} (${Number(MAX_QUARANTINE_PERIOD) / 3600} hours)`,
|
|
26
|
+
MAX_REWARD_RATIO,
|
|
27
|
+
MAX_LIDO_FEE_RATE_PER_SECOND,
|
|
28
|
+
latestReportTimestamp: `${latestReportTimestamp} (${new Date(Number(latestReportTimestamp) * 1000).toLocaleString()})`,
|
|
29
|
+
quarantinePeriod: `${quarantinePeriod} (${Number(quarantinePeriod) / 3600} hours)`,
|
|
30
|
+
maxRewardRatioBP: `${maxRewardRatioBP} (${Number(maxRewardRatioBP) / 100} %)`,
|
|
31
|
+
maxLidoFeeRatePerSecond: `${maxLidoFeeRatePerSecond} (${formatEther(maxLidoFeeRatePerSecond)} ETH/s)`,
|
|
32
|
+
};
|
|
33
|
+
logResult({
|
|
34
|
+
data: Object.entries(payload).map(([key, value]) => [key, value]),
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
catch (err) {
|
|
38
|
+
hideSpinner();
|
|
39
|
+
printError(err, 'Error when getting base info');
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=lazy-oracle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lazy-oracle.js","sourceRoot":"","sources":["../../features/lazy-oracle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAEnC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAC;AAElD,MAAM,CAAC,MAAM,qBAAqB,GAAG,KAAK,IAAI,EAAE;IAC9C,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,qBAAqB,EAAE,CAAC;QAE/C,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QACxD,MAAM,kBAAkB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACpE,MAAM,yBAAyB,GAC7B,MAAM,QAAQ,CAAC,IAAI,CAAC,yBAAyB,EAAE,CAAC;QAClD,MAAM,qBAAqB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC1E,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAChE,MAAM,4BAA4B,GAChC,MAAM,QAAQ,CAAC,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACrD,MAAM,qBAAqB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC1E,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAChE,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAChE,MAAM,uBAAuB,GAC3B,MAAM,QAAQ,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAChD,MAAM,gBAAgB,GAAG,QAAQ,CAAC,OAAO,CAAC;QAE1C,WAAW,EAAE,CAAC;QAEd,MAAM,OAAO,GAAG;YACd,gBAAgB;YAChB,YAAY;YACZ,kBAAkB;YAClB,yBAAyB;YACzB,qBAAqB,EAAE,GAAG,qBAAqB,KAAK,MAAM,CAAC,qBAAqB,CAAC,GAAG,IAAI,SAAS;YACjG,gBAAgB;YAChB,4BAA4B;YAC5B,qBAAqB,EAAE,GAAG,qBAAqB,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,qBAAqB,CAAC,GAAG,IAAI,CAAC,CAAC,cAAc,EAAE,GAAG;YACtH,gBAAgB,EAAE,GAAG,gBAAgB,KAAK,MAAM,CAAC,gBAAgB,CAAC,GAAG,IAAI,SAAS;YAClF,gBAAgB,EAAE,GAAG,gBAAgB,KAAK,MAAM,CAAC,gBAAgB,CAAC,GAAG,GAAG,KAAK;YAC7E,uBAAuB,EAAE,GAAG,uBAAuB,KAAK,WAAW,CAAC,uBAAuB,CAAC,SAAS;SACtG,CAAC;QAEF,SAAS,CAAC;YACR,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SAClE,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,WAAW,EAAE,CAAC;QACd,UAAU,CAAC,GAAG,EAAE,8BAA8B,CAAC,CAAC;IAClD,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -3,7 +3,7 @@ import { getStethContract, getWstethContract, } from '../../contracts/index.js';
|
|
|
3
3
|
import { getAccount } from '../../providers/index.js';
|
|
4
4
|
import { callReadMethod, callReadMethodSilent, callWriteMethodWithReceipt, confirmOperation, logInfo, } from '../../utils/index.js';
|
|
5
5
|
export const checkAllowance = async (contract, amount, token) => {
|
|
6
|
-
const accountAddress = getAccount().address;
|
|
6
|
+
const accountAddress = (await getAccount()).address;
|
|
7
7
|
const isShares = token === 'shares';
|
|
8
8
|
let currentAmount = amount;
|
|
9
9
|
if (token === 'steth' || isShares) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"allowance.js","sourceRoot":"","sources":["../../../features/mint-burn/allowance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAEnC,OAAO,EACL,gBAAgB,EAEhB,iBAAiB,GAClB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EACL,cAAc,EACd,oBAAoB,EACpB,0BAA0B,EAC1B,gBAAgB,EAChB,OAAO,GACR,MAAM,OAAO,CAAC;AACf,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EACjC,QAA2B,EAC3B,MAAc,EACd,KAAoC,EACpC,EAAE;IACF,MAAM,cAAc,GAAG,UAAU,EAAE,CAAC,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"allowance.js","sourceRoot":"","sources":["../../../features/mint-burn/allowance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAEnC,OAAO,EACL,gBAAgB,EAEhB,iBAAiB,GAClB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EACL,cAAc,EACd,oBAAoB,EACpB,0BAA0B,EAC1B,gBAAgB,EAChB,OAAO,GACR,MAAM,OAAO,CAAC;AACf,MAAM,CAAC,MAAM,cAAc,GAAG,KAAK,EACjC,QAA2B,EAC3B,MAAc,EACd,KAAoC,EACpC,EAAE;IACF,MAAM,cAAc,GAAG,CAAC,MAAM,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC;IACpD,MAAM,QAAQ,GAAG,KAAK,KAAK,QAAQ,CAAC;IACpC,IAAI,aAAa,GAAG,MAAM,CAAC;IAE3B,IAAI,KAAK,KAAK,OAAO,IAAI,QAAQ,EAAE,CAAC;QAClC,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;QAE/C,MAAM,SAAS,GAAG,MAAM,cAAc,CAAC,aAAa,EAAE,WAAW,EAAE;YACjE,cAAc;YACd,QAAQ,CAAC,OAAO;SACjB,CAAC,CAAC;QACH,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,GAAG,MAAM,oBAAoB,CACxC,aAAa,EACb,6BAA6B,EAC7B,CAAC,MAAM,CAAC,CACT,CAAC;QACJ,CAAC;QAED,IAAI,SAAS,GAAG,aAAa,EAAE,CAAC;YAC9B,OAAO,CAAC,wBAAwB,CAAC,CAAC;YAElC,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oCAAoC,WAAW,CAAC,MAAM,CAAC,IAAI,KAAK,KAAK,WAAW,CAAC,aAAa,CAAC,cAAc,QAAQ,CAAC,OAAO,6CAA6C,WAAW,CAAC,SAAS,CAAC,QAAQ,CACzM,CAAC;YACF,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAEnD,MAAM,0BAA0B,CAAC;gBAC/B,QAAQ,EAAE,aAAa;gBACvB,UAAU,EAAE,SAAS;gBACrB,OAAO,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,aAAa,CAAC;aAC3C,CAAC,CAAC;QACL,CAAC;IACH,CAAC;SAAM,CAAC;QACN,MAAM,cAAc,GAAG,MAAM,iBAAiB,EAAE,CAAC;QAEjD,MAAM,eAAe,GAAG,MAAM,cAAc,CAAC,cAAc,EAAE,WAAW,EAAE;YACxE,cAAc;YACd,cAAc;SACf,CAAC,CAAC;QACH,IAAI,eAAe,GAAG,MAAM,EAAE,CAAC;YAC7B,OAAO,CAAC,wBAAwB,CAAC,CAAC;YAElC,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,oCAAoC,WAAW,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,QAAQ,CAAC,OAAO,6CAA6C,WAAW,CAAC,eAAe,CAAC,SAAS,CAC1K,CAAC;YACF,IAAI,CAAC,OAAO;gBAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAEnD,MAAM,0BAA0B,CAAC;gBAC/B,QAAQ,EAAE,cAAc;gBACxB,UAAU,EAAE,SAAS;gBACrB,OAAO,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;aACpC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { getAccount } from '../../providers/index.js';
|
|
2
2
|
import { addressPrompt, confirmOperation } from '../../utils/index.js';
|
|
3
3
|
export const getAddress = async (address, name) => {
|
|
4
|
-
const account = getAccount();
|
|
4
|
+
const account = await getAccount();
|
|
5
5
|
const currentAddress = address ?? account.address;
|
|
6
6
|
const isYourself = currentAddress === account.address;
|
|
7
7
|
const confirm = await confirmOperation(`Do you want to use ${currentAddress} as the ${name}?${isYourself ? ' (yourself)' : ''}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-address.js","sourceRoot":"","sources":["../../../features/utils/get-address.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AAExD,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,EAAE,OAAiB,EAAE,IAAa,EAAE,EAAE;IACnE,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"get-address.js","sourceRoot":"","sources":["../../../features/utils/get-address.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AAExD,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,EAAE,OAAiB,EAAE,IAAa,EAAE,EAAE;IACnE,MAAM,OAAO,GAAG,MAAM,UAAU,EAAE,CAAC;IACnC,MAAM,cAAc,GAAG,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC;IAClD,MAAM,UAAU,GAAG,cAAc,KAAK,OAAO,CAAC,OAAO,CAAC;IAEtD,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,sBAAsB,cAAc,WAAW,IAAI,IACjD,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAC/B,EAAE,CACH,CAAC;IACF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,YAAY,GAAG,MAAM,aAAa,CACtC,aAAa,IAAI,UAAU,EAC3B,SAAS,CACV,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAC9D,OAAO,YAAY,CAAC,OAAO,CAAC;IAC9B,CAAC;IAED,OAAO,cAAc,CAAC;AACxB,CAAC,CAAC"}
|
|
@@ -14,7 +14,6 @@ export const getVaultHubBaseInfo = async () => {
|
|
|
14
14
|
const REPORT_FRESHNESS_DELTA = await contract.read.REPORT_FRESHNESS_DELTA();
|
|
15
15
|
const RESUME_ROLE = await contract.read.RESUME_ROLE();
|
|
16
16
|
const VAULT_MASTER_ROLE = await contract.read.VAULT_MASTER_ROLE();
|
|
17
|
-
const VAULT_CODEHASH_SET_ROLE = await contract.read.VAULT_CODEHASH_SET_ROLE();
|
|
18
17
|
const MAX_RELATIVE_SHARE_LIMIT_BP = await contract.read.MAX_RELATIVE_SHARE_LIMIT_BP();
|
|
19
18
|
const resumeSinceTimestamp = await contract.read.getResumeSinceTimestamp();
|
|
20
19
|
const isPaused = await contract.read.isPaused();
|
|
@@ -30,7 +29,6 @@ export const getVaultHubBaseInfo = async () => {
|
|
|
30
29
|
PAUSE_ROLE,
|
|
31
30
|
RESUME_ROLE,
|
|
32
31
|
VAULT_MASTER_ROLE,
|
|
33
|
-
VAULT_CODEHASH_SET_ROLE,
|
|
34
32
|
MAX_RELATIVE_SHARE_LIMIT_BP,
|
|
35
33
|
CONNECT_DEPOSIT: `${formatEther(CONNECT_DEPOSIT)} ETH`,
|
|
36
34
|
REPORT_FRESHNESS_DELTA,
|
|
@@ -56,13 +54,11 @@ export const getVaultHubRoles = async () => {
|
|
|
56
54
|
const PAUSE_ROLE = await contract.read.PAUSE_ROLE();
|
|
57
55
|
const RESUME_ROLE = await contract.read.RESUME_ROLE();
|
|
58
56
|
const VAULT_MASTER_ROLE = await contract.read.VAULT_MASTER_ROLE();
|
|
59
|
-
const VAULT_CODEHASH_SET_ROLE = await contract.read.VAULT_CODEHASH_SET_ROLE();
|
|
60
57
|
const roles = {
|
|
61
58
|
DEFAULT_ADMIN_ROLE,
|
|
62
59
|
PAUSE_ROLE,
|
|
63
60
|
RESUME_ROLE,
|
|
64
61
|
VAULT_MASTER_ROLE,
|
|
65
|
-
VAULT_CODEHASH_SET_ROLE,
|
|
66
62
|
};
|
|
67
63
|
const result = await Promise.all(Object.entries(roles).map(async ([key, value]) => {
|
|
68
64
|
const accounts = await contract.read.getRoleMembers([value]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-hub.js","sourceRoot":"","sources":["../../features/vault-hub.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAEnC,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,IAAI,EAAE;IAC5C,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,mBAAmB,EAAE,CAAC;QAE7C,MAAM,eAAe,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;QAC9D,MAAM,kBAAkB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACpE,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACxC,MAAM,YAAY,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QACxD,MAAM,gBAAgB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAChE,MAAM,UAAU,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;QACpD,MAAM,sBAAsB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC5E,MAAM,WAAW,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACtD,MAAM,iBAAiB,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAClE,MAAM,
|
|
1
|
+
{"version":3,"file":"vault-hub.js","sourceRoot":"","sources":["../../features/vault-hub.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,8 +18,8 @@ const validateNodeOperatorFeeRate = (nodeOperatorFeeRate, type) => {
|
|
|
18
18
|
throw new Error(`Node operator fee rate must be less than 10000. Current value: ${nodeOperatorFeeRate}`);
|
|
19
19
|
if (type === 'percentage' && nodeOperatorFeeRate > 100)
|
|
20
20
|
throw new Error(`Node operator fee rate must be less than 100. Current value: ${nodeOperatorFeeRate}`);
|
|
21
|
-
if (type === 'basis points' && nodeOperatorFeeRate %
|
|
22
|
-
throw new Error(`Node operator fee rate must be a
|
|
21
|
+
if (type === 'basis points' && nodeOperatorFeeRate % 1 !== 0)
|
|
22
|
+
throw new Error(`Node operator fee rate must be a whole number. Current value: ${nodeOperatorFeeRate}`);
|
|
23
23
|
if (type === 'percentage' && nodeOperatorFeeRate % 1 !== 0)
|
|
24
24
|
throw new Error(`Node operator fee rate must be a whole number. Current value: ${nodeOperatorFeeRate}`);
|
|
25
25
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/create-vault.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,OAAO,CAAC;AAEnD,MAAM,kBAAkB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACxC,MAAM,kBAAkB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAE7C,MAAM,qBAAqB,GAAG,CAAC,aAAqB,EAAE,EAAE;IACtD,MAAM,UAAU,GAAG,kBAAkB,GAAG,IAAI,CAAC;IAC7C,MAAM,UAAU,GAAG,kBAAkB,GAAG,IAAI,CAAC;IAE7C,IAAI,aAAa,GAAG,UAAU;QAC5B,MAAM,IAAI,KAAK,CACb,uCAAuC,UAAU,0BAA0B,aAAa,WAAW,aAAa,GAAG,IAAI,WAAW,CACnI,CAAC;IACJ,IAAI,aAAa,GAAG,UAAU;QAC5B,MAAM,IAAI,KAAK,CACb,oCAAoC,UAAU,0BAA0B,aAAa,WAAW,aAAa,GAAG,IAAI,WAAW,CAChI,CAAC;IAEJ,IAAI,aAAa,GAAG,CAAC,KAAK,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;AAClE,CAAC,CAAC;AAEF,MAAM,2BAA2B,GAAG,CAClC,mBAA2B,EAC3B,IAAmC,EACnC,EAAE;IACF,IAAI,mBAAmB,GAAG,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;IAEnE,IAAI,IAAI,KAAK,cAAc,IAAI,mBAAmB,GAAG,KAAK;QACxD,MAAM,IAAI,KAAK,CACb,kEAAkE,mBAAmB,EAAE,CACxF,CAAC;IACJ,IAAI,IAAI,KAAK,YAAY,IAAI,mBAAmB,GAAG,GAAG;QACpD,MAAM,IAAI,KAAK,CACb,gEAAgE,mBAAmB,EAAE,CACtF,CAAC;IAEJ,IAAI,IAAI,KAAK,cAAc,IAAI,mBAAmB,GAAG,
|
|
1
|
+
{"version":3,"file":"create-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/create-vault.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Address } from 'viem';
|
|
2
|
-
import { DashboardContract } from '../../contracts/index.js';
|
|
2
|
+
import { DashboardContract, StakingVaultContract } from '../../contracts/index.js';
|
|
3
3
|
export declare const getDashboardByVault: (vault: Address) => Promise<`0x${string}`>;
|
|
4
4
|
export declare const chooseVaultAndGetDashboard: (args: {
|
|
5
5
|
vault?: Address;
|
|
@@ -7,5 +7,6 @@ export declare const chooseVaultAndGetDashboard: (args: {
|
|
|
7
7
|
}) => Promise<{
|
|
8
8
|
address: Address;
|
|
9
9
|
contract: DashboardContract;
|
|
10
|
+
vaultContract: StakingVaultContract;
|
|
10
11
|
vault: Address;
|
|
11
12
|
}>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { getDashboardContract, getVaultHubContract, } from '../../contracts/index.js';
|
|
1
|
+
import { getDashboardContract, getStakingVaultContract, getVaultHubContract, } from '../../contracts/index.js';
|
|
2
2
|
import { getPublicClient } from '../../providers/index.js';
|
|
3
3
|
import { callReadMethodSilent, enterContractAddress } from '../../utils/index.js';
|
|
4
4
|
import { chooseVault } from './vaults-by-role.js';
|
|
@@ -25,9 +25,11 @@ export const chooseVaultAndGetDashboard = async (args) => {
|
|
|
25
25
|
}
|
|
26
26
|
const dashboard = await getDashboardByVault(chosenVault);
|
|
27
27
|
const dashboardContract = getDashboardContract(dashboard);
|
|
28
|
+
const vaultContract = getStakingVaultContract(chosenVault);
|
|
28
29
|
return {
|
|
29
30
|
address: dashboard,
|
|
30
31
|
contract: dashboardContract,
|
|
32
|
+
vaultContract,
|
|
31
33
|
vault: chosenVault,
|
|
32
34
|
};
|
|
33
35
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dashboard-by-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/dashboard-by-vault.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAEnE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EAAE,KAAc,EAAE,EAAE;IAC1D,MAAM,QAAQ,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC7C,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAChD,QAAQ,EACR,iBAAiB,EACjB,CAAC,KAAK,CAAC,CACR,CAAC;IAEF,MAAM,UAAU,GAAG,eAAe,CAAC,KAAK,CAAC;IACzC,MAAM,SAAS,GAAG,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAC;IAErE,IAAI,CAAC,QAAQ,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,SAAS,UAAU,mCAAmC,CAAC,CAAC;IAC1E,CAAC;IAED,OAAO,SAAS,CAAC,OAAO,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,EAAE,IAGhD,
|
|
1
|
+
{"version":3,"file":"dashboard-by-vault.js","sourceRoot":"","sources":["../../../features/vault-operations/dashboard-by-vault.ts"],"names":[],"mappings":"AAEA,OAAO,EAEL,oBAAoB,EACpB,uBAAuB,EAEvB,mBAAmB,GACpB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAEnE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,MAAM,CAAC,MAAM,mBAAmB,GAAG,KAAK,EAAE,KAAc,EAAE,EAAE;IAC1D,MAAM,QAAQ,GAAG,MAAM,mBAAmB,EAAE,CAAC;IAC7C,MAAM,eAAe,GAAG,MAAM,oBAAoB,CAChD,QAAQ,EACR,iBAAiB,EACjB,CAAC,KAAK,CAAC,CACR,CAAC;IAEF,MAAM,UAAU,GAAG,eAAe,CAAC,KAAK,CAAC;IACzC,MAAM,SAAS,GAAG,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEnD,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,MAAM,QAAQ,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC,CAAC;IAErE,IAAI,CAAC,QAAQ,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,SAAS,UAAU,mCAAmC,CAAC,CAAC;IAC1E,CAAC;IAED,OAAO,SAAS,CAAC,OAAO,CAAC;AAC3B,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,KAAK,EAAE,IAGhD,EAKE,EAAE;IACH,MAAM,EAAE,KAAK,EAAE,WAAW,GAAG,KAAK,EAAE,GAAG,IAAI,CAAC;IAC5C,IAAI,WAAoB,CAAC;IAEzB,IAAI,WAAW,EAAE,CAAC;QAChB,WAAW,GAAG,KAAK,IAAI,CAAC,MAAM,oBAAoB,CAAC,SAAS,CAAC,CAAC,CAAC;IACjE,CAAC;SAAM,CAAC;QACN,WAAW,GAAG,KAAK,IAAI,CAAC,MAAM,WAAW,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,MAAM,SAAS,GAAG,MAAM,mBAAmB,CAAC,WAAW,CAAC,CAAC;IACzD,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAC1D,MAAM,aAAa,GAAG,uBAAuB,CAAC,WAAW,CAAC,CAAC;IAE3D,OAAO;QACL,OAAO,EAAE,SAAS;QAClB,QAAQ,EAAE,iBAAiB;QAC3B,aAAa;QACb,KAAK,EAAE,WAAW;KACnB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -4,7 +4,7 @@ export const getVaultHealthByDashboard = async (contract) => {
|
|
|
4
4
|
try {
|
|
5
5
|
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
6
6
|
await reportFreshWarning(vault);
|
|
7
|
-
const { healthRatio, isHealthy, totalValueInEth, liabilitySharesInSteth,
|
|
7
|
+
const { healthRatio, isHealthy, totalValueInEth, liabilitySharesInSteth, forcedRebalanceThresholdBP, liabilityShares, } = await fetchAndCalculateVaultHealth(contract);
|
|
8
8
|
logResult({});
|
|
9
9
|
logInfo('Vault Health');
|
|
10
10
|
logTable({
|
|
@@ -14,7 +14,7 @@ export const getVaultHealthByDashboard = async (contract) => {
|
|
|
14
14
|
['Total Value, ETH', totalValueInEth],
|
|
15
15
|
['Liability Shares', liabilityShares],
|
|
16
16
|
['Liability Shares in stETH', liabilitySharesInSteth],
|
|
17
|
-
['Rebalance Threshold, %', formatBP(
|
|
17
|
+
['Forced Rebalance Threshold, %', formatBP(forcedRebalanceThresholdBP)],
|
|
18
18
|
],
|
|
19
19
|
});
|
|
20
20
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-health.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-health.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAC9C,OAAO,EACL,QAAQ,EACR,OAAO,EACP,SAAS,EACT,QAAQ,EACR,4BAA4B,EAC5B,oBAAoB,GACrB,MAAM,OAAO,CAAC;AAEf,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,EAC5C,QAA2B,EAC3B,EAAE;IACF,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;QACnE,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEhC,MAAM,EACJ,WAAW,EACX,SAAS,EACT,eAAe,EACf,sBAAsB,EACtB,
|
|
1
|
+
{"version":3,"file":"vault-health.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-health.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAC9C,OAAO,EACL,QAAQ,EACR,OAAO,EACP,SAAS,EACT,QAAQ,EACR,4BAA4B,EAC5B,oBAAoB,GACrB,MAAM,OAAO,CAAC;AAEf,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,EAC5C,QAA2B,EAC3B,EAAE;IACF,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;QACnE,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEhC,MAAM,EACJ,WAAW,EACX,SAAS,EACT,eAAe,EACf,sBAAsB,EACtB,0BAA0B,EAC1B,eAAe,GAChB,GAAG,MAAM,4BAA4B,CAAC,QAAQ,CAAC,CAAC;QAEjD,SAAS,CAAC,EAAE,CAAC,CAAC;QACd,OAAO,CAAC,cAAc,CAAC,CAAC;QACxB,QAAQ,CAAC;YACP,IAAI,EAAE;gBACJ,CAAC,eAAe,EAAE,SAAS,CAAC;gBAC5B,CAAC,aAAa,EAAE,GAAG,WAAW,GAAG,CAAC;gBAClC,CAAC,kBAAkB,EAAE,eAAe,CAAC;gBACrC,CAAC,kBAAkB,EAAE,eAAe,CAAC;gBACrC,CAAC,2BAA2B,EAAE,sBAAsB,CAAC;gBACrD,CAAC,+BAA+B,EAAE,QAAQ,CAAC,0BAA0B,CAAC,CAAC;aACxE;SACF,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,IAAI,GAAG,YAAY,KAAK,EAAE,CAAC;YACzB,OAAO,CAAC,4BAA4B,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;QACrD,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -8,30 +8,23 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
8
8
|
const hideSpinner = showSpinner();
|
|
9
9
|
const publicClient = getPublicClient();
|
|
10
10
|
try {
|
|
11
|
-
const [steth, wsteth,
|
|
11
|
+
const [steth, wsteth, lidoLocator, vaultHub, vaultConnection, liabilityShares, obligations, totalValue, locked, maxLockableValue, totalMintingCapacityShares, remainingMintingCapacityShares, withdrawableValue, feeRecipient, nodeOperatorAccruedFee, feeRate, confirmExpiry, maxConfirmExpiry, minConfirmExpiry,] = await Promise.all([
|
|
12
12
|
contract.read.STETH(),
|
|
13
13
|
contract.read.WSTETH(),
|
|
14
|
-
contract.read.ETH(),
|
|
15
14
|
contract.read.LIDO_LOCATOR(),
|
|
16
15
|
contract.read.VAULT_HUB(),
|
|
17
|
-
contract.read.
|
|
18
|
-
contract.read.forcedRebalanceThresholdBP(),
|
|
19
|
-
contract.read.infraFeeBP(),
|
|
20
|
-
contract.read.liquidityFeeBP(),
|
|
21
|
-
contract.read.reservationFeeBP(),
|
|
22
|
-
contract.read.shareLimit(),
|
|
16
|
+
contract.read.vaultConnection(),
|
|
23
17
|
contract.read.liabilityShares(),
|
|
24
|
-
contract.read.
|
|
18
|
+
contract.read.obligations(),
|
|
25
19
|
contract.read.totalValue(),
|
|
26
20
|
contract.read.locked(),
|
|
27
21
|
contract.read.maxLockableValue(),
|
|
28
22
|
contract.read.totalMintingCapacityShares(),
|
|
29
23
|
contract.read.remainingMintingCapacityShares([0n]),
|
|
30
24
|
contract.read.withdrawableValue(),
|
|
31
|
-
contract.read.
|
|
32
|
-
contract.read.
|
|
33
|
-
contract.read.
|
|
34
|
-
contract.read.nodeOperatorFeeRate(),
|
|
25
|
+
contract.read.feeRecipient(),
|
|
26
|
+
contract.read.accruedFee(),
|
|
27
|
+
contract.read.feeRate(),
|
|
35
28
|
contract.read.getConfirmExpiry(),
|
|
36
29
|
contract.read.MAX_CONFIRM_EXPIRY(),
|
|
37
30
|
contract.read.MIN_CONFIRM_EXPIRY(),
|
|
@@ -50,20 +43,26 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
50
43
|
['LIDO Locator address', lidoLocator],
|
|
51
44
|
['stETH address', steth],
|
|
52
45
|
['wstETH address', wsteth],
|
|
53
|
-
['
|
|
54
|
-
['Reserve Ratio,
|
|
55
|
-
[
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
[
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
['
|
|
64
|
-
['
|
|
46
|
+
['Reserve Ratio, BP', vaultConnection.reserveRatioBP],
|
|
47
|
+
['Reserve Ratio, %', formatBP(vaultConnection.reserveRatioBP)],
|
|
48
|
+
[
|
|
49
|
+
'Forced Rebalance Threshold, BP',
|
|
50
|
+
vaultConnection.forcedRebalanceThresholdBP,
|
|
51
|
+
],
|
|
52
|
+
[
|
|
53
|
+
'Forced Rebalance Threshold, %',
|
|
54
|
+
formatBP(vaultConnection.forcedRebalanceThresholdBP),
|
|
55
|
+
],
|
|
56
|
+
['Infra Fee, BP', vaultConnection.infraFeeBP],
|
|
57
|
+
['Infra Fee, %', formatBP(vaultConnection.infraFeeBP)],
|
|
58
|
+
['Liquidity Fee, BP', vaultConnection.liquidityFeeBP],
|
|
59
|
+
['Liquidity Fee, %', formatBP(vaultConnection.liquidityFeeBP)],
|
|
60
|
+
['Reservation Fee, BP', vaultConnection.reservationFeeBP],
|
|
61
|
+
['Reservation Fee, %', formatBP(vaultConnection.reservationFeeBP)],
|
|
62
|
+
['Share Limit, Shares', vaultConnection.shareLimit],
|
|
65
63
|
['Liability Shares, Shares', formatEther(liabilityShares)],
|
|
66
|
-
['
|
|
64
|
+
['Obligations (sharesToBurn), Shares', formatEther(obligations[0])],
|
|
65
|
+
['Obligations (feesToSettle), ETH', formatEther(obligations[1])],
|
|
67
66
|
['Total Value, ETH', formatEther(totalValue)],
|
|
68
67
|
['Locked, ETH', formatEther(locked)],
|
|
69
68
|
['Max Lockable Value, ETH', formatEther(maxLockableValue)],
|
|
@@ -77,15 +76,13 @@ export const getVaultInfoByDashboard = async (contract) => {
|
|
|
77
76
|
formatEther(remainingMintingCapacityShares),
|
|
78
77
|
],
|
|
79
78
|
['Withdrawable Value, ETH', formatEther(withdrawableValue)],
|
|
80
|
-
['Node Operator Fee Recipient',
|
|
81
|
-
['Node Operator Fee Rate, BP',
|
|
82
|
-
['Node Operator Fee Rate, %', formatBP(
|
|
79
|
+
['Node Operator Fee Recipient', feeRecipient],
|
|
80
|
+
['Node Operator Fee Rate, BP', feeRate],
|
|
81
|
+
['Node Operator Fee Rate, %', formatBP(feeRate)],
|
|
83
82
|
[
|
|
84
83
|
'Node Operator Disbursable Fee, ETH',
|
|
85
|
-
formatEther(
|
|
84
|
+
formatEther(nodeOperatorAccruedFee),
|
|
86
85
|
],
|
|
87
|
-
['Rewards Adjustment amount, ETH', formatEther(rewardsAdjustment[0])],
|
|
88
|
-
['Rewards Adjustment latestTimestamp', rewardsAdjustment[1]],
|
|
89
86
|
[
|
|
90
87
|
'Confirm Expiry',
|
|
91
88
|
`${confirmExpiry} (${Number(confirmExpiry) / 3600} hours)`,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vault-info.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AAGnC,OAAO,EACL,QAAQ,EACR,OAAO,EACP,QAAQ,EACR,SAAS,EACT,WAAW,EACX,UAAU,EACV,oBAAoB,GACrB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAE9C,MAAM,CAAC,MAAM,uBAAuB,GAAG,KAAK,EAAE,QAA2B,EAAE,EAAE;IAC3E,MAAM,KAAK,GAAG,MAAM,oBAAoB,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC;IACnE,MAAM,kBAAkB,CAAC,KAAK,CAAC,CAAC;IAEhC,MAAM,WAAW,GAAG,WAAW,EAAE,CAAC;IAClC,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IAEvC,IAAI,CAAC;QACH,MAAM,CACJ,KAAK,EACL,MAAM,EACN,
|
|
1
|
+
{"version":3,"file":"vault-info.js","sourceRoot":"","sources":["../../../features/vault-operations/vault-info.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,37 +1,47 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
|
-
import { getOperatorGridContract, getStethContract, getVaultHubContract, } from '../../contracts/index.js';
|
|
2
|
+
import { getLazyOracleContract, getOperatorGridContract, getStethContract, getVaultHubContract, } from '../../contracts/index.js';
|
|
3
3
|
import { getPublicClient } from '../../providers/index.js';
|
|
4
|
-
import { fetchAndCalculateVaultHealth, formatBP, formatRatio, showSpinner, logInfo, logTable, logResult, logLiabilityBar, logVaultHealthBar, printError, calculateOverviewV2, callReadMethodSilent, } from '../../utils/index.js';
|
|
4
|
+
import { fetchAndCalculateVaultHealth, formatBP, formatRatio, showSpinner, logInfo, logTable, logResult, logLiabilityBar, logVaultHealthBar, printError, calculateOverviewV2, getVaultReport, callReadMethodSilent, } from '../../utils/index.js';
|
|
5
5
|
import { reportFreshWarning } from '../index.js';
|
|
6
6
|
export const getVaultOverviewByDashboard = async (contract) => {
|
|
7
7
|
const vault = await callReadMethodSilent(contract, 'stakingVault');
|
|
8
8
|
await reportFreshWarning(vault);
|
|
9
9
|
const hideSpinner = showSpinner();
|
|
10
10
|
const publicClient = getPublicClient();
|
|
11
|
+
let report = null;
|
|
12
|
+
try {
|
|
13
|
+
const lazyOracleContract = await getLazyOracleContract();
|
|
14
|
+
const [_timestamp, _refSlot, _treeRoot, cid] = await callReadMethodSilent(lazyOracleContract, 'latestReportData');
|
|
15
|
+
report = await getVaultReport({ vault, cid });
|
|
16
|
+
}
|
|
17
|
+
catch (error) {
|
|
18
|
+
logInfo('No report found');
|
|
19
|
+
}
|
|
11
20
|
try {
|
|
12
21
|
const health = await fetchAndCalculateVaultHealth(contract);
|
|
13
22
|
const operatorGridContract = await getOperatorGridContract();
|
|
14
|
-
const [
|
|
15
|
-
contract.read.
|
|
16
|
-
contract.read.reserveRatioBP(),
|
|
23
|
+
const [vaultConnection, totalMintingCapacityShares, withdrawableValue, totalValue, locked, remainingMintingCapacityShares, minimalReserve, nodeOperatorFeeRate, nodeOperatorAccruedFee,] = await Promise.all([
|
|
24
|
+
contract.read.vaultConnection(),
|
|
17
25
|
contract.read.totalMintingCapacityShares(),
|
|
18
26
|
contract.read.withdrawableValue(),
|
|
19
|
-
contract.read.nodeOperatorDisbursableFee(),
|
|
20
27
|
contract.read.totalValue(),
|
|
21
28
|
contract.read.locked(),
|
|
22
|
-
contract.read.shareLimit(),
|
|
23
29
|
contract.read.remainingMintingCapacityShares([0n]),
|
|
30
|
+
contract.read.minimalReserve(),
|
|
31
|
+
contract.read.feeRate(),
|
|
32
|
+
contract.read.accruedFee(),
|
|
24
33
|
]);
|
|
34
|
+
const { reserveRatioBP, shareLimit } = vaultConnection;
|
|
25
35
|
const stethContract = await getStethContract();
|
|
26
36
|
const vaultHubContract = await getVaultHubContract();
|
|
27
37
|
const balance = await publicClient.getBalance({
|
|
28
38
|
address: vault,
|
|
29
39
|
});
|
|
30
|
-
const vaultObligation = await callReadMethodSilent(vaultHubContract, '
|
|
31
|
-
const tierInfo = await callReadMethodSilent(operatorGridContract, '
|
|
40
|
+
const vaultObligation = await callReadMethodSilent(vaultHubContract, 'obligations', [vault]);
|
|
41
|
+
const tierInfo = await callReadMethodSilent(operatorGridContract, 'vaultTierInfo', [vault]);
|
|
32
42
|
const isNoHaveGroup = tierInfo[0] === '0xFFfFfFffFFfffFFfFFfFFFFFffFFFffffFfFFFfF';
|
|
33
43
|
const nodeOperatorGroup = await callReadMethodSilent(operatorGridContract, 'group', [tierInfo[0]]);
|
|
34
|
-
const [totalMintingCapacityStethWei, shareLimitStethWei, tierShareLimitStethWei, groupShareLimitStethWei, remainingMintingCapacityStethWei,] = await Promise.all([
|
|
44
|
+
const [totalMintingCapacityStethWei, shareLimitStethWei, tierShareLimitStethWei, groupShareLimitStethWei, remainingMintingCapacityStethWei, lastReportLiabilityInStethWei,] = await Promise.all([
|
|
35
45
|
stethContract.read.getPooledEthBySharesRoundUp([
|
|
36
46
|
totalMintingCapacityShares,
|
|
37
47
|
]),
|
|
@@ -43,18 +53,25 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
43
53
|
stethContract.read.getPooledEthBySharesRoundUp([
|
|
44
54
|
remainingMintingCapacityShares,
|
|
45
55
|
]),
|
|
56
|
+
report
|
|
57
|
+
? stethContract.read.getPooledEthBySharesRoundUp([
|
|
58
|
+
BigInt(report.data.liabilityShares),
|
|
59
|
+
])
|
|
60
|
+
: 0n,
|
|
46
61
|
]);
|
|
47
62
|
const overview = calculateOverviewV2({
|
|
48
63
|
totalValue,
|
|
49
64
|
reserveRatioBP,
|
|
50
65
|
liabilitySharesInStethWei: health.liabilitySharesInStethWei,
|
|
51
|
-
|
|
66
|
+
forcedRebalanceThresholdBP: health.forcedRebalanceThresholdBP,
|
|
52
67
|
withdrawableEther: withdrawableValue,
|
|
53
68
|
balance,
|
|
54
69
|
locked,
|
|
55
|
-
|
|
70
|
+
nodeOperatorAccruedFee,
|
|
56
71
|
totalMintingCapacityStethWei,
|
|
57
|
-
unsettledLidoFees: vaultObligation
|
|
72
|
+
unsettledLidoFees: vaultObligation[1],
|
|
73
|
+
minimalReserve,
|
|
74
|
+
lastReportLiabilityInStethWei,
|
|
58
75
|
});
|
|
59
76
|
hideSpinner();
|
|
60
77
|
logResult({});
|
|
@@ -65,7 +82,7 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
65
82
|
['Reserve Ratio, %', formatBP(reserveRatioBP)],
|
|
66
83
|
[
|
|
67
84
|
'Force Rebalance Threshold',
|
|
68
|
-
formatBP(health.
|
|
85
|
+
formatBP(health.forcedRebalanceThresholdBP),
|
|
69
86
|
],
|
|
70
87
|
['stVault Share Limit, stETH', formatEther(shareLimitStethWei)],
|
|
71
88
|
['stVault Share Limit, Shares', formatEther(shareLimit)],
|
|
@@ -83,10 +100,7 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
83
100
|
['Total Locked, ETH', formatEther(overview.totalLocked)],
|
|
84
101
|
['Collateral, ETH', formatEther(overview.collateral)],
|
|
85
102
|
['Recently Repaid, ETH', formatEther(overview.recentlyRepaid)],
|
|
86
|
-
[
|
|
87
|
-
'Node Operator Disbursable Fee, ETH',
|
|
88
|
-
formatEther(nodeOperatorDisbursableFee),
|
|
89
|
-
],
|
|
103
|
+
['Node Operator Accrued Fee, ETH', formatEther(nodeOperatorAccruedFee)],
|
|
90
104
|
['Reserved, ETH', formatEther(overview.reserved)],
|
|
91
105
|
[
|
|
92
106
|
'Total Minting Capacity, stETH',
|
|
@@ -100,15 +114,8 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
100
114
|
'Remaining Minting Capacity, Shares',
|
|
101
115
|
formatEther(remainingMintingCapacityShares),
|
|
102
116
|
],
|
|
103
|
-
[
|
|
104
|
-
|
|
105
|
-
formatEther(vaultObligation.unsettledLidoFees),
|
|
106
|
-
],
|
|
107
|
-
[
|
|
108
|
-
'Settled Lido Fees, ETH',
|
|
109
|
-
formatEther(vaultObligation.settledLidoFees),
|
|
110
|
-
],
|
|
111
|
-
['Redemptions, ETH', formatEther(vaultObligation.redemptions)],
|
|
117
|
+
['Unsettled Lido Fees, ETH', formatEther(vaultObligation[1])],
|
|
118
|
+
['Shares to Burn, Shares', formatEther(vaultObligation[0])],
|
|
112
119
|
['Tier ID', tierInfo[1]],
|
|
113
120
|
['Tier Share Limit, stETH', formatEther(tierShareLimitStethWei)],
|
|
114
121
|
['Tier Share Limit, Shares', formatEther(tierInfo[2])],
|
|
@@ -126,7 +133,7 @@ export const getVaultOverviewByDashboard = async (contract) => {
|
|
|
126
133
|
totalValue: totalValue,
|
|
127
134
|
stETHLiability: health.liabilitySharesInStethWei,
|
|
128
135
|
reserveRatioBP: reserveRatioBP,
|
|
129
|
-
|
|
136
|
+
forcedRebalanceThresholdBP: health.forcedRebalanceThresholdBP,
|
|
130
137
|
stETHTotalMintingCapacity: totalMintingCapacityStethWei,
|
|
131
138
|
});
|
|
132
139
|
console.info('\n');
|