@lidofinance/lsv-cli 1.0.0-alpha.47 → 1.0.0-alpha.49
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 +1 -1
- package/dist/abi/Dashboard.d.ts +160 -0
- package/dist/abi/Dashboard.js +2 -0
- package/dist/abi/Dashboard.js.map +1 -1
- package/dist/abi/OperatorGrid.d.ts +166 -5
- package/dist/abi/OperatorGrid.js +15 -12
- package/dist/abi/OperatorGrid.js.map +1 -1
- package/dist/abi/VaultFactory.d.ts +504 -0
- package/dist/abi/VaultFactory.js +4 -0
- package/dist/abi/VaultFactory.js.map +1 -1
- package/dist/abi/VaultHub.d.ts +451 -106
- package/dist/abi/VaultHub.js +26 -23
- package/dist/abi/VaultHub.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 +7 -9
- package/dist/contracts/vault-factory.d.ts +9414 -1350
- package/dist/features/dashboard.js +141 -111
- package/dist/features/dashboard.js.map +1 -1
- package/dist/features/index.d.ts +0 -1
- package/dist/features/index.js +0 -1
- package/dist/features/index.js.map +1 -1
- package/dist/features/operator-grid.js +13 -6
- package/dist/features/operator-grid.js.map +1 -1
- package/dist/features/pdg.d.ts +2 -0
- package/dist/features/pdg.js +43 -7
- package/dist/features/pdg.js.map +1 -1
- package/dist/features/vault-factory.d.ts +5 -0
- package/dist/features/vault-factory.js +7 -1
- package/dist/features/vault-factory.js.map +1 -1
- package/dist/features/vault-hub.js +16 -9
- package/dist/features/vault-hub.js.map +1 -1
- package/dist/features/vault.js +9 -7
- package/dist/features/vault.js.map +1 -1
- package/dist/programs/account/index.d.ts +3 -0
- package/dist/programs/account/index.js +4 -0
- package/dist/programs/account/index.js.map +1 -0
- package/dist/programs/account/main.d.ts +1 -0
- package/dist/programs/account/main.js +5 -0
- package/dist/programs/account/main.js.map +1 -0
- package/dist/programs/account/read.js +109 -0
- package/dist/programs/account/read.js.map +1 -0
- package/dist/programs/account/write.js +65 -0
- package/dist/programs/account/write.js.map +1 -0
- package/dist/programs/dashboard/read.js +15 -6
- package/dist/programs/dashboard/read.js.map +1 -1
- package/dist/programs/dashboard/write.js +83 -11
- package/dist/programs/dashboard/write.js.map +1 -1
- package/dist/programs/hub/read.js +4 -2
- package/dist/programs/hub/read.js.map +1 -1
- package/dist/programs/index.d.ts +2 -2
- package/dist/programs/index.js +2 -2
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/metrics/index.d.ts +2 -0
- package/dist/programs/metrics/index.js +3 -0
- package/dist/programs/metrics/index.js.map +1 -0
- package/dist/programs/metrics/main.d.ts +1 -0
- package/dist/programs/metrics/main.js +3 -0
- package/dist/programs/metrics/main.js.map +1 -0
- package/dist/programs/metrics/read.d.ts +1 -0
- package/dist/programs/metrics/read.js +96 -0
- package/dist/programs/metrics/read.js.map +1 -0
- package/dist/programs/operator-grid/read.js +8 -2
- package/dist/programs/operator-grid/read.js.map +1 -1
- package/dist/programs/pdg/config.js +1 -0
- package/dist/programs/pdg/config.js.map +1 -1
- package/dist/programs/pdg/read.js +18 -4
- package/dist/programs/pdg/read.js.map +1 -1
- package/dist/programs/pdg/write.js +82 -78
- package/dist/programs/pdg/write.js.map +1 -1
- package/dist/programs/pdg-helpers.js +32 -27
- package/dist/programs/pdg-helpers.js.map +1 -1
- package/dist/programs/report/write.js +2 -37
- package/dist/programs/report/write.js.map +1 -1
- package/dist/programs/vault/write.js +13 -13
- package/dist/programs/vault/write.js.map +1 -1
- package/dist/programs/vault-factory/write.js +16 -2
- package/dist/programs/vault-factory/write.js.map +1 -1
- package/dist/programs/vault-viewer/read.js +31 -16
- package/dist/programs/vault-viewer/read.js.map +1 -1
- package/dist/providers/wallet.d.ts +11 -11
- package/dist/providers/wallet.js +3 -2
- package/dist/providers/wallet.js.map +1 -1
- package/dist/tests/__mocks__/@lodestar/types.d.ts +1 -0
- package/dist/tests/__mocks__/@lodestar/types.js +6 -0
- package/dist/tests/__mocks__/@lodestar/types.js.map +1 -0
- package/dist/tests/utils/arguments.test.d.ts +1 -0
- package/dist/tests/utils/arguments.test.js +92 -0
- package/dist/tests/utils/arguments.test.js.map +1 -0
- package/dist/tests/utils/calculate-overview.test.d.ts +1 -0
- package/dist/tests/utils/calculate-overview.test.js +30 -0
- package/dist/tests/utils/calculate-overview.test.js.map +1 -0
- package/dist/tests/utils/data-validators.test.d.ts +1 -0
- package/dist/tests/utils/data-validators.test.js +56 -0
- package/dist/tests/utils/data-validators.test.js.map +1 -0
- package/dist/tests/utils/error-handler.test.d.ts +1 -0
- package/dist/tests/utils/error-handler.test.js +51 -0
- package/dist/tests/utils/error-handler.test.js.map +1 -0
- package/dist/tests/utils/fetchCL.test.d.ts +1 -0
- package/dist/tests/utils/fetchCL.test.js +57 -0
- package/dist/tests/utils/fetchCL.test.js.map +1 -0
- package/dist/tests/utils/get-commands.test.d.ts +1 -0
- package/dist/tests/utils/get-commands.test.js +19 -0
- package/dist/tests/utils/get-commands.test.js.map +1 -0
- package/dist/tests/utils/get-deposit-data-root.test.d.ts +1 -0
- package/dist/tests/utils/get-deposit-data-root.test.js +31 -0
- package/dist/tests/utils/get-deposit-data-root.test.js.map +1 -0
- package/dist/tests/utils/get-value.test.d.ts +1 -0
- package/dist/tests/utils/get-value.test.js +13 -0
- package/dist/tests/utils/get-value.test.js.map +1 -0
- package/dist/tests/utils/health.test.d.ts +1 -0
- package/dist/tests/utils/health.test.js +22 -0
- package/dist/tests/utils/health.test.js.map +1 -0
- package/dist/tests/utils/interrupt-handler.test.d.ts +1 -0
- package/dist/tests/utils/interrupt-handler.test.js +15 -0
- package/dist/tests/utils/interrupt-handler.test.js.map +1 -0
- package/dist/tests/utils/ipfs.test.d.ts +1 -0
- package/dist/tests/utils/ipfs.test.js +98 -0
- package/dist/tests/utils/ipfs.test.js.map +1 -0
- package/dist/tests/utils/logging.test.d.ts +1 -0
- package/dist/tests/utils/logging.test.js +23 -0
- package/dist/tests/utils/logging.test.js.map +1 -0
- package/dist/tests/utils/report-proof.test.d.ts +1 -0
- package/dist/tests/utils/report-proof.test.js +29 -0
- package/dist/tests/utils/report-proof.test.js.map +1 -0
- package/dist/tests/utils/report-statistic.test.d.ts +1 -0
- package/dist/tests/utils/report-statistic.test.js +247 -0
- package/dist/tests/utils/report-statistic.test.js.map +1 -0
- package/dist/tests/utils/required-lock.test.d.ts +1 -0
- package/dist/tests/utils/required-lock.test.js +26 -0
- package/dist/tests/utils/required-lock.test.js.map +1 -0
- package/dist/tests/utils/resove-path.test.d.ts +1 -0
- package/dist/tests/utils/resove-path.test.js +18 -0
- package/dist/tests/utils/resove-path.test.js.map +1 -0
- package/dist/tests/utils/sleep.test.d.ts +1 -0
- package/dist/tests/utils/sleep.test.js +14 -0
- package/dist/tests/utils/sleep.test.js.map +1 -0
- package/dist/utils/arguments.d.ts +1 -0
- package/dist/utils/arguments.js +4 -1
- package/dist/utils/arguments.js.map +1 -1
- package/dist/utils/cache.d.ts +18 -0
- package/dist/utils/cache.js +109 -0
- package/dist/utils/cache.js.map +1 -0
- package/dist/utils/calculate-overview-v2.d.ts +28 -0
- package/dist/utils/calculate-overview-v2.js +57 -0
- package/dist/utils/calculate-overview-v2.js.map +1 -0
- package/dist/utils/calculate-overview.d.ts +1 -0
- package/dist/utils/calculate-overview.js +4 -1
- package/dist/utils/calculate-overview.js.map +1 -1
- package/dist/utils/charts/blessed/charts-apr.d.ts +91 -0
- package/dist/utils/charts/blessed/charts-apr.js +119 -0
- package/dist/utils/charts/blessed/charts-apr.js.map +1 -0
- package/dist/utils/charts/blessed/charts-rewards.d.ts +67 -0
- package/dist/utils/charts/blessed/charts-rewards.js +106 -0
- package/dist/utils/charts/blessed/charts-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/constants.d.ts +22 -0
- package/dist/utils/charts/blessed/constants.js +23 -0
- package/dist/utils/charts/blessed/constants.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.d.ts +19 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js +34 -0
- package/dist/utils/charts/blessed/datasets/bottom-line.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/efficiency.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/efficiency.js +33 -0
- package/dist/utils/charts/blessed/datasets/efficiency.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.js +33 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.d.ts +24 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js +39 -0
- package/dist/utils/charts/blessed/datasets/gross-staking-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/index.d.ts +9 -0
- package/dist/utils/charts/blessed/datasets/index.js +10 -0
- package/dist/utils/charts/blessed/datasets/index.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.d.ts +19 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.js +34 -0
- package/dist/utils/charts/blessed/datasets/lido-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.js +33 -0
- package/dist/utils/charts/blessed/datasets/net-staking-apr.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.d.ts +18 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.js +33 -0
- package/dist/utils/charts/blessed/datasets/net-staking-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.d.ts +24 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js +39 -0
- package/dist/utils/charts/blessed/datasets/node-operator-rewards.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.d.ts +33 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js +133 -0
- package/dist/utils/charts/blessed/datasets/prepare-metrics.js.map +1 -0
- package/dist/utils/charts/blessed/datasets/types.d.ts +4 -0
- package/dist/utils/charts/blessed/datasets/types.js +2 -0
- package/dist/utils/charts/blessed/datasets/types.js.map +1 -0
- package/dist/utils/charts/blessed/index.d.ts +3 -0
- package/dist/utils/charts/blessed/index.js +4 -0
- package/dist/utils/charts/blessed/index.js.map +1 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.d.ts +13 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.js +19 -0
- package/dist/utils/charts/blessed/net-vs-lido-apr.js.map +1 -0
- package/dist/utils/charts/blessed/utils.d.ts +62 -0
- package/dist/utils/charts/blessed/utils.js +84 -0
- package/dist/utils/charts/blessed/utils.js.map +1 -0
- package/dist/utils/charts/index.d.ts +2 -0
- package/dist/utils/charts/index.js +2 -0
- package/dist/utils/charts/index.js.map +1 -1
- package/dist/utils/charts/metrics.d.ts +16 -0
- package/dist/utils/charts/metrics.js +160 -0
- package/dist/utils/charts/metrics.js.map +1 -0
- package/dist/utils/charts/overview.js +5 -5
- package/dist/utils/charts/overview.js.map +1 -1
- package/dist/utils/charts/simple/index.d.ts +1 -0
- package/dist/utils/charts/simple/index.js +2 -0
- package/dist/utils/charts/simple/index.js.map +1 -0
- package/dist/utils/charts/simple/simple-charts.d.ts +2 -0
- package/dist/utils/charts/simple/simple-charts.js +81 -0
- package/dist/utils/charts/simple/simple-charts.js.map +1 -0
- package/dist/utils/commands/confirmations.d.ts +21 -0
- package/dist/utils/commands/confirmations.js +99 -0
- package/dist/utils/commands/confirmations.js.map +1 -0
- package/dist/utils/commands/dashboard.d.ts +2 -2
- package/dist/utils/commands/dashboard.js +84 -47
- package/dist/utils/commands/dashboard.js.map +1 -1
- package/dist/utils/commands/index.d.ts +3 -0
- package/dist/utils/commands/index.js +3 -0
- package/dist/utils/commands/index.js.map +1 -1
- package/dist/utils/commands/report.d.ts +7 -0
- package/dist/utils/commands/report.js +41 -0
- package/dist/utils/commands/report.js.map +1 -0
- package/dist/utils/commands/utils.d.ts +6 -0
- package/dist/utils/commands/utils.js +57 -0
- package/dist/utils/commands/utils.js.map +1 -0
- package/dist/utils/contract.d.ts +10 -1
- package/dist/utils/contract.js +61 -22
- package/dist/utils/contract.js.map +1 -1
- package/dist/utils/error-handler.d.ts +1 -1
- package/dist/utils/error-handler.js +2 -2
- package/dist/utils/error-handler.js.map +1 -1
- package/dist/utils/get-deposit-data-root.d.ts +1 -1
- package/dist/utils/get-deposit-data-root.js +3 -6
- package/dist/utils/get-deposit-data-root.js.map +1 -1
- package/dist/utils/health/health-utils.js +6 -6
- package/dist/utils/health/health-utils.js.map +1 -1
- package/dist/utils/index.d.ts +7 -1
- package/dist/utils/index.js +7 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/ipfs.d.ts +1 -0
- package/dist/utils/ipfs.js +29 -4
- package/dist/utils/ipfs.js.map +1 -1
- package/dist/utils/lido-apr.d.ts +2 -0
- package/dist/utils/lido-apr.js +8 -0
- package/dist/utils/lido-apr.js.map +1 -0
- package/dist/utils/logging/console.d.ts +9 -1
- package/dist/utils/logging/console.js +15 -2
- package/dist/utils/logging/console.js.map +1 -1
- package/dist/utils/logging/constants.d.ts +2 -0
- package/dist/utils/logging/constants.js +11 -5
- package/dist/utils/logging/constants.js.map +1 -1
- package/dist/utils/prompts/confirmations.d.ts +2 -0
- package/dist/utils/prompts/confirmations.js +18 -0
- package/dist/utils/prompts/confirmations.js.map +1 -0
- package/dist/utils/prompts/dashboard.d.ts +4 -0
- package/dist/utils/prompts/dashboard.js +20 -38
- package/dist/utils/prompts/dashboard.js.map +1 -1
- package/dist/utils/prompts/default.d.ts +4 -3
- package/dist/utils/prompts/default.js +3 -0
- package/dist/utils/prompts/default.js.map +1 -1
- package/dist/utils/prompts/index.d.ts +1 -0
- package/dist/utils/prompts/index.js +1 -0
- package/dist/utils/prompts/index.js.map +1 -1
- package/dist/utils/prompts/operations.js +5 -1
- package/dist/utils/prompts/operations.js.map +1 -1
- package/dist/utils/proof/first-validator-gindex.js +6 -1
- package/dist/utils/proof/first-validator-gindex.js.map +1 -1
- package/dist/utils/proof/merkle-utils.d.ts +2 -1
- package/dist/utils/proof/merkle-utils.js.map +1 -1
- package/dist/utils/proof/proofs.d.ts +5 -280
- package/dist/utils/proof/proofs.js.map +1 -1
- package/dist/utils/rebase-rewards.d.ts +8 -0
- package/dist/utils/rebase-rewards.js +6 -0
- package/dist/utils/rebase-rewards.js.map +1 -0
- package/dist/utils/report/index.d.ts +3 -0
- package/dist/utils/report/index.js +4 -0
- package/dist/utils/report/index.js.map +1 -0
- package/dist/utils/report/report-statistic.d.ts +52 -0
- package/dist/utils/report/report-statistic.js +128 -0
- package/dist/utils/report/report-statistic.js.map +1 -0
- package/dist/utils/{report.d.ts → report/report.d.ts} +13 -11
- package/dist/utils/report/report.js +146 -0
- package/dist/utils/report/report.js.map +1 -0
- package/dist/utils/report/statistic-data.d.ts +32 -0
- package/dist/utils/report/statistic-data.js +29 -0
- package/dist/utils/report/statistic-data.js.map +1 -0
- package/dist/utils/share-rate.d.ts +1 -0
- package/dist/utils/share-rate.js +16 -0
- package/dist/utils/share-rate.js.map +1 -0
- package/dist/utils/spinner/spinners.js +5 -2
- package/dist/utils/spinner/spinners.js.map +1 -1
- package/dist/utils/spinner/spinners.json +119 -0
- package/dist/version/index.js +1 -1
- package/package.json +17 -4
- package/dist/features/voting.d.ts +0 -7
- package/dist/features/voting.js +0 -133
- package/dist/features/voting.js.map +0 -1
- package/dist/programs/account.js +0 -147
- package/dist/programs/account.js.map +0 -1
- package/dist/programs/voting.js +0 -18
- package/dist/programs/voting.js.map +0 -1
- package/dist/utils/report.js +0 -73
- package/dist/utils/report.js.map +0 -1
- /package/dist/programs/{account.d.ts → account/read.d.ts} +0 -0
- /package/dist/programs/{voting.d.ts → account/write.d.ts} +0 -0
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { fetchIPFSWithCache, IPFS_GATEWAY, logInfo, } from '../index.js';
|
|
2
|
+
export const getVaultReport = async (args) => {
|
|
3
|
+
const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
4
|
+
const report = await fetchIPFSWithCache({
|
|
5
|
+
cid,
|
|
6
|
+
gateway,
|
|
7
|
+
bigNumberType,
|
|
8
|
+
});
|
|
9
|
+
const vaultData = getVaultData(report, vault);
|
|
10
|
+
return vaultData;
|
|
11
|
+
};
|
|
12
|
+
export const getVaultPreviousReport = async (args) => {
|
|
13
|
+
const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
14
|
+
const report = await fetchIPFSWithCache({
|
|
15
|
+
cid,
|
|
16
|
+
gateway,
|
|
17
|
+
bigNumberType,
|
|
18
|
+
});
|
|
19
|
+
const previousReportCID = report.prevTreeCID;
|
|
20
|
+
const previousReport = await fetchIPFSWithCache({
|
|
21
|
+
cid: previousReportCID,
|
|
22
|
+
gateway,
|
|
23
|
+
bigNumberType,
|
|
24
|
+
});
|
|
25
|
+
const vaultData = getVaultData(previousReport, vault);
|
|
26
|
+
return vaultData;
|
|
27
|
+
};
|
|
28
|
+
const getVaultData = (report, vault) => {
|
|
29
|
+
const match = report.values.find((entry) => entry.value[0]?.toLowerCase() === vault.toLowerCase());
|
|
30
|
+
if (!match)
|
|
31
|
+
throw new Error('Vault not found');
|
|
32
|
+
const leaf = report.tree[match.treeIndex];
|
|
33
|
+
if (!leaf)
|
|
34
|
+
throw new Error('Leaf not found');
|
|
35
|
+
const data = {
|
|
36
|
+
vault_address: '',
|
|
37
|
+
in_out_delta: '',
|
|
38
|
+
fee: '',
|
|
39
|
+
total_value_wei: '',
|
|
40
|
+
liability_shares: '',
|
|
41
|
+
};
|
|
42
|
+
for (const [index, fieldName] of Object.entries(report.leafIndexToData)) {
|
|
43
|
+
const value = match.value[Number(index)];
|
|
44
|
+
if (value === undefined) {
|
|
45
|
+
throw new Error(`Missing value at index ${index} for field "${fieldName}"`);
|
|
46
|
+
}
|
|
47
|
+
data[fieldName] = value.toString();
|
|
48
|
+
}
|
|
49
|
+
return {
|
|
50
|
+
data,
|
|
51
|
+
leaf,
|
|
52
|
+
refSlot: report.refSlot,
|
|
53
|
+
blockNumber: report.blockNumber,
|
|
54
|
+
timestamp: report.timestamp,
|
|
55
|
+
proofsCID: report.proofsCID,
|
|
56
|
+
merkleTreeRoot: report.merkleTreeRoot,
|
|
57
|
+
prevTreeCID: report.prevTreeCID,
|
|
58
|
+
};
|
|
59
|
+
};
|
|
60
|
+
export const getVaultReportProof = async (args) => {
|
|
61
|
+
const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
62
|
+
const report = await fetchIPFSWithCache({
|
|
63
|
+
cid,
|
|
64
|
+
gateway,
|
|
65
|
+
bigNumberType,
|
|
66
|
+
});
|
|
67
|
+
const proofCID = report.proofsCID;
|
|
68
|
+
const data = await fetchIPFSWithCache({
|
|
69
|
+
cid: proofCID,
|
|
70
|
+
gateway,
|
|
71
|
+
bigNumberType,
|
|
72
|
+
});
|
|
73
|
+
const proofByVault = data.proofs[vault];
|
|
74
|
+
if (!proofByVault)
|
|
75
|
+
throw new Error('Proof not found');
|
|
76
|
+
return proofByVault;
|
|
77
|
+
};
|
|
78
|
+
export const getVaultReportProofByCid = async (args) => {
|
|
79
|
+
const { vault, cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
80
|
+
const proof = await fetchIPFSWithCache({
|
|
81
|
+
cid,
|
|
82
|
+
gateway,
|
|
83
|
+
bigNumberType,
|
|
84
|
+
});
|
|
85
|
+
const proofByVault = proof.proofs[vault];
|
|
86
|
+
if (!proofByVault)
|
|
87
|
+
throw new Error('Proof not found');
|
|
88
|
+
return proofByVault;
|
|
89
|
+
};
|
|
90
|
+
export const getAllVaultsReportProofs = async (args) => {
|
|
91
|
+
const { cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
92
|
+
const proof = await fetchIPFSWithCache({
|
|
93
|
+
cid,
|
|
94
|
+
gateway,
|
|
95
|
+
bigNumberType,
|
|
96
|
+
});
|
|
97
|
+
return proof.proofs;
|
|
98
|
+
};
|
|
99
|
+
export const getAllVaultsReports = async (args) => {
|
|
100
|
+
const { cid, gateway = IPFS_GATEWAY, bigNumberType = 'string' } = args;
|
|
101
|
+
const report = await fetchIPFSWithCache({
|
|
102
|
+
cid,
|
|
103
|
+
gateway,
|
|
104
|
+
bigNumberType,
|
|
105
|
+
});
|
|
106
|
+
const vaultReports = report.values.map((value) => getVaultData(report, value.value[0]).data);
|
|
107
|
+
return {
|
|
108
|
+
vaultReports,
|
|
109
|
+
proofsCID: report.proofsCID,
|
|
110
|
+
prevTreeCID: report.prevTreeCID,
|
|
111
|
+
};
|
|
112
|
+
};
|
|
113
|
+
/**
|
|
114
|
+
* Retrieves a chain of historical VaultReport entries using prevTreeCID, starting from the specified CID.
|
|
115
|
+
* @param args { vault, cid, gateway, bigNumberType, limit, direction }
|
|
116
|
+
* @returns Promise<VaultReport[]> — array from newest to oldest (default) or oldest to newest (if direction === 'asc')
|
|
117
|
+
*/
|
|
118
|
+
export const getVaultReportHistory = async (args) => {
|
|
119
|
+
const { vault, gateway = IPFS_GATEWAY, bigNumberType = 'string', direction = 'desc', } = args;
|
|
120
|
+
let cid = args.cid;
|
|
121
|
+
const limit = args.limit ?? 20;
|
|
122
|
+
const history = [];
|
|
123
|
+
for (let i = 0; i < limit; i++) {
|
|
124
|
+
try {
|
|
125
|
+
const report = await getVaultReport({
|
|
126
|
+
vault,
|
|
127
|
+
cid,
|
|
128
|
+
gateway,
|
|
129
|
+
bigNumberType,
|
|
130
|
+
});
|
|
131
|
+
history.push(report);
|
|
132
|
+
if (!report.prevTreeCID || report.prevTreeCID === cid)
|
|
133
|
+
break;
|
|
134
|
+
cid = report.prevTreeCID;
|
|
135
|
+
}
|
|
136
|
+
catch (e) {
|
|
137
|
+
break;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
logInfo('Report hostory cached', history.length);
|
|
141
|
+
if (direction === 'asc') {
|
|
142
|
+
return history.reverse();
|
|
143
|
+
}
|
|
144
|
+
return history;
|
|
145
|
+
};
|
|
146
|
+
//# sourceMappingURL=report.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"report.js","sourceRoot":"","sources":["../../../utils/report/report.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Address } from 'viem';
|
|
2
|
+
import { VaultReport } from './report.js';
|
|
3
|
+
type StatisticDataArgs = {
|
|
4
|
+
dashboard: Address;
|
|
5
|
+
reports: {
|
|
6
|
+
current: VaultReport;
|
|
7
|
+
previous: VaultReport;
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
export declare const getReportStatisticData: (args: StatisticDataArgs) => Promise<{
|
|
11
|
+
grossStakingRewards: bigint;
|
|
12
|
+
nodeOperatorRewards: bigint;
|
|
13
|
+
dailyLidoFees: bigint;
|
|
14
|
+
netStakingRewards: bigint;
|
|
15
|
+
grossStakingAPR: {
|
|
16
|
+
apr: bigint;
|
|
17
|
+
apr_bps: number;
|
|
18
|
+
apr_percent: number;
|
|
19
|
+
};
|
|
20
|
+
netStakingAPR: {
|
|
21
|
+
apr: bigint;
|
|
22
|
+
apr_bps: number;
|
|
23
|
+
apr_percent: number;
|
|
24
|
+
};
|
|
25
|
+
bottomLine: bigint;
|
|
26
|
+
efficiency: {
|
|
27
|
+
apr: bigint;
|
|
28
|
+
apr_bps: number;
|
|
29
|
+
apr_percent: number;
|
|
30
|
+
};
|
|
31
|
+
}>;
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { getDashboardContract } from '../../contracts/index.js';
|
|
2
|
+
import { calculateRebaseReward, callReadMethodSilent, calculateShareRate, } from '../index.js';
|
|
3
|
+
import { reportMetrics } from './report-statistic.js';
|
|
4
|
+
export const getReportStatisticData = async (args) => {
|
|
5
|
+
const { dashboard, reports } = args;
|
|
6
|
+
const dashboardContract = getDashboardContract(dashboard);
|
|
7
|
+
const reportRefBlockNumber = reports.current.blockNumber;
|
|
8
|
+
const reportPrevBlockNumber = reports.previous.blockNumber;
|
|
9
|
+
const nodeOperatorFeeBP = await callReadMethodSilent(dashboardContract, 'nodeOperatorFeeBP', {
|
|
10
|
+
blockNumber: BigInt(reportRefBlockNumber),
|
|
11
|
+
});
|
|
12
|
+
const [shareRatePrev, shareRateCurr] = await Promise.all([
|
|
13
|
+
calculateShareRate(reportPrevBlockNumber),
|
|
14
|
+
calculateShareRate(reportRefBlockNumber),
|
|
15
|
+
]);
|
|
16
|
+
const stEthLiabilityRebaseRewards = calculateRebaseReward({
|
|
17
|
+
shareRatePrev,
|
|
18
|
+
shareRateCurr,
|
|
19
|
+
sharesPrev: BigInt(reports.previous.data.liability_shares),
|
|
20
|
+
sharesCurr: BigInt(reports.current.data.liability_shares),
|
|
21
|
+
});
|
|
22
|
+
const metrics = reportMetrics({
|
|
23
|
+
reports: { current: reports.current, previous: reports.previous },
|
|
24
|
+
nodeOperatorFeeBP,
|
|
25
|
+
stEthLiabilityRebaseRewards,
|
|
26
|
+
});
|
|
27
|
+
return metrics;
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=statistic-data.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"statistic-data.js","sourceRoot":"","sources":["../../../utils/report/statistic-data.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EACL,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,OAAO,CAAC;AAGf,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAOtD,MAAM,CAAC,MAAM,sBAAsB,GAAG,KAAK,EAAE,IAAuB,EAAE,EAAE;IACtE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IACpC,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAC1D,MAAM,oBAAoB,GAAG,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC;IACzD,MAAM,qBAAqB,GAAG,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC;IAE3D,MAAM,iBAAiB,GAAG,MAAM,oBAAoB,CAClD,iBAAiB,EACjB,mBAAmB,EACnB;QACE,WAAW,EAAE,MAAM,CAAC,oBAAoB,CAAC;KAC1C,CACF,CAAC;IACF,MAAM,CAAC,aAAa,EAAE,aAAa,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACvD,kBAAkB,CAAC,qBAAqB,CAAC;QACzC,kBAAkB,CAAC,oBAAoB,CAAC;KACzC,CAAC,CAAC;IAEH,MAAM,2BAA2B,GAAG,qBAAqB,CAAC;QACxD,aAAa;QACb,aAAa;QACb,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC;QAC1D,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC;KAC1D,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,aAAa,CAAC;QAC5B,OAAO,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE;QACjE,iBAAiB;QACjB,2BAA2B;KAC5B,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const calculateShareRate: (blockNumber: number) => Promise<bigint>;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { getStethContract } from '../contracts/index.js';
|
|
2
|
+
import { callReadMethodSilent } from './index.js';
|
|
3
|
+
export const calculateShareRate = async (blockNumber) => {
|
|
4
|
+
const stEthContract = await getStethContract();
|
|
5
|
+
const [totalSupply, getTotalShares] = await Promise.all([
|
|
6
|
+
callReadMethodSilent(stEthContract, 'totalSupply', {
|
|
7
|
+
blockNumber: BigInt(blockNumber),
|
|
8
|
+
}),
|
|
9
|
+
callReadMethodSilent(stEthContract, 'getTotalShares', {
|
|
10
|
+
blockNumber: BigInt(blockNumber),
|
|
11
|
+
}),
|
|
12
|
+
]);
|
|
13
|
+
const shareRate = getTotalShares !== 0n ? (totalSupply * 10n ** 27n) / getTotalShares : 0n;
|
|
14
|
+
return shareRate;
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=share-rate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"share-rate.js","sourceRoot":"","sources":["../../utils/share-rate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAC;AAE7C,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EACrC,WAAmB,EACF,EAAE;IACnB,MAAM,aAAa,GAAG,MAAM,gBAAgB,EAAE,CAAC;IAE/C,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;QACtD,oBAAoB,CAAC,aAAa,EAAE,aAAa,EAAE;YACjD,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;SACjC,CAAC;QACF,oBAAoB,CAAC,aAAa,EAAE,gBAAgB,EAAE;YACpD,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC;SACjC,CAAC;KACH,CAAC,CAAC;IACH,MAAM,SAAS,GACb,cAAc,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;IAE3E,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC"}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import logUpdate from 'log-update';
|
|
2
2
|
import { readFileSync } from 'fs';
|
|
3
3
|
import path from 'path';
|
|
4
|
+
import { fileURLToPath } from 'url';
|
|
4
5
|
export const showSpinner = (args) => {
|
|
5
6
|
const { type = 'point', message = 'Executing...' } = args || {};
|
|
6
|
-
//
|
|
7
|
-
|
|
7
|
+
// Resolve the JSON file relative to this module so it works when the
|
|
8
|
+
// CLI is executed from any directory
|
|
9
|
+
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
10
|
+
const fullPath = path.join(__dirname, 'spinners.json');
|
|
8
11
|
const spinners = JSON.parse(readFileSync(fullPath, 'utf-8'));
|
|
9
12
|
const spinner = spinners[type || 'point'];
|
|
10
13
|
let index = 0;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spinners.js","sourceRoot":"","sources":["../../../utils/spinner/spinners.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAClC,OAAO,IAAI,MAAM,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"spinners.js","sourceRoot":"","sources":["../../../utils/spinner/spinners.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,YAAY,EAAE,MAAM,IAAI,CAAC;AAClC,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,EAAE,aAAa,EAAE,MAAM,KAAK,CAAC;AAiBpC,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,IAAW,EAAE,EAAE;IACzC,MAAM,EAAE,IAAI,GAAG,OAAO,EAAE,OAAO,GAAG,cAAc,EAAE,GAAG,IAAI,IAAI,EAAE,CAAC;IAEhE,qEAAqE;IACrE,qCAAqC;IACrC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/D,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;IACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAG1D,CAAC;IAEF,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,IAAI,OAAO,CAAC,CAAC;IAC1C,IAAI,KAAK,GAAG,CAAC,CAAC;IAEd,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;QAChC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;QAC3B,SAAS,CAAC,MAAM,CAAC,CAAC,KAAK,GAAG,EAAE,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,OAAO,EAAE,CAAC,CAAC;IACvE,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IAErB,OAAO,GAAG,EAAE;QACV,aAAa,CAAC,QAAQ,CAAC,CAAC;QACxB,SAAS,CAAC,KAAK,EAAE,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
{
|
|
2
|
+
"dots": {
|
|
3
|
+
"interval": 80,
|
|
4
|
+
"frames": ["⠋", "⠙", "⠹", "⠸", "⠼", "⠴", "⠦", "⠧", "⠇", "⠏"]
|
|
5
|
+
},
|
|
6
|
+
"dots12": {
|
|
7
|
+
"interval": 80,
|
|
8
|
+
"frames": [
|
|
9
|
+
"⢀⠀",
|
|
10
|
+
"⡀⠀",
|
|
11
|
+
"⠄⠀",
|
|
12
|
+
"⢂⠀",
|
|
13
|
+
"⡂⠀",
|
|
14
|
+
"⠅⠀",
|
|
15
|
+
"⢃⠀",
|
|
16
|
+
"⡃⠀",
|
|
17
|
+
"⠍⠀",
|
|
18
|
+
"⢋⠀",
|
|
19
|
+
"⡋⠀",
|
|
20
|
+
"⠍⠁",
|
|
21
|
+
"⢋⠁",
|
|
22
|
+
"⡋⠁",
|
|
23
|
+
"⠍⠉",
|
|
24
|
+
"⠋⠉",
|
|
25
|
+
"⠋⠉",
|
|
26
|
+
"⠉⠙",
|
|
27
|
+
"⠉⠙",
|
|
28
|
+
"⠉⠩",
|
|
29
|
+
"⠈⢙",
|
|
30
|
+
"⠈⡙",
|
|
31
|
+
"⢈⠩",
|
|
32
|
+
"⡀⢙",
|
|
33
|
+
"⠄⡙",
|
|
34
|
+
"⢂⠩",
|
|
35
|
+
"⡂⢘",
|
|
36
|
+
"⠅⡘",
|
|
37
|
+
"⢃⠨",
|
|
38
|
+
"⡃⢐",
|
|
39
|
+
"⠍⡐",
|
|
40
|
+
"⢋⠠",
|
|
41
|
+
"⡋⢀",
|
|
42
|
+
"⠍⡁",
|
|
43
|
+
"⢋⠁",
|
|
44
|
+
"⡋⠁",
|
|
45
|
+
"⠍⠉",
|
|
46
|
+
"⠋⠉",
|
|
47
|
+
"⠋⠉",
|
|
48
|
+
"⠉⠙",
|
|
49
|
+
"⠉⠙",
|
|
50
|
+
"⠉⠩",
|
|
51
|
+
"⠈⢙",
|
|
52
|
+
"⠈⡙",
|
|
53
|
+
"⠈⠩",
|
|
54
|
+
"⠀⢙",
|
|
55
|
+
"⠀⡙",
|
|
56
|
+
"⠀⠩",
|
|
57
|
+
"⠀⢘",
|
|
58
|
+
"⠀⡘",
|
|
59
|
+
"⠀⠨",
|
|
60
|
+
"⠀⢐",
|
|
61
|
+
"⠀⡐",
|
|
62
|
+
"⠀⠠",
|
|
63
|
+
"⠀⢀",
|
|
64
|
+
"⠀⡀"
|
|
65
|
+
]
|
|
66
|
+
},
|
|
67
|
+
"dotsCircle": {
|
|
68
|
+
"interval": 80,
|
|
69
|
+
"frames": ["⢎ ", "⠎⠁", "⠊⠑", "⠈⠱", " ⡱", "⢀⡰", "⢄⡠", "⢆⡀"]
|
|
70
|
+
},
|
|
71
|
+
"line": {
|
|
72
|
+
"interval": 130,
|
|
73
|
+
"frames": ["-", "\\", "|", "/"]
|
|
74
|
+
},
|
|
75
|
+
"arrow3": {
|
|
76
|
+
"interval": 120,
|
|
77
|
+
"frames": ["▹▹▹▹▹", "▸▹▹▹▹", "▹▸▹▹▹", "▹▹▸▹▹", "▹▹▹▸▹", "▹▹▹▹▸"]
|
|
78
|
+
},
|
|
79
|
+
"bouncingBar": {
|
|
80
|
+
"interval": 80,
|
|
81
|
+
"frames": [
|
|
82
|
+
"[ ]",
|
|
83
|
+
"[= ]",
|
|
84
|
+
"[== ]",
|
|
85
|
+
"[=== ]",
|
|
86
|
+
"[====]",
|
|
87
|
+
"[ ===]",
|
|
88
|
+
"[ ==]",
|
|
89
|
+
"[ =]",
|
|
90
|
+
"[ ]",
|
|
91
|
+
"[ =]",
|
|
92
|
+
"[ ==]",
|
|
93
|
+
"[ ===]",
|
|
94
|
+
"[====]",
|
|
95
|
+
"[=== ]",
|
|
96
|
+
"[== ]",
|
|
97
|
+
"[= ]"
|
|
98
|
+
]
|
|
99
|
+
},
|
|
100
|
+
"bouncingBall": {
|
|
101
|
+
"interval": 80,
|
|
102
|
+
"frames": [
|
|
103
|
+
"( ● )",
|
|
104
|
+
"( ● )",
|
|
105
|
+
"( ● )",
|
|
106
|
+
"( ● )",
|
|
107
|
+
"( ●)",
|
|
108
|
+
"( ● )",
|
|
109
|
+
"( ● )",
|
|
110
|
+
"( ● )",
|
|
111
|
+
"( ● )",
|
|
112
|
+
"(● )"
|
|
113
|
+
]
|
|
114
|
+
},
|
|
115
|
+
"point": {
|
|
116
|
+
"interval": 125,
|
|
117
|
+
"frames": ["∙∙∙", "●∙∙", "∙●∙", "∙∙●", "∙∙∙"]
|
|
118
|
+
}
|
|
119
|
+
}
|
package/dist/version/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const version = 'v1.0.0-alpha.
|
|
1
|
+
export const version = 'v1.0.0-alpha.49'
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lidofinance/lsv-cli",
|
|
3
|
-
"version": "1.0.0-alpha.
|
|
3
|
+
"version": "1.0.0-alpha.49",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"files": [
|
|
6
6
|
"dist"
|
|
@@ -9,10 +9,13 @@
|
|
|
9
9
|
"bin": "dist/index.js",
|
|
10
10
|
"scripts": {
|
|
11
11
|
"start": "tsx ./index.ts",
|
|
12
|
-
"build": "npx tsc && tsc-alias",
|
|
12
|
+
"build": "npx tsc && tsc-alias && npm run copy-assets",
|
|
13
|
+
"copy-assets": "cp utils/spinner/spinners.json dist/utils/spinner/",
|
|
13
14
|
"types": "echo 'No types yet'",
|
|
14
15
|
"lint": "eslint . --ext .ts --max-warnings 0",
|
|
15
|
-
"test": "
|
|
16
|
+
"test": "jest",
|
|
17
|
+
"test:watch": "jest --watch",
|
|
18
|
+
"test:coverage": "jest --coverage",
|
|
16
19
|
"prepare": "git config core.hooksPath .git-hooks || echo 'Not in a git repo'",
|
|
17
20
|
"prepublishOnly": "node scripts/updateVersion.cjs"
|
|
18
21
|
},
|
|
@@ -34,13 +37,16 @@
|
|
|
34
37
|
"@chainsafe/blst": "^2.2.0",
|
|
35
38
|
"@chainsafe/persistent-merkle-tree": "^1.0.1",
|
|
36
39
|
"@chainsafe/ssz": "^1.0.2",
|
|
37
|
-
"@kaiachain/ethers-ext": "^2.0.3",
|
|
38
40
|
"@lodestar/types": "^1.27.1",
|
|
41
|
+
"blessed": "^0.1.81",
|
|
42
|
+
"blessed-contrib": "^4.11.0",
|
|
39
43
|
"blockstore-core": "^5.0.2",
|
|
40
44
|
"chalk": "^5.4.1",
|
|
41
45
|
"cli-progress": "^3.12.0",
|
|
46
|
+
"cli-table3": "^0.6.5",
|
|
42
47
|
"commander": "^12.1.0",
|
|
43
48
|
"dotenv": "^16.4.5",
|
|
49
|
+
"ethers": "^6.14.3",
|
|
44
50
|
"fs-extra": "^11.3.0",
|
|
45
51
|
"ipfs-unixfs-importer": "^15.3.2",
|
|
46
52
|
"json-bigint": "^1.0.0",
|
|
@@ -53,8 +59,10 @@
|
|
|
53
59
|
"@commitlint/cli": "^17.4.4",
|
|
54
60
|
"@commitlint/config-conventional": "^17.4.4",
|
|
55
61
|
"@commitlint/prompt": "^17.4.4",
|
|
62
|
+
"@jest/globals": "^29.7.0",
|
|
56
63
|
"@lidofinance/eslint-config": "^0.48.0",
|
|
57
64
|
"@swc/core": "^1.11.21",
|
|
65
|
+
"@types/blessed": "^0.1.25",
|
|
58
66
|
"@types/cli-progress": "^3.11.6",
|
|
59
67
|
"@types/fs-extra": "^11.0.4",
|
|
60
68
|
"@types/json-bigint": "^1.0.4",
|
|
@@ -76,15 +84,20 @@
|
|
|
76
84
|
"eslint-plugin-promise": "^6",
|
|
77
85
|
"eslint-plugin-sonarjs": "^0.14.0",
|
|
78
86
|
"eslint-plugin-unicorn": "^45",
|
|
87
|
+
"jest": "^29.7.0",
|
|
79
88
|
"lint-staged": "^15.4.3",
|
|
80
89
|
"prettier": "^3.0.1",
|
|
81
90
|
"semantic-release": "^24.2.0",
|
|
91
|
+
"ts-jest": "^29.3.4",
|
|
82
92
|
"ts-node": "^10.9.2",
|
|
83
93
|
"tsc-alias": "^1.8.10",
|
|
84
94
|
"tsconfig-paths": "^4.2.0",
|
|
85
95
|
"tsx": "^4.19.3",
|
|
86
96
|
"typescript": "^5.7.2"
|
|
87
97
|
},
|
|
98
|
+
"resolutions": {
|
|
99
|
+
"xml2js": "^0.5.0"
|
|
100
|
+
},
|
|
88
101
|
"lint-staged": {
|
|
89
102
|
"./**/*.{ts,tsx}": [
|
|
90
103
|
"eslint --ignore-path .gitignore --max-warnings=0"
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { SingleBar } from 'cli-progress';
|
|
2
|
-
import { Vote } from '../types/index.js';
|
|
3
|
-
export declare const voteLastVoting: () => Promise<void>;
|
|
4
|
-
export declare const voteFor: (voteId: bigint) => Promise<void>;
|
|
5
|
-
export declare const executeVote: (voteId: bigint) => Promise<void>;
|
|
6
|
-
export declare const waitForEnd: (voteId: bigint, progressBar?: SingleBar) => Promise<void>;
|
|
7
|
-
export declare const createVoteMap: (vote: Vote) => Record<string, any>;
|
package/dist/features/voting.js
DELETED
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import progress from 'cli-progress';
|
|
2
|
-
import { getVotingContract } from '../contracts/index.js';
|
|
3
|
-
import { sleep, callReadMethod, callWriteMethodWithReceipt, logInfo, } from '../utils/index.js';
|
|
4
|
-
const voteAbi = [
|
|
5
|
-
{
|
|
6
|
-
name: 'open',
|
|
7
|
-
},
|
|
8
|
-
{
|
|
9
|
-
name: 'executed',
|
|
10
|
-
},
|
|
11
|
-
{
|
|
12
|
-
name: 'startDate',
|
|
13
|
-
},
|
|
14
|
-
{
|
|
15
|
-
name: 'snapshotBlock',
|
|
16
|
-
},
|
|
17
|
-
{
|
|
18
|
-
name: 'supportRequired',
|
|
19
|
-
},
|
|
20
|
-
{
|
|
21
|
-
name: 'minAcceptQuorum',
|
|
22
|
-
},
|
|
23
|
-
{
|
|
24
|
-
name: 'yea',
|
|
25
|
-
},
|
|
26
|
-
{
|
|
27
|
-
name: 'nay',
|
|
28
|
-
},
|
|
29
|
-
{
|
|
30
|
-
name: 'votingPower',
|
|
31
|
-
},
|
|
32
|
-
{
|
|
33
|
-
name: 'script',
|
|
34
|
-
},
|
|
35
|
-
{
|
|
36
|
-
name: 'phase',
|
|
37
|
-
},
|
|
38
|
-
];
|
|
39
|
-
export const voteLastVoting = async () => {
|
|
40
|
-
const { contract } = getVotingContract();
|
|
41
|
-
const votesLength = await callReadMethod(contract, 'votesLength');
|
|
42
|
-
const lastVoteId = votesLength - 1n;
|
|
43
|
-
if (lastVoteId === -1n) {
|
|
44
|
-
console.warn('No votes');
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
const lastVote = await contract.read.getVote([lastVoteId]);
|
|
48
|
-
const voteMap = createVoteMap(lastVote);
|
|
49
|
-
logInfo('voteLastVoting');
|
|
50
|
-
logInfo('voteMap', voteMap);
|
|
51
|
-
if (!voteMap.open) {
|
|
52
|
-
console.warn('Vote is not open');
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
if (voteMap.phase !== 0n) {
|
|
56
|
-
console.warn('Wrong phase');
|
|
57
|
-
return;
|
|
58
|
-
}
|
|
59
|
-
await voteFor(lastVoteId);
|
|
60
|
-
await waitForEnd(lastVoteId);
|
|
61
|
-
await executeVote(lastVoteId);
|
|
62
|
-
};
|
|
63
|
-
export const voteFor = async (voteId) => {
|
|
64
|
-
const { contract } = getVotingContract();
|
|
65
|
-
await callWriteMethodWithReceipt({
|
|
66
|
-
contract,
|
|
67
|
-
methodName: 'vote',
|
|
68
|
-
payload: [voteId, true, false],
|
|
69
|
-
});
|
|
70
|
-
logInfo('Vote voted', voteId);
|
|
71
|
-
};
|
|
72
|
-
export const executeVote = async (voteId) => {
|
|
73
|
-
const { contract } = getVotingContract();
|
|
74
|
-
await callWriteMethodWithReceipt({
|
|
75
|
-
contract,
|
|
76
|
-
methodName: 'executeVote',
|
|
77
|
-
payload: [voteId],
|
|
78
|
-
});
|
|
79
|
-
logInfo('Vote executed', voteId);
|
|
80
|
-
};
|
|
81
|
-
export const waitForEnd = async (voteId, progressBar) => {
|
|
82
|
-
const { contract, client } = getVotingContract();
|
|
83
|
-
const [vote, voteTime, block] = await Promise.all([
|
|
84
|
-
contract.read.getVote([voteId]),
|
|
85
|
-
contract.read.voteTime(),
|
|
86
|
-
client.getBlock(),
|
|
87
|
-
]);
|
|
88
|
-
if (!block)
|
|
89
|
-
throw new Error('Can not get latest block');
|
|
90
|
-
const voteMap = createVoteMap(vote);
|
|
91
|
-
const voteStart = Number(voteMap.startDate);
|
|
92
|
-
const voteEnd = voteStart + Number(voteTime);
|
|
93
|
-
const bTimestamp = Number(block.timestamp);
|
|
94
|
-
const secondsLeft = Math.max(0, voteEnd - bTimestamp);
|
|
95
|
-
const currentPosition = Math.min(bTimestamp - voteStart, Number(voteTime));
|
|
96
|
-
if (!voteMap.open) {
|
|
97
|
-
progressBar?.update(currentPosition, { secondsLeft });
|
|
98
|
-
progressBar?.stop();
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
if (progressBar) {
|
|
102
|
-
progressBar.update(currentPosition, { secondsLeft });
|
|
103
|
-
}
|
|
104
|
-
else {
|
|
105
|
-
progressBar = new progress.SingleBar({
|
|
106
|
-
format: `Vote #${voteId} in progress |{bar}| {percentage}% | {secondsLeft}s left`,
|
|
107
|
-
}, progress.Presets.shades_classic);
|
|
108
|
-
progressBar.start(Number(voteTime), currentPosition, { secondsLeft });
|
|
109
|
-
}
|
|
110
|
-
await sleep(10_000);
|
|
111
|
-
await waitForEnd(voteId, progressBar);
|
|
112
|
-
};
|
|
113
|
-
export const createVoteMap = (vote) => {
|
|
114
|
-
return vote.reduce((acc, item, index) => {
|
|
115
|
-
if (voteAbi[index]) {
|
|
116
|
-
acc[voteAbi[index].name] = item;
|
|
117
|
-
}
|
|
118
|
-
return acc;
|
|
119
|
-
}, {});
|
|
120
|
-
};
|
|
121
|
-
// export const checkTmCanForward = async () => {
|
|
122
|
-
// const vContract = getVotingContract();
|
|
123
|
-
// const signerAddress = await getSignerAddress(tmContract);
|
|
124
|
-
// const canForward = await tmContract.canForward(signerAddress, '0x');
|
|
125
|
-
//
|
|
126
|
-
// if (!canForward) {
|
|
127
|
-
// console.warn('TM can not forward, check your LDO balance');
|
|
128
|
-
// return false;
|
|
129
|
-
// }
|
|
130
|
-
//
|
|
131
|
-
// return true;
|
|
132
|
-
// };
|
|
133
|
-
//# sourceMappingURL=voting.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"voting.js","sourceRoot":"","sources":["../../features/voting.ts"],"names":[],"mappings":"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"}
|