@lidofinance/lsv-cli 1.0.0-alpha.3 → 1.0.0-alpha.30
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 +102 -1
- package/dist/abi/BlsHarness.d.ts +178 -0
- package/dist/abi/BlsHarness.js +232 -0
- package/dist/abi/BlsHarness.js.map +1 -0
- package/dist/abi/CLProofVerifier.d.ts +188 -0
- package/dist/abi/CLProofVerifier.js +247 -0
- package/dist/abi/CLProofVerifier.js.map +1 -0
- package/dist/abi/Dashboard.d.ts +1486 -0
- package/dist/abi/Dashboard.js +1920 -0
- package/dist/abi/Dashboard.js.map +1 -0
- package/dist/abi/LidoLocator.d.ts +330 -0
- package/dist/abi/LidoLocator.js +426 -0
- package/dist/abi/LidoLocator.js.map +1 -0
- package/dist/abi/OperatorGrid.d.ts +914 -0
- package/dist/abi/OperatorGrid.js +1185 -0
- package/dist/abi/OperatorGrid.js.map +1 -0
- package/dist/abi/PredepositGuarantee.d.ts +1382 -0
- package/dist/abi/PredepositGuarantee.js +1789 -0
- package/dist/abi/PredepositGuarantee.js.map +1 -0
- package/dist/abi/ReportChecker.d.ts +83 -0
- package/dist/abi/ReportChecker.js +109 -0
- package/dist/abi/ReportChecker.js.map +1 -0
- package/dist/abi/StEth.d.ts +372 -0
- package/dist/abi/StEth.js +493 -0
- package/dist/abi/StEth.js.map +1 -0
- package/dist/abi/StakingVault.d.ts +864 -0
- package/dist/abi/StakingVault.js +1112 -0
- package/dist/abi/StakingVault.js.map +1 -0
- package/dist/abi/TokenManager.d.ts +577 -0
- package/dist/abi/TokenManager.js +756 -0
- package/dist/abi/TokenManager.js.map +1 -0
- package/dist/abi/VaultFactory.d.ts +160 -0
- package/dist/abi/VaultFactory.js +209 -0
- package/dist/abi/VaultFactory.js.map +1 -0
- package/dist/abi/VaultHub.d.ts +1309 -0
- package/dist/abi/VaultHub.js +1245 -436
- package/dist/abi/VaultHub.js.map +1 -1
- package/dist/abi/VaultViewer.d.ts +223 -0
- package/dist/abi/VaultViewer.js +297 -0
- package/dist/abi/VaultViewer.js.map +1 -0
- package/dist/abi/Voting.d.ts +676 -0
- package/dist/abi/Voting.js +884 -0
- package/dist/abi/Voting.js.map +1 -0
- package/dist/abi/WstEth.d.ts +362 -0
- package/dist/abi/WstEth.js +478 -0
- package/dist/abi/WstEth.js.map +1 -0
- package/dist/abi/index.d.ts +15 -0
- package/dist/abi/index.js +17 -0
- package/dist/abi/index.js.map +1 -0
- package/dist/command/index.d.ts +2 -0
- package/dist/command/index.js +4 -5
- package/dist/command/index.js.map +1 -1
- package/dist/configs/constants.d.ts +36 -0
- package/dist/configs/constants.js +3 -0
- package/dist/configs/constants.js.map +1 -0
- package/dist/configs/deployed.d.ts +17 -0
- package/dist/configs/deployed.js +87 -52
- package/dist/configs/deployed.js.map +1 -1
- package/dist/configs/envs.d.ts +2 -0
- package/dist/configs/envs.js +8 -37
- package/dist/configs/envs.js.map +1 -1
- package/dist/configs/index.d.ts +3 -0
- package/dist/configs/index.js +3 -18
- package/dist/configs/index.js.map +1 -1
- package/dist/configs/utils.d.ts +4 -0
- package/dist/configs/utils.js +22 -0
- package/dist/configs/utils.js.map +1 -0
- package/dist/contracts/blsHarness.d.ts +947 -0
- package/dist/contracts/blsHarness.js +24 -0
- package/dist/contracts/blsHarness.js.map +1 -0
- package/dist/contracts/clProofVerifier.d.ts +2647 -0
- package/dist/contracts/clProofVerifier.js +23 -0
- package/dist/contracts/clProofVerifier.js.map +1 -0
- package/dist/contracts/dashboard.d.ts +4 -0
- package/dist/contracts/dashboard.js +11 -0
- package/dist/contracts/dashboard.js.map +1 -0
- package/dist/contracts/index.d.ts +15 -0
- package/dist/contracts/index.js +15 -17
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/locator.d.ts +6935 -0
- package/dist/contracts/locator.js +16 -0
- package/dist/contracts/locator.js.map +1 -0
- package/dist/contracts/operator-grid.d.ts +3 -0
- package/dist/contracts/operator-grid.js +17 -0
- package/dist/contracts/operator-grid.js.map +1 -0
- package/dist/contracts/pdg.d.ts +3 -0
- package/dist/contracts/pdg.js +17 -0
- package/dist/contracts/pdg.js.map +1 -0
- package/dist/contracts/reportChecker.d.ts +758 -0
- package/dist/contracts/reportChecker.js +23 -0
- package/dist/contracts/reportChecker.js.map +1 -0
- package/dist/contracts/steth.d.ts +27706 -0
- package/dist/contracts/steth.js +18 -0
- package/dist/contracts/steth.js.map +1 -0
- package/dist/contracts/token-manager.d.ts +3 -0
- package/dist/contracts/token-manager.js +13 -0
- package/dist/contracts/token-manager.js.map +1 -0
- package/dist/contracts/vault-factory.d.ts +2678 -0
- package/dist/contracts/vault-factory.js +14 -0
- package/dist/contracts/vault-factory.js.map +1 -0
- package/dist/contracts/vault-hub.d.ts +3 -0
- package/dist/contracts/vault-hub.js +14 -16
- package/dist/contracts/vault-hub.js.map +1 -1
- package/dist/contracts/vault-viewer.d.ts +2681 -0
- package/dist/contracts/vault-viewer.js +23 -0
- package/dist/contracts/vault-viewer.js.map +1 -0
- package/dist/contracts/vault.d.ts +3 -0
- package/dist/contracts/vault.js +11 -0
- package/dist/contracts/vault.js.map +1 -0
- package/dist/contracts/voting.d.ts +6 -0
- package/dist/contracts/voting.js +18 -0
- package/dist/contracts/voting.js.map +1 -0
- package/dist/contracts/wsteth.d.ts +24690 -0
- package/dist/contracts/wsteth.js +18 -0
- package/dist/contracts/wsteth.js.map +1 -0
- package/dist/features/advanced-config.d.ts +5 -0
- package/dist/features/advanced-config.js +17 -0
- package/dist/features/advanced-config.js.map +1 -0
- package/dist/features/dashboard.d.ts +5 -0
- package/dist/features/dashboard.js +210 -0
- package/dist/features/dashboard.js.map +1 -0
- package/dist/features/index.d.ts +8 -0
- package/dist/features/index.js +9 -0
- package/dist/features/index.js.map +1 -0
- package/dist/features/operator-grid.d.ts +2 -0
- package/dist/features/operator-grid.js +57 -0
- package/dist/features/operator-grid.js.map +1 -0
- package/dist/features/pdg.d.ts +2 -0
- package/dist/features/pdg.js +79 -0
- package/dist/features/pdg.js.map +1 -0
- package/dist/features/token-manager.d.ts +1 -0
- package/dist/features/token-manager.js +7 -0
- package/dist/features/token-manager.js.map +1 -0
- package/dist/features/vault-factory.d.ts +8 -0
- package/dist/features/vault-factory.js +52 -0
- package/dist/features/vault-factory.js.map +1 -0
- package/dist/features/vault-hub.d.ts +2 -0
- package/dist/features/vault-hub.js +81 -0
- package/dist/features/vault-hub.js.map +1 -0
- package/dist/features/vault.d.ts +2 -0
- package/dist/features/vault.js +54 -0
- package/dist/features/vault.js.map +1 -0
- package/dist/features/voting.d.ts +7 -0
- package/dist/features/voting.js +125 -0
- package/dist/features/voting.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +8 -5
- package/dist/index.js.map +1 -1
- package/dist/programs/account.d.ts +1 -0
- package/dist/programs/account.js +135 -0
- package/dist/programs/account.js.map +1 -0
- package/dist/programs/config.d.ts +1 -0
- package/dist/programs/config.js +31 -0
- package/dist/programs/config.js.map +1 -0
- package/dist/programs/dashboard/config.d.ts +2 -0
- package/dist/programs/dashboard/config.js +111 -0
- package/dist/programs/dashboard/config.js.map +1 -0
- package/dist/programs/dashboard/index.d.ts +3 -0
- package/dist/programs/dashboard/index.js +4 -0
- package/dist/programs/dashboard/index.js.map +1 -0
- package/dist/programs/dashboard/main.d.ts +1 -0
- package/dist/programs/dashboard/main.js +5 -0
- package/dist/programs/dashboard/main.js.map +1 -0
- package/dist/programs/dashboard/read.d.ts +1 -0
- package/dist/programs/dashboard/read.js +76 -0
- package/dist/programs/dashboard/read.js.map +1 -0
- package/dist/programs/dashboard/write.d.ts +1 -0
- package/dist/programs/dashboard/write.js +408 -0
- package/dist/programs/dashboard/write.js.map +1 -0
- package/dist/programs/hub/config.d.ts +2 -0
- package/dist/programs/hub/config.js +123 -0
- package/dist/programs/hub/config.js.map +1 -0
- package/dist/programs/hub/index.d.ts +3 -0
- package/dist/programs/hub/index.js +4 -0
- package/dist/programs/hub/index.js.map +1 -0
- package/dist/programs/hub/main.d.ts +1 -0
- package/dist/programs/hub/main.js +5 -0
- package/dist/programs/hub/main.js.map +1 -0
- package/dist/programs/hub/read.d.ts +1 -0
- package/dist/programs/hub/read.js +57 -0
- package/dist/programs/hub/read.js.map +1 -0
- package/dist/programs/hub/write.d.ts +1 -0
- package/dist/programs/hub/write.js +217 -0
- package/dist/programs/hub/write.js.map +1 -0
- package/dist/programs/index.d.ts +11 -0
- package/dist/programs/index.js +11 -17
- package/dist/programs/index.js.map +1 -1
- package/dist/programs/operator-grid/config.d.ts +2 -0
- package/dist/programs/operator-grid/config.js +81 -0
- package/dist/programs/operator-grid/config.js.map +1 -0
- package/dist/programs/operator-grid/index.d.ts +3 -0
- package/dist/programs/operator-grid/index.js +4 -0
- package/dist/programs/operator-grid/index.js.map +1 -0
- package/dist/programs/operator-grid/main.d.ts +1 -0
- package/dist/programs/operator-grid/main.js +5 -0
- package/dist/programs/operator-grid/main.js.map +1 -0
- package/dist/programs/operator-grid/read.d.ts +1 -0
- package/dist/programs/operator-grid/read.js +24 -0
- package/dist/programs/operator-grid/read.js.map +1 -0
- package/dist/programs/operator-grid/write.d.ts +1 -0
- package/dist/programs/operator-grid/write.js +109 -0
- package/dist/programs/operator-grid/write.js.map +1 -0
- package/dist/programs/pdg/config.d.ts +2 -0
- package/dist/programs/pdg/config.js +133 -0
- package/dist/programs/pdg/config.js.map +1 -0
- package/dist/programs/pdg/index.d.ts +3 -0
- package/dist/programs/pdg/index.js +4 -0
- package/dist/programs/pdg/index.js.map +1 -0
- package/dist/programs/pdg/main.d.ts +1 -0
- package/dist/programs/pdg/main.js +5 -0
- package/dist/programs/pdg/main.js.map +1 -0
- package/dist/programs/pdg/read.d.ts +1 -0
- package/dist/programs/pdg/read.js +24 -0
- package/dist/programs/pdg/read.js.map +1 -0
- package/dist/programs/pdg/write.d.ts +1 -0
- package/dist/programs/pdg/write.js +311 -0
- package/dist/programs/pdg/write.js.map +1 -0
- package/dist/programs/pdg-helpers.d.ts +1 -0
- package/dist/programs/pdg-helpers.js +207 -0
- package/dist/programs/pdg-helpers.js.map +1 -0
- package/dist/programs/report.d.ts +1 -0
- package/dist/programs/report.js +89 -0
- package/dist/programs/report.js.map +1 -0
- package/dist/programs/vault/config.d.ts +2 -0
- package/dist/programs/vault/config.js +70 -0
- package/dist/programs/vault/config.js.map +1 -0
- package/dist/programs/vault/index.d.ts +3 -0
- package/dist/programs/vault/index.js +4 -0
- package/dist/programs/vault/index.js.map +1 -0
- package/dist/programs/vault/main.d.ts +1 -0
- package/dist/programs/vault/main.js +3 -0
- package/dist/programs/vault/main.js.map +1 -0
- package/dist/programs/vault/read.d.ts +1 -0
- package/dist/programs/vault/read.js +25 -0
- package/dist/programs/vault/read.js.map +1 -0
- package/dist/programs/vault/write.d.ts +1 -0
- package/dist/programs/vault/write.js +203 -0
- package/dist/programs/vault/write.js.map +1 -0
- package/dist/programs/vault-factory/config.d.ts +2 -0
- package/dist/programs/vault-factory/config.js +2 -0
- package/dist/programs/vault-factory/config.js.map +1 -0
- package/dist/programs/vault-factory/index.d.ts +3 -0
- package/dist/programs/vault-factory/index.js +4 -0
- package/dist/programs/vault-factory/index.js.map +1 -0
- package/dist/programs/vault-factory/main.d.ts +1 -0
- package/dist/programs/vault-factory/main.js +5 -0
- package/dist/programs/vault-factory/main.js.map +1 -0
- package/dist/programs/vault-factory/read.d.ts +1 -0
- package/dist/programs/vault-factory/read.js +24 -0
- package/dist/programs/vault-factory/read.js.map +1 -0
- package/dist/programs/vault-factory/write.d.ts +1 -0
- package/dist/programs/vault-factory/write.js +72 -0
- package/dist/programs/vault-factory/write.js.map +1 -0
- package/dist/programs/vault-viewer/config.d.ts +2 -0
- package/dist/programs/vault-viewer/config.js +85 -0
- package/dist/programs/vault-viewer/config.js.map +1 -0
- package/dist/programs/vault-viewer/index.d.ts +2 -0
- package/dist/programs/vault-viewer/index.js +3 -0
- package/dist/programs/vault-viewer/index.js.map +1 -0
- package/dist/programs/vault-viewer/main.d.ts +1 -0
- package/dist/programs/vault-viewer/main.js +10 -0
- package/dist/programs/vault-viewer/main.js.map +1 -0
- package/dist/programs/vault-viewer/read.d.ts +1 -0
- package/dist/programs/vault-viewer/read.js +55 -0
- package/dist/programs/vault-viewer/read.js.map +1 -0
- package/dist/programs/voting.d.ts +1 -0
- package/dist/programs/voting.js +18 -0
- package/dist/programs/voting.js.map +1 -0
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.js +1 -17
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/wallet.d.ts +6897 -0
- package/dist/providers/wallet.js +20 -29
- package/dist/providers/wallet.js.map +1 -1
- package/dist/types/common.d.ts +31 -0
- package/dist/types/common.js +2 -0
- package/dist/types/common.js.map +1 -0
- package/dist/types/config.d.ts +23 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/arguments.d.ts +13 -0
- package/dist/utils/arguments.js +67 -0
- package/dist/utils/arguments.js.map +1 -0
- package/dist/utils/bls.d.ts +21 -0
- package/dist/utils/bls.js +101 -0
- package/dist/utils/bls.js.map +1 -0
- package/dist/utils/calculate-overview.d.ts +19 -0
- package/dist/utils/calculate-overview.js +55 -0
- package/dist/utils/calculate-overview.js.map +1 -0
- package/dist/utils/commands/dashboard.d.ts +6 -0
- package/dist/utils/commands/dashboard.js +103 -0
- package/dist/utils/commands/dashboard.js.map +1 -0
- package/dist/utils/commands/index.d.ts +1 -0
- package/dist/utils/commands/index.js +2 -0
- package/dist/utils/commands/index.js.map +1 -0
- package/dist/utils/contract.d.ts +25 -0
- package/dist/utils/contract.js +138 -0
- package/dist/utils/contract.js.map +1 -0
- package/dist/utils/data-validators.d.ts +6 -0
- package/dist/utils/data-validators.js +54 -0
- package/dist/utils/data-validators.js.map +1 -0
- package/dist/utils/error-handler.d.ts +1 -0
- package/dist/utils/error-handler.js +13 -0
- package/dist/utils/error-handler.js.map +1 -0
- package/dist/utils/fetchCL.d.ts +14 -0
- package/dist/utils/fetchCL.js +57 -0
- package/dist/utils/fetchCL.js.map +1 -0
- package/dist/utils/get-commands.d.ts +2 -0
- package/dist/utils/get-commands.js +11 -0
- package/dist/utils/get-commands.js.map +1 -0
- package/dist/utils/get-deposit-data-root.d.ts +7 -0
- package/dist/utils/get-deposit-data-root.js +40 -0
- package/dist/utils/get-deposit-data-root.js.map +1 -0
- package/dist/utils/get-value.d.ts +1 -0
- package/dist/utils/get-value.js +5 -11
- package/dist/utils/get-value.js.map +1 -1
- package/dist/utils/health.d.ts +27748 -0
- package/dist/utils/health.js +84 -0
- package/dist/utils/health.js.map +1 -0
- package/dist/utils/index.d.ts +22 -0
- package/dist/utils/index.js +22 -17
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/ipfs.d.ts +6 -0
- package/dist/utils/ipfs.js +54 -0
- package/dist/utils/ipfs.js.map +1 -0
- package/dist/utils/logging/console.d.ts +7 -0
- package/dist/utils/logging/console.js +23 -0
- package/dist/utils/logging/console.js.map +1 -0
- package/dist/utils/logging/constants.d.ts +2 -0
- package/dist/utils/logging/constants.js +12 -0
- package/dist/utils/logging/constants.js.map +1 -0
- package/dist/utils/logging/index.d.ts +1 -0
- package/dist/utils/logging/index.js +2 -0
- package/dist/utils/logging/index.js.map +1 -0
- package/dist/utils/prompts/dashboard.d.ts +29 -0
- package/dist/utils/prompts/dashboard.js +63 -0
- package/dist/utils/prompts/dashboard.js.map +1 -0
- package/dist/utils/prompts/default.d.ts +3 -0
- package/dist/utils/prompts/default.js +17 -0
- package/dist/utils/prompts/default.js.map +1 -0
- package/dist/utils/prompts/index.d.ts +5 -0
- package/dist/utils/prompts/index.js +6 -0
- package/dist/utils/prompts/index.js.map +1 -0
- package/dist/utils/prompts/operations.d.ts +9 -0
- package/dist/utils/prompts/operations.js +41 -0
- package/dist/utils/prompts/operations.js.map +1 -0
- package/dist/utils/prompts/predeposit-guarantee.d.ts +3 -0
- package/dist/utils/prompts/predeposit-guarantee.js +22 -0
- package/dist/utils/prompts/predeposit-guarantee.js.map +1 -0
- package/dist/utils/prompts/vault.d.ts +2 -0
- package/dist/utils/prompts/vault.js +14 -0
- package/dist/utils/prompts/vault.js.map +1 -0
- package/dist/utils/proof/create-proof.d.ts +11 -0
- package/dist/utils/proof/create-proof.js +38 -0
- package/dist/utils/proof/create-proof.js.map +1 -0
- package/dist/utils/proof/first-validator-gindex.d.ts +1 -0
- package/dist/utils/proof/first-validator-gindex.js +27 -0
- package/dist/utils/proof/first-validator-gindex.js.map +1 -0
- package/dist/utils/proof/index.d.ts +4 -0
- package/dist/utils/proof/index.js +5 -0
- package/dist/utils/proof/index.js.map +1 -0
- package/dist/utils/proof/merkle-utils.d.ts +54 -0
- package/dist/utils/proof/merkle-utils.js +173 -0
- package/dist/utils/proof/merkle-utils.js.map +1 -0
- package/dist/utils/proof/proofs.d.ts +305 -0
- package/dist/utils/proof/proofs.js +52 -0
- package/dist/utils/proof/proofs.js.map +1 -0
- package/dist/utils/proof/report-proof.d.ts +5 -0
- package/dist/utils/proof/report-proof.js +26 -0
- package/dist/utils/proof/report-proof.js.map +1 -0
- package/dist/utils/read-programs-by-abi.d.ts +18 -0
- package/dist/utils/read-programs-by-abi.js +87 -0
- package/dist/utils/read-programs-by-abi.js.map +1 -0
- package/dist/utils/report.d.ts +75 -0
- package/dist/utils/report.js +68 -0
- package/dist/utils/report.js.map +1 -0
- package/dist/utils/required-lock.d.ts +5 -0
- package/dist/utils/required-lock.js +21 -0
- package/dist/utils/required-lock.js.map +1 -0
- package/dist/utils/resolve-path.d.ts +1 -0
- package/dist/utils/resolve-path.js +10 -0
- package/dist/utils/resolve-path.js.map +1 -0
- package/dist/utils/sleep.d.ts +1 -0
- package/dist/utils/sleep.js +4 -0
- package/dist/utils/sleep.js.map +1 -0
- package/dist/utils/spinner/index.d.ts +1 -0
- package/dist/utils/spinner/index.js +2 -0
- package/dist/utils/spinner/index.js.map +1 -0
- package/dist/utils/spinner/spinners.d.ts +7 -0
- package/dist/utils/spinner/spinners.js +16 -0
- package/dist/utils/spinner/spinners.js.map +1 -0
- package/dist/utils/spinner/spinners.json +119 -0
- package/dist/version/index.d.ts +1 -0
- package/dist/version/index.js +1 -0
- package/dist/version/index.js.map +1 -0
- package/package.json +61 -12
- package/dist/programs/vault-hub.js +0 -137
- package/dist/programs/vault-hub.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const getFirstValidatorGIndex: (forks: string[]) => void;
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { ssz } from '@lodestar/types';
|
|
2
|
+
import { logResult } from '../index.js';
|
|
3
|
+
const SupportedFork = {
|
|
4
|
+
deneb: 'deneb',
|
|
5
|
+
electra: 'electra',
|
|
6
|
+
};
|
|
7
|
+
export const getFirstValidatorGIndex = (forks) => {
|
|
8
|
+
const gIndexes = {};
|
|
9
|
+
for (const fork of forks) {
|
|
10
|
+
const Fork = ssz[fork];
|
|
11
|
+
const Validators = Fork.BeaconState.getPathInfo(['validators']).type;
|
|
12
|
+
const gI = pack(Fork.BeaconState.getPathInfo(['validators', 0]).gindex,
|
|
13
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
14
|
+
// @ts-ignore
|
|
15
|
+
Validators.limit);
|
|
16
|
+
gIndexes[fork] = toBytes32String(gI);
|
|
17
|
+
}
|
|
18
|
+
logResult(gIndexes);
|
|
19
|
+
};
|
|
20
|
+
const pack = (gI, limit) => {
|
|
21
|
+
const width = limit ? BigInt(Math.log2(limit)) : 0n;
|
|
22
|
+
return (gI << 8n) | width;
|
|
23
|
+
};
|
|
24
|
+
const toBytes32String = (gI) => {
|
|
25
|
+
return `0x${gI.toString(16).padStart(64, '0')}`;
|
|
26
|
+
};
|
|
27
|
+
//# sourceMappingURL=first-validator-gindex.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"first-validator-gindex.js","sourceRoot":"","sources":["../../../utils/proof/first-validator-gindex.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,iBAAiB,CAAC;AAEtC,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,MAAM,aAAa,GAAG;IACpB,KAAK,EAAE,OAAO;IACd,OAAO,EAAE,SAAS;CACnB,CAAC;AAEF,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,KAAe,EAAE,EAAE;IACzD,MAAM,QAAQ,GAA2B,EAAE,CAAC;IAC5C,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,IAAI,GAAG,GAAG,CAAC,IAAkC,CAAC,CAAC;QACrD,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC;QAErE,MAAM,EAAE,GAAG,IAAI,CACb,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM;QACtD,6DAA6D;QAC7D,aAAa;QACb,UAAU,CAAC,KAAK,CACjB,CAAC;QACF,QAAQ,CAAC,IAAI,CAAC,GAAG,eAAe,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC;IACD,SAAS,CAAC,QAAQ,CAAC,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,IAAI,GAAG,CAAC,EAAU,EAAE,KAAa,EAAE,EAAE;IACzC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACpD,OAAO,CAAC,EAAE,IAAI,EAAE,CAAC,GAAG,KAAK,CAAC;AAC5B,CAAC,CAAC;AAEF,MAAM,eAAe,GAAG,CAAC,EAAU,EAAE,EAAE;IACrC,OAAO,KAAK,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC;AAClD,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../utils/proof/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
export type Validator = {
|
|
2
|
+
pubkey: Uint8Array<ArrayBufferLike>;
|
|
3
|
+
withdrawalCredentials: Uint8Array<ArrayBufferLike>;
|
|
4
|
+
effectiveBalance: number;
|
|
5
|
+
slashed: boolean;
|
|
6
|
+
activationEligibilityEpoch: number;
|
|
7
|
+
activationEpoch: number;
|
|
8
|
+
exitEpoch: number | typeof Infinity;
|
|
9
|
+
withdrawableEpoch: number | typeof Infinity;
|
|
10
|
+
};
|
|
11
|
+
export type BeaconBlockHeader = {
|
|
12
|
+
slot: number;
|
|
13
|
+
proposer_index: number;
|
|
14
|
+
parent_root: string;
|
|
15
|
+
state_root: string;
|
|
16
|
+
body_root: string;
|
|
17
|
+
};
|
|
18
|
+
/** Hex -> bytes */
|
|
19
|
+
export declare const fromHex: (hex: string) => Uint8Array;
|
|
20
|
+
/** anything -> hex */
|
|
21
|
+
export declare const toHex: (value: unknown) => string;
|
|
22
|
+
/** sha256(32+32) => 32 */
|
|
23
|
+
export declare const sha256Pair: (left: Uint8Array, right: Uint8Array) => Uint8Array;
|
|
24
|
+
/**
|
|
25
|
+
* Helper for SHA-256 over multiple Uint8Array chunks.
|
|
26
|
+
* Returns a 32-byte hash (Uint8Array of length 32).
|
|
27
|
+
*/
|
|
28
|
+
export declare const sha256Concat: (...chunks: Uint8Array[]) => Uint8Array;
|
|
29
|
+
/** 48 => 64 padded => sha256 => 32 */
|
|
30
|
+
export declare const pubkeyRoot: (pubkey48: Uint8Array) => Uint8Array;
|
|
31
|
+
/** uint64 => little-endian => pad => 32 */
|
|
32
|
+
export declare const uint64To32LE: (val: bigint) => Uint8Array;
|
|
33
|
+
/**
|
|
34
|
+
* Converts BigInt (gwei) to 8 bytes (big-endian), then reverses it to little-endian.
|
|
35
|
+
* Returns Uint8Array[8].
|
|
36
|
+
*/
|
|
37
|
+
export declare const encodeGweiAsLittleEndian8: (amountGwei: bigint) => Uint8Array;
|
|
38
|
+
/** bool => 1 byte => 32 */
|
|
39
|
+
export declare const boolTo32: (b: boolean) => Uint8Array;
|
|
40
|
+
/**
|
|
41
|
+
* If value == Infinity, treat it as 2^64-1 (18446744073709551615)
|
|
42
|
+
* sentinel "Infinity" => max uint64
|
|
43
|
+
*/
|
|
44
|
+
export declare const safeUint64: (value: number) => bigint;
|
|
45
|
+
export declare const manualSubProofPubkeyWC: (validator: Validator) => {
|
|
46
|
+
leafPubkeyWC: Uint8Array<ArrayBufferLike>;
|
|
47
|
+
root: Uint8Array<ArrayBufferLike>;
|
|
48
|
+
siblings: Uint8Array<ArrayBufferLike>[];
|
|
49
|
+
};
|
|
50
|
+
export declare const manualSubProofBeaconBlockHeader: (blockHeader: BeaconBlockHeader) => {
|
|
51
|
+
root: Uint8Array<ArrayBufferLike>;
|
|
52
|
+
siblings: Uint8Array<ArrayBufferLike>[];
|
|
53
|
+
};
|
|
54
|
+
export declare const getPubkeyWCParentGIndex: () => bigint;
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Utils that could be used for testing lodestar packages
|
|
3
|
+
*/
|
|
4
|
+
import { createHash } from 'crypto';
|
|
5
|
+
/** Hex -> bytes */
|
|
6
|
+
export const fromHex = (hex) => {
|
|
7
|
+
if (hex.startsWith('0x'))
|
|
8
|
+
hex = hex.slice(2);
|
|
9
|
+
return new Uint8Array(Buffer.from(hex, 'hex'));
|
|
10
|
+
};
|
|
11
|
+
/** anything -> hex */
|
|
12
|
+
export const toHex = (value) => {
|
|
13
|
+
if (typeof value === 'string' && !value.startsWith('0x')) {
|
|
14
|
+
return `0x${value}`;
|
|
15
|
+
}
|
|
16
|
+
if (typeof value === 'string') {
|
|
17
|
+
return value;
|
|
18
|
+
}
|
|
19
|
+
if (typeof value === 'number' || typeof value === 'bigint') {
|
|
20
|
+
return `0x${value.toString(16)}`;
|
|
21
|
+
}
|
|
22
|
+
if (value instanceof Uint8Array) {
|
|
23
|
+
return `0x${Buffer.from(value).toString('hex')}`;
|
|
24
|
+
}
|
|
25
|
+
throw new Error('Unsupported value type');
|
|
26
|
+
};
|
|
27
|
+
/** sha256(32+32) => 32 */
|
|
28
|
+
export const sha256Pair = (left, right) => {
|
|
29
|
+
if (left.length !== 32 || right.length !== 32) {
|
|
30
|
+
throw new Error('sha256Pair expects 2 x 32-byte inputs');
|
|
31
|
+
}
|
|
32
|
+
const buf = Buffer.alloc(64);
|
|
33
|
+
buf.set(left, 0);
|
|
34
|
+
buf.set(right, 32);
|
|
35
|
+
return createHash('sha256').update(buf).digest();
|
|
36
|
+
};
|
|
37
|
+
/**
|
|
38
|
+
* Helper for SHA-256 over multiple Uint8Array chunks.
|
|
39
|
+
* Returns a 32-byte hash (Uint8Array of length 32).
|
|
40
|
+
*/
|
|
41
|
+
export const sha256Concat = (...chunks) => {
|
|
42
|
+
const hash = createHash('sha256');
|
|
43
|
+
for (const chunk of chunks) {
|
|
44
|
+
hash.update(chunk);
|
|
45
|
+
}
|
|
46
|
+
return hash.digest();
|
|
47
|
+
};
|
|
48
|
+
/** 48 => 64 padded => sha256 => 32 */
|
|
49
|
+
export const pubkeyRoot = (pubkey48) => {
|
|
50
|
+
if (pubkey48.length !== 48) {
|
|
51
|
+
throw new Error(`pubkey must be 48 bytes, got=${pubkey48.length}`);
|
|
52
|
+
}
|
|
53
|
+
const padded = Buffer.alloc(64);
|
|
54
|
+
padded.set(pubkey48, 0);
|
|
55
|
+
return createHash('sha256').update(padded).digest();
|
|
56
|
+
};
|
|
57
|
+
/** uint64 => little-endian => pad => 32 */
|
|
58
|
+
export const uint64To32LE = (val) => {
|
|
59
|
+
const b = Buffer.alloc(8);
|
|
60
|
+
b.writeBigUInt64LE(val, 0);
|
|
61
|
+
return Buffer.concat([b, Buffer.alloc(24)]);
|
|
62
|
+
};
|
|
63
|
+
/**
|
|
64
|
+
* Converts BigInt (gwei) to 8 bytes (big-endian), then reverses it to little-endian.
|
|
65
|
+
* Returns Uint8Array[8].
|
|
66
|
+
*/
|
|
67
|
+
export const encodeGweiAsLittleEndian8 = (amountGwei) => {
|
|
68
|
+
// First 8 bytes big-endian
|
|
69
|
+
const be = new Uint8Array(8);
|
|
70
|
+
let tmp = amountGwei;
|
|
71
|
+
for (let i = 7; i >= 0; i--) {
|
|
72
|
+
be[i] = Number(tmp & 0xffn);
|
|
73
|
+
tmp >>= 8n;
|
|
74
|
+
}
|
|
75
|
+
// Now reverse it (big-endian -> little-endian)
|
|
76
|
+
const le = new Uint8Array(8);
|
|
77
|
+
for (let i = 0; i < 8; i++) {
|
|
78
|
+
le[i] = be[7 - i] ?? 0;
|
|
79
|
+
}
|
|
80
|
+
return le;
|
|
81
|
+
};
|
|
82
|
+
/** bool => 1 byte => 32 */
|
|
83
|
+
export const boolTo32 = (b) => {
|
|
84
|
+
const oneByte = Buffer.from([b ? 1 : 0]);
|
|
85
|
+
return Buffer.concat([oneByte, Buffer.alloc(31)]);
|
|
86
|
+
};
|
|
87
|
+
/**
|
|
88
|
+
* If value == Infinity, treat it as 2^64-1 (18446744073709551615)
|
|
89
|
+
* sentinel "Infinity" => max uint64
|
|
90
|
+
*/
|
|
91
|
+
export const safeUint64 = (value) => {
|
|
92
|
+
if (!Number.isFinite(value)) {
|
|
93
|
+
// sentinel "Infinity" => max uint64
|
|
94
|
+
return 18446744073709551615n;
|
|
95
|
+
}
|
|
96
|
+
return BigInt(value);
|
|
97
|
+
};
|
|
98
|
+
export const manualSubProofPubkeyWC = (validator) => {
|
|
99
|
+
const pubkey48 = new Uint8Array(validator.pubkey); // 48
|
|
100
|
+
const wc32 = new Uint8Array(validator.withdrawalCredentials); // 32
|
|
101
|
+
const effBalance32 = uint64To32LE(BigInt(validator.effectiveBalance));
|
|
102
|
+
const slashed32 = boolTo32(!!validator.slashed);
|
|
103
|
+
const actElig32 = uint64To32LE(BigInt(validator.activationEligibilityEpoch));
|
|
104
|
+
const act32 = uint64To32LE(BigInt(validator.activationEpoch));
|
|
105
|
+
const exitEpochSafe = safeUint64(validator.exitEpoch);
|
|
106
|
+
const exit32 = uint64To32LE(exitEpochSafe);
|
|
107
|
+
const withdrawableEpochSafe = safeUint64(validator.withdrawableEpoch);
|
|
108
|
+
const wdble32 = uint64To32LE(withdrawableEpochSafe);
|
|
109
|
+
const node0 = sha256Pair(pubkeyRoot(pubkey48), wc32);
|
|
110
|
+
const node1 = sha256Pair(effBalance32, slashed32);
|
|
111
|
+
const node2 = sha256Pair(actElig32, act32);
|
|
112
|
+
const node3 = sha256Pair(exit32, wdble32);
|
|
113
|
+
const node01 = sha256Pair(node0, node1);
|
|
114
|
+
const node23 = sha256Pair(node2, node3);
|
|
115
|
+
const siblings = [node1, node23];
|
|
116
|
+
const root = sha256Pair(node01, node23);
|
|
117
|
+
return {
|
|
118
|
+
leafPubkeyWC: node0,
|
|
119
|
+
root,
|
|
120
|
+
siblings,
|
|
121
|
+
};
|
|
122
|
+
};
|
|
123
|
+
export const manualSubProofBeaconBlockHeader = (blockHeader) => {
|
|
124
|
+
const slot = blockHeader.slot;
|
|
125
|
+
const proposerIndex = blockHeader.proposer_index;
|
|
126
|
+
const parentRoot = blockHeader.parent_root;
|
|
127
|
+
const stateRoot = blockHeader.state_root;
|
|
128
|
+
const bodyRoot = blockHeader.body_root;
|
|
129
|
+
const zero1_32 = new Uint8Array(32);
|
|
130
|
+
const zero2_32 = new Uint8Array(32);
|
|
131
|
+
const zero3_32 = new Uint8Array(32);
|
|
132
|
+
const slot32 = uint64To32LE(BigInt(slot));
|
|
133
|
+
const proposerIndex32 = uint64To32LE(BigInt(proposerIndex));
|
|
134
|
+
const parentRoot32 = fromHex(parentRoot);
|
|
135
|
+
const stateRoot32 = fromHex(stateRoot);
|
|
136
|
+
const bodyRoot32 = fromHex(bodyRoot);
|
|
137
|
+
const node0 = sha256Pair(slot32, proposerIndex32);
|
|
138
|
+
const node1 = sha256Pair(parentRoot32, stateRoot32);
|
|
139
|
+
const node2 = sha256Pair(bodyRoot32, zero1_32);
|
|
140
|
+
const node3 = sha256Pair(zero2_32, zero3_32);
|
|
141
|
+
const node01 = sha256Pair(node0, node1);
|
|
142
|
+
const node23 = sha256Pair(node2, node3);
|
|
143
|
+
const siblings = [parentRoot32, node0, node23];
|
|
144
|
+
const root = sha256Pair(node01, node23);
|
|
145
|
+
return {
|
|
146
|
+
root,
|
|
147
|
+
siblings,
|
|
148
|
+
};
|
|
149
|
+
};
|
|
150
|
+
/*
|
|
151
|
+
gIndex=1
|
|
152
|
+
Validator Container Root
|
|
153
|
+
│
|
|
154
|
+
┌───────────────┴───────────────┐
|
|
155
|
+
│ │
|
|
156
|
+
gIndex=2 gIndex=3
|
|
157
|
+
node proof[1] **DEPTH = 1
|
|
158
|
+
│ │
|
|
159
|
+
┌───────┴───────┐ ┌───────┴───────┐
|
|
160
|
+
│ │ │ │
|
|
161
|
+
gIndex=4 gIndex=5 gIndex=6 gIndex=7
|
|
162
|
+
Proven Parent proof[0] node node **DEPTH = 2
|
|
163
|
+
│ │ │ │
|
|
164
|
+
┌─────┴─────┐ ┌─────┴─────┐ ┌─────┴─────┐ ┌─────┴─────┐
|
|
165
|
+
│ │ │ │ │ │ │ │
|
|
166
|
+
[pubkeyRoot] [wc] [EB] [slashed] [AEE] [AE] [EE] [WE] **DEPTH = 3
|
|
167
|
+
*/
|
|
168
|
+
export const getPubkeyWCParentGIndex = () => {
|
|
169
|
+
const depth = 2;
|
|
170
|
+
const position = 0;
|
|
171
|
+
return BigInt((1 << depth) + position); // => 4
|
|
172
|
+
};
|
|
173
|
+
//# sourceMappingURL=merkle-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"merkle-utils.js","sourceRoot":"","sources":["../../../utils/proof/merkle-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
import { Hex } from 'viem';
|
|
2
|
+
import { SingleProof, Node } from '@chainsafe/persistent-merkle-tree';
|
|
3
|
+
declare const SupportedFork: {
|
|
4
|
+
capella: string;
|
|
5
|
+
deneb: string;
|
|
6
|
+
electra: string;
|
|
7
|
+
};
|
|
8
|
+
export type BeaconHeaderResponse = {
|
|
9
|
+
slot: number;
|
|
10
|
+
proposer_index: number;
|
|
11
|
+
parent_root: Hex;
|
|
12
|
+
state_root: Hex;
|
|
13
|
+
body_root: Hex;
|
|
14
|
+
};
|
|
15
|
+
export declare const createPubkeyWCProof: (validatorNode: Node) => Promise<{
|
|
16
|
+
proof: SingleProof;
|
|
17
|
+
}>;
|
|
18
|
+
export declare const createStateProof: (validatorIndex: number, bodyBytes: ArrayBuffer, forkName: keyof typeof SupportedFork) => Promise<{
|
|
19
|
+
proof: SingleProof;
|
|
20
|
+
validator: import("@chainsafe/ssz/lib/view/container.js").ContainerTreeViewType<{
|
|
21
|
+
pubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
22
|
+
withdrawalCredentials: import("@chainsafe/ssz").ByteVectorType;
|
|
23
|
+
effectiveBalance: import("@chainsafe/ssz").UintNumberType;
|
|
24
|
+
slashed: import("@chainsafe/ssz").BooleanType;
|
|
25
|
+
activationEligibilityEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
26
|
+
activationEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
27
|
+
exitEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
28
|
+
withdrawableEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
29
|
+
}>;
|
|
30
|
+
view: import("@chainsafe/ssz/lib/view/container.js").ContainerTreeViewType<{
|
|
31
|
+
genesisTime: import("@chainsafe/ssz").UintNumberType;
|
|
32
|
+
genesisValidatorsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
33
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
34
|
+
fork: import("@chainsafe/ssz").ContainerType<{
|
|
35
|
+
previousVersion: import("@chainsafe/ssz").ByteVectorType;
|
|
36
|
+
currentVersion: import("@chainsafe/ssz").ByteVectorType;
|
|
37
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
38
|
+
}>;
|
|
39
|
+
latestBlockHeader: import("@chainsafe/ssz").ContainerType<{
|
|
40
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
41
|
+
proposerIndex: import("@chainsafe/ssz").UintNumberType;
|
|
42
|
+
parentRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
43
|
+
stateRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
44
|
+
bodyRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
45
|
+
}>;
|
|
46
|
+
blockRoots: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
47
|
+
stateRoots: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
48
|
+
historicalRoots: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
49
|
+
eth1Data: import("@chainsafe/ssz").ContainerType<{
|
|
50
|
+
depositRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
51
|
+
depositCount: import("@chainsafe/ssz").UintNumberType;
|
|
52
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
53
|
+
}>;
|
|
54
|
+
eth1DataVotes: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
55
|
+
depositRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
56
|
+
depositCount: import("@chainsafe/ssz").UintNumberType;
|
|
57
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
58
|
+
}>>;
|
|
59
|
+
eth1DepositIndex: import("@chainsafe/ssz").UintNumberType;
|
|
60
|
+
validators: import("@chainsafe/ssz").ListCompositeType<import("node_modules/@lodestar/types/lib/phase0/validator.js").ValidatorNodeStructType>;
|
|
61
|
+
balances: import("@chainsafe/ssz").ListUintNum64Type;
|
|
62
|
+
randaoMixes: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
63
|
+
slashings: import("@chainsafe/ssz").VectorBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
64
|
+
previousEpochParticipation: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
65
|
+
currentEpochParticipation: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
66
|
+
justificationBits: import("@chainsafe/ssz").BitVectorType;
|
|
67
|
+
previousJustifiedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
68
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
69
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
70
|
+
}>;
|
|
71
|
+
currentJustifiedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
72
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
73
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
74
|
+
}>;
|
|
75
|
+
finalizedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
76
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
77
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
78
|
+
}>;
|
|
79
|
+
inactivityScores: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
80
|
+
currentSyncCommittee: import("@chainsafe/ssz").ContainerType<{
|
|
81
|
+
pubkeys: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
82
|
+
aggregatePubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
83
|
+
}>;
|
|
84
|
+
nextSyncCommittee: import("@chainsafe/ssz").ContainerType<{
|
|
85
|
+
pubkeys: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
86
|
+
aggregatePubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
87
|
+
}>;
|
|
88
|
+
latestExecutionPayloadHeader: import("@chainsafe/ssz").ContainerType<{
|
|
89
|
+
withdrawalsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
90
|
+
transactionsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
91
|
+
parentHash: import("@chainsafe/ssz").ByteVectorType;
|
|
92
|
+
feeRecipient: import("node_modules/@lodestar/types/lib/utils/executionAddress.js").ExecutionAddressType;
|
|
93
|
+
stateRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
94
|
+
receiptsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
95
|
+
logsBloom: import("@chainsafe/ssz").ByteVectorType;
|
|
96
|
+
prevRandao: import("@chainsafe/ssz").ByteVectorType;
|
|
97
|
+
blockNumber: import("@chainsafe/ssz").UintNumberType;
|
|
98
|
+
gasLimit: import("@chainsafe/ssz").UintNumberType;
|
|
99
|
+
gasUsed: import("@chainsafe/ssz").UintNumberType;
|
|
100
|
+
timestamp: import("@chainsafe/ssz").UintNumberType;
|
|
101
|
+
extraData: import("@chainsafe/ssz").ByteListType;
|
|
102
|
+
baseFeePerGas: import("@chainsafe/ssz").UintBigintType;
|
|
103
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
104
|
+
}>;
|
|
105
|
+
nextWithdrawalIndex: import("@chainsafe/ssz").UintNumberType;
|
|
106
|
+
nextWithdrawalValidatorIndex: import("@chainsafe/ssz").UintNumberType;
|
|
107
|
+
historicalSummaries: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
108
|
+
blockSummaryRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
109
|
+
stateSummaryRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
110
|
+
}>>;
|
|
111
|
+
}> | import("@chainsafe/ssz/lib/view/container.js").ContainerTreeViewType<{
|
|
112
|
+
genesisTime: import("@chainsafe/ssz").UintNumberType;
|
|
113
|
+
genesisValidatorsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
114
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
115
|
+
fork: import("@chainsafe/ssz").ContainerType<{
|
|
116
|
+
previousVersion: import("@chainsafe/ssz").ByteVectorType;
|
|
117
|
+
currentVersion: import("@chainsafe/ssz").ByteVectorType;
|
|
118
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
119
|
+
}>;
|
|
120
|
+
latestBlockHeader: import("@chainsafe/ssz").ContainerType<{
|
|
121
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
122
|
+
proposerIndex: import("@chainsafe/ssz").UintNumberType;
|
|
123
|
+
parentRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
124
|
+
stateRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
125
|
+
bodyRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
126
|
+
}>;
|
|
127
|
+
blockRoots: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
128
|
+
stateRoots: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
129
|
+
historicalRoots: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
130
|
+
eth1Data: import("@chainsafe/ssz").ContainerType<{
|
|
131
|
+
depositRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
132
|
+
depositCount: import("@chainsafe/ssz").UintNumberType;
|
|
133
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
134
|
+
}>;
|
|
135
|
+
eth1DataVotes: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
136
|
+
depositRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
137
|
+
depositCount: import("@chainsafe/ssz").UintNumberType;
|
|
138
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
139
|
+
}>>;
|
|
140
|
+
eth1DepositIndex: import("@chainsafe/ssz").UintNumberType;
|
|
141
|
+
validators: import("@chainsafe/ssz").ListCompositeType<import("node_modules/@lodestar/types/lib/phase0/validator.js").ValidatorNodeStructType>;
|
|
142
|
+
balances: import("@chainsafe/ssz").ListUintNum64Type;
|
|
143
|
+
randaoMixes: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
144
|
+
slashings: import("@chainsafe/ssz").VectorBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
145
|
+
previousEpochParticipation: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
146
|
+
currentEpochParticipation: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
147
|
+
justificationBits: import("@chainsafe/ssz").BitVectorType;
|
|
148
|
+
previousJustifiedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
149
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
150
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
151
|
+
}>;
|
|
152
|
+
currentJustifiedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
153
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
154
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
155
|
+
}>;
|
|
156
|
+
finalizedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
157
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
158
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
159
|
+
}>;
|
|
160
|
+
inactivityScores: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
161
|
+
currentSyncCommittee: import("@chainsafe/ssz").ContainerType<{
|
|
162
|
+
pubkeys: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
163
|
+
aggregatePubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
164
|
+
}>;
|
|
165
|
+
nextSyncCommittee: import("@chainsafe/ssz").ContainerType<{
|
|
166
|
+
pubkeys: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
167
|
+
aggregatePubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
168
|
+
}>;
|
|
169
|
+
latestExecutionPayloadHeader: import("@chainsafe/ssz").ContainerType<{
|
|
170
|
+
blobGasUsed: import("@chainsafe/ssz").UintBigintType;
|
|
171
|
+
excessBlobGas: import("@chainsafe/ssz").UintBigintType;
|
|
172
|
+
withdrawalsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
173
|
+
transactionsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
174
|
+
parentHash: import("@chainsafe/ssz").ByteVectorType;
|
|
175
|
+
feeRecipient: import("node_modules/@lodestar/types/lib/utils/executionAddress.js").ExecutionAddressType;
|
|
176
|
+
stateRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
177
|
+
receiptsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
178
|
+
logsBloom: import("@chainsafe/ssz").ByteVectorType;
|
|
179
|
+
prevRandao: import("@chainsafe/ssz").ByteVectorType;
|
|
180
|
+
blockNumber: import("@chainsafe/ssz").UintNumberType;
|
|
181
|
+
gasLimit: import("@chainsafe/ssz").UintNumberType;
|
|
182
|
+
gasUsed: import("@chainsafe/ssz").UintNumberType;
|
|
183
|
+
timestamp: import("@chainsafe/ssz").UintNumberType;
|
|
184
|
+
extraData: import("@chainsafe/ssz").ByteListType;
|
|
185
|
+
baseFeePerGas: import("@chainsafe/ssz").UintBigintType;
|
|
186
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
187
|
+
}>;
|
|
188
|
+
nextWithdrawalIndex: import("@chainsafe/ssz").UintNumberType;
|
|
189
|
+
nextWithdrawalValidatorIndex: import("@chainsafe/ssz").UintNumberType;
|
|
190
|
+
historicalSummaries: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
191
|
+
blockSummaryRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
192
|
+
stateSummaryRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
193
|
+
}>>;
|
|
194
|
+
}> | import("@chainsafe/ssz/lib/view/container.js").ContainerTreeViewType<{
|
|
195
|
+
genesisTime: import("@chainsafe/ssz").UintNumberType;
|
|
196
|
+
genesisValidatorsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
197
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
198
|
+
fork: import("@chainsafe/ssz").ContainerType<{
|
|
199
|
+
previousVersion: import("@chainsafe/ssz").ByteVectorType;
|
|
200
|
+
currentVersion: import("@chainsafe/ssz").ByteVectorType;
|
|
201
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
202
|
+
}>;
|
|
203
|
+
latestBlockHeader: import("@chainsafe/ssz").ContainerType<{
|
|
204
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
205
|
+
proposerIndex: import("@chainsafe/ssz").UintNumberType;
|
|
206
|
+
parentRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
207
|
+
stateRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
208
|
+
bodyRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
209
|
+
}>;
|
|
210
|
+
blockRoots: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
211
|
+
stateRoots: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
212
|
+
historicalRoots: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
213
|
+
eth1Data: import("@chainsafe/ssz").ContainerType<{
|
|
214
|
+
depositRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
215
|
+
depositCount: import("@chainsafe/ssz").UintNumberType;
|
|
216
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
217
|
+
}>;
|
|
218
|
+
eth1DataVotes: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
219
|
+
depositRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
220
|
+
depositCount: import("@chainsafe/ssz").UintNumberType;
|
|
221
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
222
|
+
}>>;
|
|
223
|
+
eth1DepositIndex: import("@chainsafe/ssz").UintNumberType;
|
|
224
|
+
validators: import("@chainsafe/ssz").ListCompositeType<import("node_modules/@lodestar/types/lib/phase0/validator.js").ValidatorNodeStructType>;
|
|
225
|
+
balances: import("@chainsafe/ssz").ListUintNum64Type;
|
|
226
|
+
randaoMixes: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
227
|
+
slashings: import("@chainsafe/ssz").VectorBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
228
|
+
previousEpochParticipation: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
229
|
+
currentEpochParticipation: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
230
|
+
justificationBits: import("@chainsafe/ssz").BitVectorType;
|
|
231
|
+
previousJustifiedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
232
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
233
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
234
|
+
}>;
|
|
235
|
+
currentJustifiedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
236
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
237
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
238
|
+
}>;
|
|
239
|
+
finalizedCheckpoint: import("@chainsafe/ssz").ContainerType<{
|
|
240
|
+
epoch: import("@chainsafe/ssz").UintNumberType;
|
|
241
|
+
root: import("@chainsafe/ssz").ByteVectorType;
|
|
242
|
+
}>;
|
|
243
|
+
inactivityScores: import("@chainsafe/ssz").ListBasicType<import("@chainsafe/ssz").UintNumberType>;
|
|
244
|
+
currentSyncCommittee: import("@chainsafe/ssz").ContainerType<{
|
|
245
|
+
pubkeys: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
246
|
+
aggregatePubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
247
|
+
}>;
|
|
248
|
+
nextSyncCommittee: import("@chainsafe/ssz").ContainerType<{
|
|
249
|
+
pubkeys: import("@chainsafe/ssz").VectorCompositeType<import("@chainsafe/ssz").ByteVectorType>;
|
|
250
|
+
aggregatePubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
251
|
+
}>;
|
|
252
|
+
latestExecutionPayloadHeader: import("@chainsafe/ssz").ContainerType<{
|
|
253
|
+
blobGasUsed: import("@chainsafe/ssz").UintBigintType;
|
|
254
|
+
excessBlobGas: import("@chainsafe/ssz").UintBigintType;
|
|
255
|
+
withdrawalsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
256
|
+
transactionsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
257
|
+
parentHash: import("@chainsafe/ssz").ByteVectorType;
|
|
258
|
+
feeRecipient: import("node_modules/@lodestar/types/lib/utils/executionAddress.js").ExecutionAddressType;
|
|
259
|
+
stateRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
260
|
+
receiptsRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
261
|
+
logsBloom: import("@chainsafe/ssz").ByteVectorType;
|
|
262
|
+
prevRandao: import("@chainsafe/ssz").ByteVectorType;
|
|
263
|
+
blockNumber: import("@chainsafe/ssz").UintNumberType;
|
|
264
|
+
gasLimit: import("@chainsafe/ssz").UintNumberType;
|
|
265
|
+
gasUsed: import("@chainsafe/ssz").UintNumberType;
|
|
266
|
+
timestamp: import("@chainsafe/ssz").UintNumberType;
|
|
267
|
+
extraData: import("@chainsafe/ssz").ByteListType;
|
|
268
|
+
baseFeePerGas: import("@chainsafe/ssz").UintBigintType;
|
|
269
|
+
blockHash: import("@chainsafe/ssz").ByteVectorType;
|
|
270
|
+
}>;
|
|
271
|
+
nextWithdrawalIndex: import("@chainsafe/ssz").UintNumberType;
|
|
272
|
+
nextWithdrawalValidatorIndex: import("@chainsafe/ssz").UintNumberType;
|
|
273
|
+
historicalSummaries: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
274
|
+
blockSummaryRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
275
|
+
stateSummaryRoot: import("@chainsafe/ssz").ByteVectorType;
|
|
276
|
+
}>>;
|
|
277
|
+
depositRequestsStartIndex: import("@chainsafe/ssz").UintBigintType;
|
|
278
|
+
depositBalanceToConsume: import("@chainsafe/ssz").UintBigintType;
|
|
279
|
+
exitBalanceToConsume: import("@chainsafe/ssz").UintBigintType;
|
|
280
|
+
earliestExitEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
281
|
+
consolidationBalanceToConsume: import("@chainsafe/ssz").UintBigintType;
|
|
282
|
+
earliestConsolidationEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
283
|
+
pendingDeposits: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
284
|
+
pubkey: import("@chainsafe/ssz").ByteVectorType;
|
|
285
|
+
withdrawalCredentials: import("@chainsafe/ssz").ByteVectorType;
|
|
286
|
+
amount: import("@chainsafe/ssz").UintNumberType;
|
|
287
|
+
signature: import("@chainsafe/ssz").ByteVectorType;
|
|
288
|
+
slot: import("@chainsafe/ssz").UintNumberType;
|
|
289
|
+
}>>;
|
|
290
|
+
pendingPartialWithdrawals: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
291
|
+
validatorIndex: import("@chainsafe/ssz").UintNumberType;
|
|
292
|
+
amount: import("@chainsafe/ssz").UintBigintType;
|
|
293
|
+
withdrawableEpoch: import("@chainsafe/ssz").UintNumberType;
|
|
294
|
+
}>>;
|
|
295
|
+
pendingConsolidations: import("@chainsafe/ssz").ListCompositeType<import("@chainsafe/ssz").ContainerType<{
|
|
296
|
+
sourceIndex: import("@chainsafe/ssz").UintNumberType;
|
|
297
|
+
targetIndex: import("@chainsafe/ssz").UintNumberType;
|
|
298
|
+
}>>;
|
|
299
|
+
}>;
|
|
300
|
+
}>;
|
|
301
|
+
export declare const createBeaconHeaderProof: (beaconHeader: BeaconHeaderResponse) => Promise<{
|
|
302
|
+
proof: SingleProof;
|
|
303
|
+
root: `0x${string}`;
|
|
304
|
+
}>;
|
|
305
|
+
export {};
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { toHex, fromHex } from 'viem';
|
|
2
|
+
import { ProofType, createProof, } from '@chainsafe/persistent-merkle-tree';
|
|
3
|
+
import { ssz } from '@lodestar/types';
|
|
4
|
+
import { getPubkeyWCParentGIndex } from './merkle-utils.js';
|
|
5
|
+
const SupportedFork = {
|
|
6
|
+
capella: 'capella',
|
|
7
|
+
deneb: 'deneb',
|
|
8
|
+
electra: 'electra',
|
|
9
|
+
};
|
|
10
|
+
export const createPubkeyWCProof = async (validatorNode) => {
|
|
11
|
+
const pubkeyWCProof = createProof(validatorNode, {
|
|
12
|
+
type: ProofType.single,
|
|
13
|
+
gindex: getPubkeyWCParentGIndex(),
|
|
14
|
+
});
|
|
15
|
+
return { proof: pubkeyWCProof };
|
|
16
|
+
};
|
|
17
|
+
export const createStateProof = async (validatorIndex, bodyBytes, forkName) => {
|
|
18
|
+
const stateView = ssz[forkName].BeaconState.deserializeToView(new Uint8Array(bodyBytes));
|
|
19
|
+
if (validatorIndex >= stateView.validators.length)
|
|
20
|
+
throw new Error(`ValidatorIndex ${validatorIndex} out of range`);
|
|
21
|
+
const validator = stateView.validators.getReadonly(Number(validatorIndex));
|
|
22
|
+
const gIValidator = stateView.type.getPathInfo([
|
|
23
|
+
'validators',
|
|
24
|
+
Number(validatorIndex),
|
|
25
|
+
]).gindex;
|
|
26
|
+
const validatorStateProof = createProof(stateView.node, {
|
|
27
|
+
type: ProofType.single,
|
|
28
|
+
gindex: gIValidator,
|
|
29
|
+
});
|
|
30
|
+
return { proof: validatorStateProof, validator, view: stateView };
|
|
31
|
+
};
|
|
32
|
+
export const createBeaconHeaderProof = async (beaconHeader) => {
|
|
33
|
+
const beaconHeaderView = ssz['phase0'].BeaconBlockHeader.toView({
|
|
34
|
+
slot: Number(beaconHeader.slot),
|
|
35
|
+
proposerIndex: Number(beaconHeader.proposer_index),
|
|
36
|
+
parentRoot: fromHex(beaconHeader.parent_root, 'bytes'),
|
|
37
|
+
stateRoot: fromHex(beaconHeader.state_root, 'bytes'),
|
|
38
|
+
bodyRoot: fromHex(beaconHeader.body_root, 'bytes'),
|
|
39
|
+
});
|
|
40
|
+
const gIndexBeaconHeader = beaconHeaderView.type.getPathInfo([
|
|
41
|
+
'state_root',
|
|
42
|
+
]).gindex;
|
|
43
|
+
const beaconHeaderProof = createProof(beaconHeaderView.node, {
|
|
44
|
+
type: ProofType.single,
|
|
45
|
+
gindex: gIndexBeaconHeader,
|
|
46
|
+
});
|
|
47
|
+
return {
|
|
48
|
+
proof: beaconHeaderProof,
|
|
49
|
+
root: toHex(beaconHeaderView.hashTreeRoot()),
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
//# sourceMappingURL=proofs.js.map
|