@lidofinance/lsv-cli 1.5.1 → 1.6.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/dist/abi/AccessControlConfirmable.js.map +1 -1
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/LazyOracle.js.map +1 -1
- package/dist/abi/LidoLocator.js.map +1 -1
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/PredepositGuarantee.js.map +1 -1
- package/dist/abi/StEth.js.map +1 -1
- package/dist/abi/StakingVault.js.map +1 -1
- package/dist/abi/ValidatorConsolidationRequests.js.map +1 -1
- package/dist/abi/VaultFactory.js.map +1 -1
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.js.map +1 -1
- package/dist/abi/WstEth.js.map +1 -1
- package/dist/abi/defi-wrapper/Distributor.js.map +1 -1
- package/dist/abi/defi-wrapper/Factory.js.map +1 -1
- package/dist/abi/defi-wrapper/OssifiableProxy.js.map +1 -1
- package/dist/abi/defi-wrapper/StrategyFactory.d.ts +59 -0
- package/dist/abi/defi-wrapper/StrategyFactory.js +37 -0
- package/dist/abi/defi-wrapper/StrategyFactory.js.map +1 -0
- package/dist/abi/defi-wrapper/StvPool.js.map +1 -1
- package/dist/abi/defi-wrapper/StvStETHPool.js.map +1 -1
- package/dist/abi/defi-wrapper/TimeLock.js.map +1 -1
- package/dist/abi/defi-wrapper/WithdrawalQueue.js.map +1 -1
- package/dist/abi/defi-wrapper/index.d.ts +1 -0
- package/dist/abi/defi-wrapper/index.js +1 -0
- package/dist/abi/defi-wrapper/index.js.map +1 -1
- package/dist/command/index.js +11 -0
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +4 -4
- package/dist/contracts/dashboard-impl.d.ts +4 -3
- package/dist/contracts/dashboard-impl.js +5 -8
- package/dist/contracts/dashboard-impl.js.map +1 -1
- package/dist/contracts/dashboard.d.ts +4 -3
- package/dist/contracts/dashboard.js +1 -1
- package/dist/contracts/dashboard.js.map +1 -1
- package/dist/contracts/defi-wrapper/distributor.d.ts +5 -4
- package/dist/contracts/defi-wrapper/distributor.js +2 -2
- package/dist/contracts/defi-wrapper/distributor.js.map +1 -1
- package/dist/contracts/defi-wrapper/factory.d.ts +5 -4
- package/dist/contracts/defi-wrapper/factory.js +2 -2
- package/dist/contracts/defi-wrapper/factory.js.map +1 -1
- package/dist/contracts/defi-wrapper/index.d.ts +1 -0
- package/dist/contracts/defi-wrapper/index.js +1 -0
- package/dist/contracts/defi-wrapper/index.js.map +1 -1
- package/dist/contracts/defi-wrapper/ossifiable-proxy.d.ts +5 -4
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js +2 -2
- package/dist/contracts/defi-wrapper/ossifiable-proxy.js.map +1 -1
- package/dist/contracts/defi-wrapper/strategy-factory.d.ts +5 -0
- package/dist/contracts/defi-wrapper/strategy-factory.js +12 -0
- package/dist/contracts/defi-wrapper/strategy-factory.js.map +1 -0
- package/dist/contracts/defi-wrapper/stv-pool.d.ts +5 -4
- package/dist/contracts/defi-wrapper/stv-pool.js +2 -2
- package/dist/contracts/defi-wrapper/stv-pool.js.map +1 -1
- package/dist/contracts/defi-wrapper/stv-steth-pool.d.ts +5 -4
- package/dist/contracts/defi-wrapper/stv-steth-pool.js +2 -2
- package/dist/contracts/defi-wrapper/stv-steth-pool.js.map +1 -1
- package/dist/contracts/defi-wrapper/timelock.d.ts +5 -4
- package/dist/contracts/defi-wrapper/timelock.js +2 -2
- package/dist/contracts/defi-wrapper/timelock.js.map +1 -1
- package/dist/contracts/defi-wrapper/withdrawal-queue.d.ts +5 -4
- package/dist/contracts/defi-wrapper/withdrawal-queue.js +2 -2
- package/dist/contracts/defi-wrapper/withdrawal-queue.js.map +1 -1
- package/dist/contracts/lazy-oracle.d.ts +5 -3
- package/dist/contracts/lazy-oracle.js +5 -9
- package/dist/contracts/lazy-oracle.js.map +1 -1
- package/dist/contracts/locator.d.ts +4 -2
- package/dist/contracts/locator.js +5 -8
- package/dist/contracts/locator.js.map +1 -1
- package/dist/contracts/operator-grid.d.ts +5 -4
- package/dist/contracts/operator-grid.js +5 -8
- package/dist/contracts/operator-grid.js.map +1 -1
- package/dist/contracts/pdg.d.ts +5 -4
- package/dist/contracts/pdg.js +5 -8
- package/dist/contracts/pdg.js.map +1 -1
- package/dist/contracts/steth.d.ts +5 -4
- package/dist/contracts/steth.js +5 -9
- package/dist/contracts/steth.js.map +1 -1
- package/dist/contracts/validator-consolidation-requests.d.ts +3 -3
- package/dist/contracts/validator-consolidation-requests.js.map +1 -1
- package/dist/contracts/vault-factory.d.ts +5 -3
- package/dist/contracts/vault-factory.js +6 -8
- package/dist/contracts/vault-factory.js.map +1 -1
- package/dist/contracts/vault-hub.d.ts +5 -3
- package/dist/contracts/vault-hub.js +5 -9
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +4 -2
- package/dist/contracts/vault-viewer.js +6 -9
- package/dist/contracts/vault-viewer.js.map +1 -1
- package/dist/contracts/vault.d.ts +5 -4
- package/dist/contracts/vault.js +2 -2
- package/dist/contracts/vault.js.map +1 -1
- package/dist/contracts/wsteth.d.ts +5 -3
- package/dist/contracts/wsteth.js +5 -9
- package/dist/contracts/wsteth.js.map +1 -1
- package/dist/features/consolidation.d.ts +1 -1
- package/dist/features/defi-wrapper/create-vault.js +3 -3
- package/dist/features/defi-wrapper/create-vault.js.map +1 -1
- package/dist/features/defi-wrapper/defi-wrapper-factory.d.ts +14 -4
- package/dist/features/defi-wrapper/defi-wrapper-factory.js +21 -4
- package/dist/features/defi-wrapper/defi-wrapper-factory.js.map +1 -1
- package/dist/features/defi-wrapper/distributor.js +3 -3
- package/dist/features/defi-wrapper/pool-info.js +2 -2
- package/dist/features/defi-wrapper/timelock.d.ts +3 -3
- package/dist/features/defi-wrapper/timelock.js +1 -1
- package/dist/features/defi-wrapper/timelock.js.map +1 -1
- package/dist/features/deposits/make-pdg-proof.js +4 -4
- package/dist/features/deposits/make-pdg-proof.js.map +1 -1
- package/dist/features/deposits/validators.js +1 -1
- package/dist/features/deposits/validators.js.map +1 -1
- package/dist/features/metrics.d.ts +3 -0
- package/dist/features/metrics.js +25 -0
- package/dist/features/metrics.js.map +1 -1
- package/dist/features/mint-burn/mint-limit.js +1 -1
- package/dist/features/utils/minting-capacity.js +1 -1
- package/dist/features/vault-factory.js +1 -1
- package/dist/features/vault-operations/index.d.ts +1 -0
- package/dist/features/vault-operations/index.js +1 -0
- package/dist/features/vault-operations/index.js.map +1 -1
- package/dist/features/vault-operations/share-limit.d.ts +8 -0
- package/dist/features/vault-operations/share-limit.js +20 -0
- package/dist/features/vault-operations/share-limit.js.map +1 -0
- package/dist/features/with-report.d.ts +1 -1
- package/dist/index.js +30 -10
- package/dist/index.js.map +1 -1
- package/dist/programs/account/main.d.ts +1 -1
- package/dist/programs/account/write.js +29 -2
- package/dist/programs/account/write.js.map +1 -1
- package/dist/programs/contracts/dashboard/main.d.ts +1 -1
- package/dist/programs/contracts/dashboard/write.js +21 -14
- package/dist/programs/contracts/dashboard/write.js.map +1 -1
- package/dist/programs/contracts/hub/main.d.ts +1 -1
- package/dist/programs/contracts/hub/write.js +2 -1
- package/dist/programs/contracts/hub/write.js.map +1 -1
- package/dist/programs/contracts/lazy-oracle/main.d.ts +1 -1
- package/dist/programs/contracts/main.d.ts +1 -1
- package/dist/programs/contracts/operator-grid/main.d.ts +1 -1
- package/dist/programs/contracts/operator-grid/write.js +13 -9
- package/dist/programs/contracts/operator-grid/write.js.map +1 -1
- package/dist/programs/contracts/pdg/main.d.ts +1 -1
- package/dist/programs/contracts/pdg/write.js +1 -1
- package/dist/programs/contracts/vault/main.d.ts +1 -1
- package/dist/programs/contracts/vault-factory/main.d.ts +1 -1
- package/dist/programs/contracts/vault-viewer/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/distributor/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/distributor/write.js +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/factory/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/factory/write.js +124 -36
- package/dist/programs/defi-wrapper/contracts/factory/write.js.map +1 -1
- package/dist/programs/defi-wrapper/contracts/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-pool/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/stv-pool/write.js +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/stv-steth-pool/write.js +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/config.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/read.js +2 -2
- package/dist/programs/defi-wrapper/contracts/withdrawal-queue/write.js +1 -1
- package/dist/programs/defi-wrapper/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/distributor/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/distributor/read.js +2 -2
- package/dist/programs/defi-wrapper/use-cases/distributor/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/health/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/read.js +2 -2
- package/dist/programs/defi-wrapper/use-cases/health/utils.js +1 -1
- package/dist/programs/defi-wrapper/use-cases/health/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/read.js +8 -8
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/common/write.js +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/dashboard/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/pool/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/read.js +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/proxy/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/timelock-governance/withdrawal-queue/write.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/main.d.ts +1 -1
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/read.js +3 -3
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js +35 -49
- package/dist/programs/defi-wrapper/use-cases/wrapper-operations/write.js.map +1 -1
- package/dist/programs/dev-tools/anvil/main.d.ts +1 -1
- package/dist/programs/dev-tools/defi-wrapper/main.d.ts +1 -1
- package/dist/programs/dev-tools/defi-wrapper/write.js +1 -1
- package/dist/programs/dev-tools/main.d.ts +1 -1
- package/dist/programs/pdg-helpers.js +4 -0
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/use-cases/consolidation/main.d.ts +1 -1
- package/dist/programs/use-cases/consolidation/write.d.ts +1 -1
- package/dist/programs/use-cases/consolidation/write.js +1 -1
- package/dist/programs/use-cases/deposits/main.d.ts +1 -1
- package/dist/programs/use-cases/metrics/main.d.ts +1 -1
- package/dist/programs/use-cases/metrics/read.js +7 -7
- package/dist/programs/use-cases/metrics/read.js.map +1 -1
- package/dist/programs/use-cases/report/main.d.ts +1 -1
- package/dist/programs/use-cases/vault-operations/main.d.ts +1 -1
- package/dist/programs/use-cases/vault-operations/write.js +29 -15
- package/dist/programs/use-cases/vault-operations/write.js.map +1 -1
- package/dist/providers/wallet.d.ts +302 -300
- package/dist/providers/wallet.js +10 -2
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/integration/deposits.test.js +1 -1
- package/dist/tests/integration/deposits.test.js.map +1 -1
- package/dist/tests/integration/helpers/test-client.d.ts +150 -150
- package/dist/tests/integration/metrics.test.js.map +1 -1
- package/dist/tests/integration/mint-burn.test.js.map +1 -1
- package/dist/tests/utils/calculate-overview-v2.test.js +1 -1
- package/dist/tests/utils/csv-file.test.js +1 -1
- package/dist/tests/utils/error-handler.test.js +5 -8
- package/dist/tests/utils/error-handler.test.js.map +1 -1
- package/dist/tests/utils/lido-apr.test.js +1 -1
- package/dist/tests/utils/logging.test.js +30 -14
- package/dist/tests/utils/logging.test.js.map +1 -1
- package/dist/tests/utils/rebase-rewards.test.js +44 -43
- package/dist/tests/utils/rebase-rewards.test.js.map +1 -1
- package/dist/tests/utils/report-statistic.test.d.ts +1 -0
- package/dist/tests/utils/report-statistic.test.js +501 -0
- package/dist/tests/utils/report-statistic.test.js.map +1 -0
- package/dist/tests/utils/snake-to-camel.test.js +1 -1
- package/dist/tests/utils/spinner.test.d.ts +1 -0
- package/dist/tests/utils/spinner.test.js +113 -0
- package/dist/tests/utils/spinner.test.js.map +1 -0
- package/dist/tests/utils/timestamp.test.js +1 -1
- package/dist/utils/arguments.d.ts +1 -1
- package/dist/utils/cache.d.ts +0 -1
- package/dist/utils/cache.js +1 -2
- package/dist/utils/cache.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.js +5 -5
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -1
- package/dist/utils/charts/blessed/charts-rewards.js +4 -4
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -1
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +6 -6
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +12 -13
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -1
- package/dist/utils/charts/blessed/utils.js +5 -2
- package/dist/utils/charts/blessed/utils.js.map +1 -1
- package/dist/utils/charts/simple/simple-charts.js +15 -7
- package/dist/utils/charts/simple/simple-charts.js.map +1 -1
- package/dist/utils/error-handler.js +3 -0
- package/dist/utils/error-handler.js.map +1 -1
- package/dist/utils/fetchCL.js +26 -35
- package/dist/utils/fetchCL.js.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/interrupt-handler.js +14 -6
- package/dist/utils/interrupt-handler.js.map +1 -1
- package/dist/utils/logging/console.d.ts +5 -1
- package/dist/utils/logging/console.js +36 -25
- package/dist/utils/logging/console.js.map +1 -1
- package/dist/utils/prompts/confirmations.d.ts +1 -1
- package/dist/utils/prompts/operations.d.ts +1 -1
- package/dist/utils/prompts/predeposit-guarantee.d.ts +1 -1
- package/dist/utils/prompts/predeposit-guarantee.js +1 -1
- package/dist/utils/proof/create-proof.js +18 -3
- package/dist/utils/proof/create-proof.js.map +1 -1
- package/dist/utils/rebase-rewards.d.ts +0 -1
- package/dist/utils/rebase-rewards.js +12 -3
- package/dist/utils/rebase-rewards.js.map +1 -1
- package/dist/utils/report/statistic-data.js +31 -16
- package/dist/utils/report/statistic-data.js.map +1 -1
- package/dist/utils/spinner/spinners.js +5 -3
- package/dist/utils/spinner/spinners.js.map +1 -1
- package/dist/utils/statistic/report-statistic.d.ts +21 -6
- package/dist/utils/statistic/report-statistic.js +65 -25
- package/dist/utils/statistic/report-statistic.js.map +1 -1
- package/dist/utils/transactions/tx-private-key.d.ts +2 -2
- package/dist/utils/transactions/tx-private-key.js +43 -11
- package/dist/utils/transactions/tx-private-key.js.map +1 -1
- package/dist/utils/transactions/tx-wc.d.ts +12 -11
- package/dist/utils/transactions/tx-wc.js +108 -11
- package/dist/utils/transactions/tx-wc.js.map +1 -1
- package/dist/utils/transactions/utils.d.ts +1 -0
- package/dist/utils/transactions/utils.js +11 -0
- package/dist/utils/transactions/utils.js.map +1 -1
- package/dist/utils/wallet-connect.d.ts +4 -1
- package/dist/utils/wallet-connect.js +52 -4
- package/dist/utils/wallet-connect.js.map +1 -1
- package/dist/utils/with-error.d.ts +7 -0
- package/dist/utils/with-error.js +6 -0
- package/dist/utils/with-error.js.map +1 -0
- package/dist/version/index.js +1 -1
- package/package.json +3 -3
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"timelock.js","sourceRoot":"","sources":["../../../features/defi-wrapper/timelock.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,0BAA0B,EAC1B,gBAAgB,EAChB,oBAAoB,EACpB,eAAe,EACf,aAAa,EACb,YAAY,EACZ,UAAU,EACV,WAAW,GACZ,MAAM,OAAO,CAAC;AACf,OAAO,EAGL,QAAQ,EACR,MAAM,
|
|
1
|
+
{"version":3,"file":"timelock.js","sourceRoot":"","sources":["../../../features/defi-wrapper/timelock.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
|
-
import { logInfo, logResult, logTable,
|
|
2
|
+
import { logInfo, logResult, logTable, showSpinner, createPDGProof, confirmMakeProof, callReadMethodSilent, } from '../../utils/index.js';
|
|
3
3
|
import { getStakingVaultContract, } from '../../contracts/index.js';
|
|
4
|
-
import { VALIDATOR_STAGES } from '
|
|
4
|
+
import { VALIDATOR_STAGES } from 'features/pdg.js';
|
|
5
5
|
export const checkValidatorStageAndStagedBalanceForActivation = async (pdgContract, pubkey) => {
|
|
6
6
|
const { stage, stakingVault } = await callReadMethodSilent({
|
|
7
7
|
contract: pdgContract,
|
|
@@ -54,13 +54,13 @@ export const makePDGProofByIndex = async (validatorIndex) => {
|
|
|
54
54
|
}
|
|
55
55
|
catch (err) {
|
|
56
56
|
hideSpinner();
|
|
57
|
-
printError(err, 'Error when making proof');
|
|
58
57
|
throw err;
|
|
59
58
|
}
|
|
60
59
|
};
|
|
61
60
|
export const makePDGProofByIndexes = async (indexes) => {
|
|
62
61
|
const witnesses = [];
|
|
63
|
-
for (const index of indexes) {
|
|
62
|
+
for (const [i, index] of indexes.entries()) {
|
|
63
|
+
logInfo(`--- Validator ${i + 1}/${indexes.length} [index: ${index}] ---`);
|
|
64
64
|
const validatorIndex = await confirmMakeProof(index);
|
|
65
65
|
if (!validatorIndex)
|
|
66
66
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"make-pdg-proof.js","sourceRoot":"","sources":["../../../features/deposits/make-pdg-proof.ts"],"names":[],"mappings":"AAAA,OAAO,EAAO,WAAW,EAAE,MAAM,MAAM,CAAC;AAExC,OAAO,EACL,OAAO,EACP,SAAS,EACT,QAAQ,EACR,
|
|
1
|
+
{"version":3,"file":"make-pdg-proof.js","sourceRoot":"","sources":["../../../features/deposits/make-pdg-proof.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,8 +17,8 @@ export const checkValidatorInfo = async (validator) => {
|
|
|
17
17
|
message += `Validator is slashed. (slashed: ${validator.slashed})\n`;
|
|
18
18
|
isValid = false;
|
|
19
19
|
}
|
|
20
|
-
logError(message);
|
|
21
20
|
if (!isValid) {
|
|
21
|
+
logError(message);
|
|
22
22
|
const confirm = await confirmOperation(`Do you want to skip this validator (pubkey: ${validator.pubkey})?`);
|
|
23
23
|
if (!confirm) {
|
|
24
24
|
throw new Error('Operation cancelled');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../features/deposits/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAO,MAAM,MAAM,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAS5D,MAAM,0BAA0B,GAAG,WAAW,CAAC;AAC/C,MAAM,mBAAmB,GAAG,QAAQ,CAAC;AAErC,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EAAE,SAAwB,EAAE,EAAE;IACnE,IAAI,OAAO,GAAG,EAAE,CAAC;IACjB,IAAI,OAAO,GAAG,IAAI,CAAC;IACnB,IAAI,SAAS,CAAC,gBAAgB,GAAG,0BAA0B,EAAE,CAAC;QAC5D,OAAO,IAAI,4CAA4C,WAAW,CAAC,MAAM,CAAC,0BAA0B,CAAC,EAAE,MAAM,CAAC,kBAAkB,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC;QACjM,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC;IAED,IAAI,SAAS,CAAC,eAAe,KAAK,mBAAmB,EAAE,CAAC;QACtD,OAAO,IAAI,iDAAiD,SAAS,CAAC,eAAe,KAAK,CAAC;QAC3F,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC;IAED,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;QACtB,OAAO,IAAI,mCAAmC,SAAS,CAAC,OAAO,KAAK,CAAC;QACrE,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC;IAED,
|
|
1
|
+
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../features/deposits/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAO,MAAM,MAAM,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAS5D,MAAM,0BAA0B,GAAG,WAAW,CAAC;AAC/C,MAAM,mBAAmB,GAAG,QAAQ,CAAC;AAErC,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EAAE,SAAwB,EAAE,EAAE;IACnE,IAAI,OAAO,GAAG,EAAE,CAAC;IACjB,IAAI,OAAO,GAAG,IAAI,CAAC;IACnB,IAAI,SAAS,CAAC,gBAAgB,GAAG,0BAA0B,EAAE,CAAC;QAC5D,OAAO,IAAI,4CAA4C,WAAW,CAAC,MAAM,CAAC,0BAA0B,CAAC,EAAE,MAAM,CAAC,kBAAkB,WAAW,CAAC,MAAM,CAAC,SAAS,CAAC,gBAAgB,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC;QACjM,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC;IAED,IAAI,SAAS,CAAC,eAAe,KAAK,mBAAmB,EAAE,CAAC;QACtD,OAAO,IAAI,iDAAiD,SAAS,CAAC,eAAe,KAAK,CAAC;QAC3F,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC;IAED,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;QACtB,OAAO,IAAI,mCAAmC,SAAS,CAAC,OAAO,KAAK,CAAC;QACrE,OAAO,GAAG,KAAK,CAAC;IAClB,CAAC;IAED,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,QAAQ,CAAC,OAAO,CAAC,CAAC;QAClB,MAAM,OAAO,GAAG,MAAM,gBAAgB,CACpC,+CAA+C,SAAS,CAAC,MAAM,IAAI,CACpE,CAAC;QAEF,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzC,CAAC;QAED,OAAO,CAAC,qCAAqC,CAAC,CAAC;QAE/C,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAClC,CAAC,CAAC"}
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
+
import { NOFeeSnapshot } from 'utils/statistic/report-statistic.js';
|
|
2
|
+
import { VaultReport } from 'utils/report/types.js';
|
|
1
3
|
import { DashboardContract } from '../contracts/index.js';
|
|
2
4
|
export declare const getNodeOperatorFeeRatesByBlockNumbers: (vaultAddress: string, blockNumbers: number[], dashboardContract: DashboardContract) => Promise<bigint[]>;
|
|
3
5
|
export declare const getSettledGrowthsByBlockNumbers: (vaultAddress: string, blockNumbers: number[], dashboardContract: DashboardContract) => Promise<bigint[]>;
|
|
4
6
|
export declare const getNodeOperatorAccruedFeeByBlockNumbers: (vaultAddress: string, blockNumbers: number[], dashboardContract: DashboardContract) => Promise<bigint[]>;
|
|
7
|
+
export declare const getNOFeeSnapshotsByBlockNumbers: (vaultAddress: string, blockNumbers: number[], dashboardContract: DashboardContract, history: VaultReport[]) => Promise<NOFeeSnapshot[]>;
|
package/dist/features/metrics.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { callReadMethodSilent, cache } from '../utils/index.js';
|
|
2
|
+
import { calcAccruedFeeOffChain, } from 'utils/statistic/report-statistic.js';
|
|
2
3
|
export const getNodeOperatorFeeRatesByBlockNumbers = async (vaultAddress, blockNumbers, dashboardContract) => {
|
|
3
4
|
// Get nodeOperatorFeeBP for each report block with caching
|
|
4
5
|
const nodeOperatorFeeBPs = [];
|
|
@@ -63,4 +64,28 @@ export const getNodeOperatorAccruedFeeByBlockNumbers = async (vaultAddress, bloc
|
|
|
63
64
|
}
|
|
64
65
|
return nodeOperatorAccruedFees;
|
|
65
66
|
};
|
|
67
|
+
// Builds NOFeeSnapshot[] aligned with `history` (one snapshot per report).
|
|
68
|
+
// accruedFee is computed off-chain from IPFS data so it is correct even when
|
|
69
|
+
// the vault owner hasn't called updateVaultData for the latest report.
|
|
70
|
+
// quarantineValue is treated as 0 (option A: rare event, timing unreliable).
|
|
71
|
+
export const getNOFeeSnapshotsByBlockNumbers = async (vaultAddress, blockNumbers, dashboardContract, history) => {
|
|
72
|
+
const [settledGrowths, feeRates] = await Promise.all([
|
|
73
|
+
getSettledGrowthsByBlockNumbers(vaultAddress, blockNumbers, dashboardContract),
|
|
74
|
+
getNodeOperatorFeeRatesByBlockNumbers(vaultAddress, blockNumbers, dashboardContract),
|
|
75
|
+
]);
|
|
76
|
+
return blockNumbers.map((_, i) => {
|
|
77
|
+
const report = history[i];
|
|
78
|
+
const settledGrowth = settledGrowths[i] ?? 0n;
|
|
79
|
+
const feeRate = feeRates[i] ?? 0n;
|
|
80
|
+
const accruedFee = report
|
|
81
|
+
? calcAccruedFeeOffChain({
|
|
82
|
+
totalValueWei: BigInt(report.data.totalValueWei),
|
|
83
|
+
inOutDelta: BigInt(report.extraData.inOutDelta),
|
|
84
|
+
settledGrowth,
|
|
85
|
+
feeRate,
|
|
86
|
+
})
|
|
87
|
+
: 0n;
|
|
88
|
+
return { accruedFee, settledGrowth, feeRate };
|
|
89
|
+
});
|
|
90
|
+
};
|
|
66
91
|
//# sourceMappingURL=metrics.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../features/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../features/metrics.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { getStethContract } from '../../contracts/index.js';
|
|
2
|
-
import { bigIntMax, bigIntMin } from '
|
|
2
|
+
import { bigIntMax, bigIntMin } from 'utils/bigInt.js';
|
|
3
3
|
export const vaultMintLimit = async (dashboard, ethToAdd = 0n) => {
|
|
4
4
|
const lido = await getStethContract();
|
|
5
5
|
const [totalMintingCapacityShares, remainingMintingCapacityShares, liabilityShares, lidoExternalShares, lidoMaxMintableExternalShares,] = await Promise.all([
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
2
|
import { logError } from '../../utils/index.js';
|
|
3
|
-
import { vaultMintLimit } from '
|
|
3
|
+
import { vaultMintLimit } from 'features/mint-burn/mint-limit.js';
|
|
4
4
|
export const checkMintingCapacity = async (contract, amountOfShares) => {
|
|
5
5
|
const { remainingMintingCapacityShares } = await vaultMintLimit(contract);
|
|
6
6
|
if (remainingMintingCapacityShares < amountOfShares) {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { parseEventLogs, parseEther, } from 'viem';
|
|
2
2
|
import { getDashboardContract, getStakingVaultContract, getVaultFactoryContract, } from '../contracts/index.js';
|
|
3
|
-
import { VaultFactoryAbi } from '
|
|
3
|
+
import { VaultFactoryAbi } from 'abi/index.js';
|
|
4
4
|
import { callWriteMethodWithReceipt, logResult, printError, showSpinner, logError, transformAddressesToArray, validateAddressesMap, validateAddressMap, logInfo, callReadMethodSilent, } from '../utils/index.js';
|
|
5
5
|
import { program } from '../command/index.js';
|
|
6
6
|
export const isCreateVaultResult = (result) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../features/vault-operations/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../features/vault-operations/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export type ResolvedShareLimit = {
|
|
2
|
+
shares: bigint;
|
|
3
|
+
/** Human-readable label for confirmation prompts.
|
|
4
|
+
* Without --steth: "1000.0 shares"
|
|
5
|
+
* With --steth: "1000.0 shares (1001.5 stETH)" */
|
|
6
|
+
label: string;
|
|
7
|
+
};
|
|
8
|
+
export declare const resolveStethShareLimit: (amount: bigint, isSteth: boolean) => Promise<ResolvedShareLimit>;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { formatEther } from 'viem';
|
|
2
|
+
import { getStethContract } from '../../contracts/index.js';
|
|
3
|
+
import { callReadMethodSilent, logInfo } from '../../utils/index.js';
|
|
4
|
+
export const resolveStethShareLimit = async (amount, isSteth) => {
|
|
5
|
+
if (!isSteth) {
|
|
6
|
+
return { shares: amount, label: `${formatEther(amount)} shares` };
|
|
7
|
+
}
|
|
8
|
+
const stethContract = await getStethContract();
|
|
9
|
+
const shares = await callReadMethodSilent({
|
|
10
|
+
contract: stethContract,
|
|
11
|
+
methodName: 'getSharesByPooledEth',
|
|
12
|
+
payload: [[amount]],
|
|
13
|
+
});
|
|
14
|
+
logInfo(`Converting ${formatEther(amount)} stETH → ${formatEther(shares)} shares`);
|
|
15
|
+
return {
|
|
16
|
+
shares,
|
|
17
|
+
label: `${formatEther(shares)} shares (${formatEther(amount)} stETH)`,
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=share-limit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"share-limit.js","sourceRoot":"","sources":["../../../features/vault-operations/share-limit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;AACnC,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAUtD,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EACzC,MAAc,EACd,OAAgB,EACa,EAAE;IAC/B,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,WAAW,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;IACpE,CAAC;IAED,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;IAC/C,MAAM,MAAM,GAAG,MAAM,oBAAoB,CAAC;QACxC,QAAQ,EAAE,aAAa;QACvB,UAAU,EAAE,sBAAsB;QAClC,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;KACpB,CAAC,CAAC;IAEH,OAAO,CACL,cAAc,WAAW,CAAC,MAAM,CAAC,YAAY,WAAW,CAAC,MAAM,CAAC,SAAS,CAC1E,CAAC;IAEF,OAAO;QACL,MAAM;QACN,KAAK,EAAE,GAAG,WAAW,CAAC,MAAM,CAAC,YAAY,WAAW,CAAC,MAAM,CAAC,SAAS;KACtE,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Address } from 'viem';
|
|
2
|
-
import { PartialContract, PopulatedTx, WriteTxArgs } from '
|
|
2
|
+
import { PartialContract, PopulatedTx, WriteTxArgs } from 'utils/transactions/types.js';
|
|
3
3
|
export declare const callWriteMethodsWithReportFresh: <T extends PartialContract, M extends keyof T["write"] & string>(args: WriteTxArgs<T, M> & {
|
|
4
4
|
calls?: PopulatedTx[];
|
|
5
5
|
vault: Address;
|
package/dist/index.js
CHANGED
|
@@ -5,7 +5,7 @@ import { program } from './command/index.js';
|
|
|
5
5
|
import { logError, logInfo } from './utils/logging/console.js';
|
|
6
6
|
import { withInterruptHandling } from './utils/interrupt-handler.js';
|
|
7
7
|
import './programs/index.js';
|
|
8
|
-
import { disconnectWalletConnect } from './utils/index.js';
|
|
8
|
+
import { closeJsonLogging, disconnectWalletConnect, logJson, openJsonLogging, } from './utils/index.js';
|
|
9
9
|
export * from './utils/index.js';
|
|
10
10
|
const showTestnetWarning = () => {
|
|
11
11
|
console.info('\nHOODI V3 application:');
|
|
@@ -28,6 +28,8 @@ const showMainnetWarning = () => {
|
|
|
28
28
|
};
|
|
29
29
|
program.addHelpText('afterAll', () => {
|
|
30
30
|
const chain = process.env.CHAIN_ID;
|
|
31
|
+
if (program.opts().json)
|
|
32
|
+
return '';
|
|
31
33
|
if (chain === String(mainnet.id)) {
|
|
32
34
|
showMainnetWarning();
|
|
33
35
|
}
|
|
@@ -38,25 +40,43 @@ program.addHelpText('afterAll', () => {
|
|
|
38
40
|
});
|
|
39
41
|
// Add interrupt handling to the CLI
|
|
40
42
|
const runCLI = withInterruptHandling(async () => {
|
|
43
|
+
// programm.opts is not init yet
|
|
44
|
+
const isJson = process.argv.includes('--json');
|
|
41
45
|
const chain = await getChain();
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
46
|
+
if (isJson) {
|
|
47
|
+
openJsonLogging();
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
logInfo(`${'-'.repeat(100)}`);
|
|
51
|
+
logInfo(`Using chain: Name: ${chain.name}, Chain ID: ${chain.id}`);
|
|
52
|
+
logInfo(`${'-'.repeat(100)}`);
|
|
53
|
+
}
|
|
45
54
|
await program.parseAsync(process.argv);
|
|
46
55
|
});
|
|
47
56
|
runCLI()
|
|
48
57
|
.catch(async (error) => {
|
|
49
|
-
|
|
50
|
-
|
|
58
|
+
await disconnectWalletConnect().catch(() => { });
|
|
59
|
+
if (program.opts().json) {
|
|
60
|
+
logJson({ error: error.message });
|
|
61
|
+
closeJsonLogging();
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
logError('CLI Error:', error.message);
|
|
65
|
+
}
|
|
51
66
|
process.exit(1);
|
|
52
67
|
})
|
|
53
68
|
.finally(async () => {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
showMainnetWarning();
|
|
69
|
+
if (program.opts().json) {
|
|
70
|
+
closeJsonLogging();
|
|
57
71
|
}
|
|
58
72
|
else {
|
|
59
|
-
|
|
73
|
+
const chain = await getChain();
|
|
74
|
+
if (chain.id === mainnet.id) {
|
|
75
|
+
showMainnetWarning();
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
showTestnetWarning();
|
|
79
|
+
}
|
|
60
80
|
}
|
|
61
81
|
await disconnectWalletConnect();
|
|
62
82
|
// If the command is not charts, exit
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AACrE,OAAO,qBAAqB,CAAC;AAC7B,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const account: import("commander").Command;
|
|
1
|
+
export declare const account: import("node_modules/commander/typings/index.js").Command;
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { formatEther } from 'viem';
|
|
2
2
|
import { mainnet } from 'viem/chains';
|
|
3
3
|
import { generatePrivateKey, privateKeyToAccount } from 'viem/accounts';
|
|
4
|
-
import { Option } from 'commander';
|
|
4
|
+
import { Option, program } from 'commander';
|
|
5
5
|
import { Keystore } from 'ox';
|
|
6
6
|
import { getStethContract, getWstethContract } from '../../contracts/index.js';
|
|
7
7
|
import { getChain } from '../../configs/index.js';
|
|
8
|
-
import { getCommandsJson, logInfo, callWriteMethodWithReceipt, stringToAddress, confirmOperation, etherToWei, } from '../../utils/index.js';
|
|
8
|
+
import { getCommandsJson, logInfo, callWriteMethodWithReceipt, stringToAddress, confirmOperation, etherToWei, stringToHex, stringToBigInt, callWCWriteMethodWithReceipt, callWriteMethod, } from '../../utils/index.js';
|
|
9
9
|
import { account } from './main.js';
|
|
10
10
|
const accountWrite = account
|
|
11
11
|
.command('write')
|
|
@@ -84,4 +84,31 @@ accountWrite
|
|
|
84
84
|
payload: [address, amount],
|
|
85
85
|
});
|
|
86
86
|
});
|
|
87
|
+
accountWrite
|
|
88
|
+
.command('send-tx')
|
|
89
|
+
.description('sends populated transaction')
|
|
90
|
+
.option('-t, --to [toAddress]', 'Address to send transaction to', stringToAddress)
|
|
91
|
+
.option('-d, --data [data]', 'Data to use for transaction, default no data', stringToHex, '0x')
|
|
92
|
+
.option('-v, --value [valueWei]', 'ETH value in wei to send with transaction', stringToBigInt, 0n)
|
|
93
|
+
.action(async ({ to, data, value }) => {
|
|
94
|
+
if (program.opts().walletConnect) {
|
|
95
|
+
await callWCWriteMethodWithReceipt({
|
|
96
|
+
calls: [
|
|
97
|
+
{
|
|
98
|
+
data,
|
|
99
|
+
to,
|
|
100
|
+
value,
|
|
101
|
+
},
|
|
102
|
+
],
|
|
103
|
+
withSpinner: true,
|
|
104
|
+
});
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
await callWriteMethod({
|
|
108
|
+
contract: { address: to, abi: [] },
|
|
109
|
+
methodName: data,
|
|
110
|
+
value,
|
|
111
|
+
payload: [],
|
|
112
|
+
});
|
|
113
|
+
});
|
|
87
114
|
//# sourceMappingURL=write.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../programs/account/write.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,WAAW,
|
|
1
|
+
{"version":3,"file":"write.js","sourceRoot":"","sources":["../../../programs/account/write.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const dashboard: import("commander").Command;
|
|
1
|
+
export declare const dashboard: import("node_modules/commander/typings/index.js").Command;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { parseEther, formatEther } from 'viem';
|
|
2
2
|
import { Option } from 'commander';
|
|
3
3
|
import { getDashboardContract, getOperatorGridContract, getPredepositGuaranteeContract, getStakingVaultContract, } from '../../../contracts/index.js';
|
|
4
|
-
import { mintShares, burnShares, mintSteth, burnSteth, checkBLSDeposits, checkPdgIsPaused, callWriteMethodsWithReportFresh, checkValidatorInfo, } from '../../../features/index.js';
|
|
4
|
+
import { mintShares, burnShares, mintSteth, burnSteth, checkBLSDeposits, checkPdgIsPaused, callWriteMethodsWithReportFresh, checkValidatorInfo, resolveStethShareLimit, } from '../../../features/index.js';
|
|
5
5
|
import { callReadMethod, callWriteMethodWithReceipt, jsonToRoleAssignment, confirmOperation, stringToBigInt, parseDepositArray, logInfo, getCommandsJson, stringToAddress, createPDGProof, confirmProposal, formatBP, callReadMethodSilent, showSpinner, stringToBigIntArrayWei, stringToHexArray, etherToWei, stringToNumber, logError, } from '../../../utils/index.js';
|
|
6
6
|
import { dashboard } from './main.js';
|
|
7
7
|
const dashboardWrite = dashboard
|
|
@@ -130,7 +130,8 @@ dashboardWrite
|
|
|
130
130
|
.argument('<amounts>', 'amounts of ether to withdraw. Comma separated list of amounts', stringToBigIntArrayWei)
|
|
131
131
|
.argument('<recipient>', 'address of the recipient', stringToAddress)
|
|
132
132
|
.action(async (address, pubkeys, amounts, recipient) => {
|
|
133
|
-
const mergedPubkeys =
|
|
133
|
+
const mergedPubkeys = ('0x' +
|
|
134
|
+
pubkeys.map((pubkey) => pubkey.replace(/^0x/, '')).join(''));
|
|
134
135
|
const contract = await getDashboardContract(address);
|
|
135
136
|
const vault = await callReadMethod({
|
|
136
137
|
contract,
|
|
@@ -621,10 +622,11 @@ dashboardWrite
|
|
|
621
622
|
.description('changes the tier of the vault and connects to VaultHub')
|
|
622
623
|
.argument('<address>', 'dashboard address', stringToAddress)
|
|
623
624
|
.argument('<tier>', 'tier to change to', stringToBigInt)
|
|
624
|
-
.argument('<requestedShareLimit>', 'requested new share limit for the vault (in shares)', etherToWei)
|
|
625
|
+
.argument('<requestedShareLimit>', 'requested new share limit for the vault (in shares by default, or in stETH if --steth flag is provided)', etherToWei)
|
|
625
626
|
.option('-f, --fund', 'optional fund the vault with 1 ETH', false)
|
|
627
|
+
.option('--steth', 'interpret requestedShareLimit as stETH value and convert to shares on-chain', false)
|
|
626
628
|
.addHelpText('after', `Reverts if settledGrowth is not corrected after the vault is disconnected`)
|
|
627
|
-
.action(async (address, tier, requestedShareLimit, { fund }) => {
|
|
629
|
+
.action(async (address, tier, requestedShareLimit, { fund, steth }) => {
|
|
628
630
|
const contract = await getDashboardContract(address);
|
|
629
631
|
const vault = await callReadMethod({
|
|
630
632
|
contract,
|
|
@@ -636,15 +638,16 @@ dashboardWrite
|
|
|
636
638
|
methodName: 'settledGrowth',
|
|
637
639
|
payload: [],
|
|
638
640
|
});
|
|
641
|
+
const { shares: resolvedShareLimit, label: shareLimitLabel } = await resolveStethShareLimit(requestedShareLimit, steth);
|
|
639
642
|
const confirm = await confirmOperation(`Are you sure you want to change the tier of the vault ${vault} to ${tier} and connect to VaultHub?
|
|
640
|
-
Requested share limit: ${
|
|
643
|
+
Requested share limit: ${shareLimitLabel}
|
|
641
644
|
Current settled growth: ${formatEther(currentSettledGrowth)}`);
|
|
642
645
|
if (!confirm)
|
|
643
646
|
return;
|
|
644
647
|
await callWriteMethodWithReceipt({
|
|
645
648
|
contract,
|
|
646
649
|
methodName: 'connectAndAcceptTier',
|
|
647
|
-
payload: [tier,
|
|
650
|
+
payload: [tier, resolvedShareLimit],
|
|
648
651
|
value: fund ? parseEther('1') : undefined,
|
|
649
652
|
});
|
|
650
653
|
});
|
|
@@ -814,21 +817,23 @@ dashboardWrite
|
|
|
814
817
|
.description('vault tier change with multi-role confirmation')
|
|
815
818
|
.argument('<address>', 'dashboard address', stringToAddress)
|
|
816
819
|
.argument('<tierId>', 'tier id', stringToBigInt)
|
|
817
|
-
.argument('<requestedShareLimit>', 'requested share limit (in shares)', etherToWei)
|
|
818
|
-
.
|
|
820
|
+
.argument('<requestedShareLimit>', 'requested share limit (in shares by default, or in stETH if --steth flag is provided)', etherToWei)
|
|
821
|
+
.option('--steth', 'interpret requestedShareLimit as stETH value and convert to shares on-chain', false)
|
|
822
|
+
.action(async (address, tierId, requestedShareLimit, { steth }) => {
|
|
819
823
|
const contract = await getDashboardContract(address);
|
|
820
824
|
const vault = await callReadMethod({
|
|
821
825
|
contract,
|
|
822
826
|
methodName: 'stakingVault',
|
|
823
827
|
payload: [],
|
|
824
828
|
});
|
|
825
|
-
const
|
|
829
|
+
const { shares: shareLimit, label: shareLimitLabel } = await resolveStethShareLimit(requestedShareLimit, steth);
|
|
830
|
+
const confirm = await confirmOperation(`Are you sure you want to change the current tier to tier ID ${tierId} for vault ${vault} with share limit ${shareLimitLabel}?`);
|
|
826
831
|
if (!confirm)
|
|
827
832
|
return;
|
|
828
833
|
await callWriteMethodWithReceipt({
|
|
829
834
|
contract,
|
|
830
835
|
methodName: 'changeTier',
|
|
831
|
-
payload: [tierId,
|
|
836
|
+
payload: [tierId, shareLimit],
|
|
832
837
|
});
|
|
833
838
|
});
|
|
834
839
|
dashboardWrite
|
|
@@ -861,21 +866,23 @@ dashboardWrite
|
|
|
861
866
|
.alias('usl')
|
|
862
867
|
.description('requests a change of share limit on the OperatorGrid')
|
|
863
868
|
.argument('<address>', 'dashboard address', stringToAddress)
|
|
864
|
-
.argument('<shareLimit>', 'share limit', etherToWei)
|
|
865
|
-
.
|
|
869
|
+
.argument('<shareLimit>', 'share limit (in shares by default, or in stETH if --steth flag is provided)', etherToWei)
|
|
870
|
+
.option('--steth', 'interpret shareLimit as stETH value and convert to shares on-chain', false)
|
|
871
|
+
.action(async (address, shareLimit, { steth }) => {
|
|
866
872
|
const contract = await getDashboardContract(address);
|
|
867
873
|
const vault = await callReadMethod({
|
|
868
874
|
contract,
|
|
869
875
|
methodName: 'stakingVault',
|
|
870
876
|
payload: [],
|
|
871
877
|
});
|
|
872
|
-
const
|
|
878
|
+
const { shares: resolvedShareLimit, label: shareLimitLabel } = await resolveStethShareLimit(shareLimit, steth);
|
|
879
|
+
const confirm = await confirmOperation(`Are you sure you want to request a change of share limit on the OperatorGrid for the vault ${vault} to ${shareLimitLabel}?`);
|
|
873
880
|
if (!confirm)
|
|
874
881
|
return;
|
|
875
882
|
await callWriteMethodWithReceipt({
|
|
876
883
|
contract,
|
|
877
884
|
methodName: 'updateShareLimit',
|
|
878
|
-
payload: [
|
|
885
|
+
payload: [resolvedShareLimit],
|
|
879
886
|
});
|
|
880
887
|
});
|
|
881
888
|
dashboardWrite
|