@lidofinance/lido-csm-sdk 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.txt +21 -0
- package/README.md +86 -0
- package/dist/cjs/abi/CSAccounting.js +2351 -0
- package/dist/cjs/abi/CSAccounting.js.map +1 -0
- package/dist/cjs/abi/CSEjector.js +690 -0
- package/dist/cjs/abi/CSEjector.js.map +1 -0
- package/dist/cjs/abi/CSExitPenalties.js +413 -0
- package/dist/cjs/abi/CSExitPenalties.js.map +1 -0
- package/dist/cjs/abi/CSFeeDistributor.js +1069 -0
- package/dist/cjs/abi/CSFeeDistributor.js.map +1 -0
- package/dist/cjs/abi/CSFeeOracle.js +1335 -0
- package/dist/cjs/abi/CSFeeOracle.js.map +1 -0
- package/dist/cjs/abi/CSMSatellite.js +190 -0
- package/dist/cjs/abi/CSMSatellite.js.map +1 -0
- package/dist/cjs/abi/CSModule.js +2757 -0
- package/dist/cjs/abi/CSModule.js.map +1 -0
- package/dist/cjs/abi/CSModuleV1Events.js +762 -0
- package/dist/cjs/abi/CSModuleV1Events.js.map +1 -0
- package/dist/cjs/abi/CSParametersRegistry.js +2165 -0
- package/dist/cjs/abi/CSParametersRegistry.js.map +1 -0
- package/dist/cjs/abi/CSStrikes.js +734 -0
- package/dist/cjs/abi/CSStrikes.js.map +1 -0
- package/dist/cjs/abi/HashConsensus.js +1145 -0
- package/dist/cjs/abi/HashConsensus.js.map +1 -0
- package/dist/cjs/abi/PermissionlessGate.js +632 -0
- package/dist/cjs/abi/PermissionlessGate.js.map +1 -0
- package/dist/cjs/abi/StakingRouter.js +2006 -0
- package/dist/cjs/abi/StakingRouter.js.map +1 -0
- package/dist/cjs/abi/ValidatorsExitBusOracle.js +43 -0
- package/dist/cjs/abi/ValidatorsExitBusOracle.js.map +1 -0
- package/dist/cjs/abi/VettedGate.js +1338 -0
- package/dist/cjs/abi/VettedGate.js.map +1 -0
- package/dist/cjs/abi/WithdrawalVault.js +32 -0
- package/dist/cjs/abi/WithdrawalVault.js.map +1 -0
- package/dist/cjs/abi/index.js +33 -0
- package/dist/cjs/abi/index.js.map +1 -0
- package/dist/cjs/accounting-sdk/accounting-sdk.js +138 -0
- package/dist/cjs/accounting-sdk/accounting-sdk.js.map +1 -0
- package/dist/cjs/accounting-sdk/index.js +19 -0
- package/dist/cjs/accounting-sdk/index.js.map +1 -0
- package/dist/cjs/accounting-sdk/types.js +3 -0
- package/dist/cjs/accounting-sdk/types.js.map +1 -0
- package/dist/cjs/bond-sdk/bond-sdk.js +283 -0
- package/dist/cjs/bond-sdk/bond-sdk.js.map +1 -0
- package/dist/cjs/bond-sdk/index.js +19 -0
- package/dist/cjs/bond-sdk/index.js.map +1 -0
- package/dist/cjs/bond-sdk/types.js +3 -0
- package/dist/cjs/bond-sdk/types.js.map +1 -0
- package/dist/cjs/common/class-primitives/bus-registry.js +29 -0
- package/dist/cjs/common/class-primitives/bus-registry.js.map +1 -0
- package/dist/cjs/common/class-primitives/csm-sdk-cacheable.js +25 -0
- package/dist/cjs/common/class-primitives/csm-sdk-cacheable.js.map +1 -0
- package/dist/cjs/common/class-primitives/csm-sdk-module.js +29 -0
- package/dist/cjs/common/class-primitives/csm-sdk-module.js.map +1 -0
- package/dist/cjs/common/class-primitives/index.js +19 -0
- package/dist/cjs/common/class-primitives/index.js.map +1 -0
- package/dist/cjs/common/constants/base.js +86 -0
- package/dist/cjs/common/constants/base.js.map +1 -0
- package/dist/cjs/common/constants/index.js +23 -0
- package/dist/cjs/common/constants/index.js.map +1 -0
- package/dist/cjs/common/constants/keys.js +28 -0
- package/dist/cjs/common/constants/keys.js.map +1 -0
- package/dist/cjs/common/constants/links.js +26 -0
- package/dist/cjs/common/constants/links.js.map +1 -0
- package/dist/cjs/common/constants/permit.js +12 -0
- package/dist/cjs/common/constants/permit.js.map +1 -0
- package/dist/cjs/common/constants/roles.js +16 -0
- package/dist/cjs/common/constants/roles.js.map +1 -0
- package/dist/cjs/common/constants/tokens.js +11 -0
- package/dist/cjs/common/constants/tokens.js.map +1 -0
- package/dist/cjs/common/decorators/cache.js +83 -0
- package/dist/cjs/common/decorators/cache.js.map +1 -0
- package/dist/cjs/common/decorators/constants.js +22 -0
- package/dist/cjs/common/decorators/constants.js.map +1 -0
- package/dist/cjs/common/decorators/error-handler.js +59 -0
- package/dist/cjs/common/decorators/error-handler.js.map +1 -0
- package/dist/cjs/common/decorators/index.js +23 -0
- package/dist/cjs/common/decorators/index.js.map +1 -0
- package/dist/cjs/common/decorators/logger.js +57 -0
- package/dist/cjs/common/decorators/logger.js.map +1 -0
- package/dist/cjs/common/decorators/types.js +3 -0
- package/dist/cjs/common/decorators/types.js.map +1 -0
- package/dist/cjs/common/decorators/utils.js +35 -0
- package/dist/cjs/common/decorators/utils.js.map +1 -0
- package/dist/cjs/common/index.js +19 -0
- package/dist/cjs/common/index.js.map +1 -0
- package/dist/cjs/common/types.js +3 -0
- package/dist/cjs/common/types.js.map +1 -0
- package/dist/cjs/common/utils/clear-empty-address.js +9 -0
- package/dist/cjs/common/utils/clear-empty-address.js.map +1 -0
- package/dist/cjs/common/utils/compare-lowercase.js +6 -0
- package/dist/cjs/common/utils/compare-lowercase.js.map +1 -0
- package/dist/cjs/common/utils/fetch-json.js +33 -0
- package/dist/cjs/common/utils/fetch-json.js.map +1 -0
- package/dist/cjs/common/utils/find-index-and-leaf.js +21 -0
- package/dist/cjs/common/utils/find-index-and-leaf.js.map +1 -0
- package/dist/cjs/common/utils/index.js +30 -0
- package/dist/cjs/common/utils/index.js.map +1 -0
- package/dist/cjs/common/utils/is-bigint.js +8 -0
- package/dist/cjs/common/utils/is-bigint.js.map +1 -0
- package/dist/cjs/common/utils/is-defined.js +16 -0
- package/dist/cjs/common/utils/is-defined.js.map +1 -0
- package/dist/cjs/common/utils/is-hexadecimal-string.js +23 -0
- package/dist/cjs/common/utils/is-hexadecimal-string.js.map +1 -0
- package/dist/cjs/common/utils/on-error.js +27 -0
- package/dist/cjs/common/utils/on-error.js.map +1 -0
- package/dist/cjs/common/utils/parse-deposit-data.js +15 -0
- package/dist/cjs/common/utils/parse-deposit-data.js.map +1 -0
- package/dist/cjs/common/utils/parse-value.js +12 -0
- package/dist/cjs/common/utils/parse-value.js.map +1 -0
- package/dist/cjs/common/utils/request-with-block-step.js +20 -0
- package/dist/cjs/common/utils/request-with-block-step.js.map +1 -0
- package/dist/cjs/common/utils/sort-events.js +6 -0
- package/dist/cjs/common/utils/sort-events.js.map +1 -0
- package/dist/cjs/common/utils/split-keys.js +14 -0
- package/dist/cjs/common/utils/split-keys.js.map +1 -0
- package/dist/cjs/common/utils/strip-permit.js +12 -0
- package/dist/cjs/common/utils/strip-permit.js.map +1 -0
- package/dist/cjs/core-sdk/core-sdk.js +327 -0
- package/dist/cjs/core-sdk/core-sdk.js.map +1 -0
- package/dist/cjs/core-sdk/index.js +19 -0
- package/dist/cjs/core-sdk/index.js.map +1 -0
- package/dist/cjs/core-sdk/types.js +17 -0
- package/dist/cjs/core-sdk/types.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/constants.js +22 -0
- package/dist/cjs/deposit-data-sdk/constants.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/deposit-data-sdk.js +143 -0
- package/dist/cjs/deposit-data-sdk/deposit-data-sdk.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/index.js +19 -0
- package/dist/cjs/deposit-data-sdk/index.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/parser.js +111 -0
- package/dist/cjs/deposit-data-sdk/parser.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/signature.js +102 -0
- package/dist/cjs/deposit-data-sdk/signature.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/types.js +19 -0
- package/dist/cjs/deposit-data-sdk/types.js.map +1 -0
- package/dist/cjs/deposit-data-sdk/validator.js +167 -0
- package/dist/cjs/deposit-data-sdk/validator.js.map +1 -0
- package/dist/cjs/deposit-queue-sdk/deposit-queue-sdk.js +112 -0
- package/dist/cjs/deposit-queue-sdk/deposit-queue-sdk.js.map +1 -0
- package/dist/cjs/deposit-queue-sdk/filter-batches.js +22 -0
- package/dist/cjs/deposit-queue-sdk/filter-batches.js.map +1 -0
- package/dist/cjs/deposit-queue-sdk/index.js +18 -0
- package/dist/cjs/deposit-queue-sdk/index.js.map +1 -0
- package/dist/cjs/deposit-queue-sdk/parse-batch.js +16 -0
- package/dist/cjs/deposit-queue-sdk/parse-batch.js.map +1 -0
- package/dist/cjs/deposit-queue-sdk/types.js +3 -0
- package/dist/cjs/deposit-queue-sdk/types.js.map +1 -0
- package/dist/cjs/events-sdk/events-sdk.js +166 -0
- package/dist/cjs/events-sdk/events-sdk.js.map +1 -0
- package/dist/cjs/events-sdk/get-node-operator-roles.js +12 -0
- package/dist/cjs/events-sdk/get-node-operator-roles.js.map +1 -0
- package/dist/cjs/events-sdk/index.js +21 -0
- package/dist/cjs/events-sdk/index.js.map +1 -0
- package/dist/cjs/events-sdk/merge.js +35 -0
- package/dist/cjs/events-sdk/merge.js.map +1 -0
- package/dist/cjs/events-sdk/reconstruct-invites.js +48 -0
- package/dist/cjs/events-sdk/reconstruct-invites.js.map +1 -0
- package/dist/cjs/events-sdk/reconstruct-operators.js +32 -0
- package/dist/cjs/events-sdk/reconstruct-operators.js.map +1 -0
- package/dist/cjs/events-sdk/types.js +3 -0
- package/dist/cjs/events-sdk/types.js.map +1 -0
- package/dist/cjs/fee-recipient-sdk/api-client.js +57 -0
- package/dist/cjs/fee-recipient-sdk/api-client.js.map +1 -0
- package/dist/cjs/fee-recipient-sdk/constants.js +7 -0
- package/dist/cjs/fee-recipient-sdk/constants.js.map +1 -0
- package/dist/cjs/fee-recipient-sdk/fee-recipient-sdk.js +147 -0
- package/dist/cjs/fee-recipient-sdk/fee-recipient-sdk.js.map +1 -0
- package/dist/cjs/fee-recipient-sdk/index.js +18 -0
- package/dist/cjs/fee-recipient-sdk/index.js.map +1 -0
- package/dist/cjs/fee-recipient-sdk/types.js +3 -0
- package/dist/cjs/fee-recipient-sdk/types.js.map +1 -0
- package/dist/cjs/fee-recipient-sdk/validators.js +70 -0
- package/dist/cjs/fee-recipient-sdk/validators.js.map +1 -0
- package/dist/cjs/frame-sdk/frame-sdk.js +104 -0
- package/dist/cjs/frame-sdk/frame-sdk.js.map +1 -0
- package/dist/cjs/frame-sdk/index.js +19 -0
- package/dist/cjs/frame-sdk/index.js.map +1 -0
- package/dist/cjs/frame-sdk/types.js +3 -0
- package/dist/cjs/frame-sdk/types.js.map +1 -0
- package/dist/cjs/ics-gate-sdk/fetch-proofs-tree.js +15 -0
- package/dist/cjs/ics-gate-sdk/fetch-proofs-tree.js.map +1 -0
- package/dist/cjs/ics-gate-sdk/find-proof.js +14 -0
- package/dist/cjs/ics-gate-sdk/find-proof.js.map +1 -0
- package/dist/cjs/ics-gate-sdk/ics-gate-sdk.js +317 -0
- package/dist/cjs/ics-gate-sdk/ics-gate-sdk.js.map +1 -0
- package/dist/cjs/ics-gate-sdk/index.js +19 -0
- package/dist/cjs/ics-gate-sdk/index.js.map +1 -0
- package/dist/cjs/ics-gate-sdk/types.js +3 -0
- package/dist/cjs/ics-gate-sdk/types.js.map +1 -0
- package/dist/cjs/index.js +41 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/keys-cache-sdk/constants.js +5 -0
- package/dist/cjs/keys-cache-sdk/constants.js.map +1 -0
- package/dist/cjs/keys-cache-sdk/index.js +22 -0
- package/dist/cjs/keys-cache-sdk/index.js.map +1 -0
- package/dist/cjs/keys-cache-sdk/keys-cache-sdk.js +127 -0
- package/dist/cjs/keys-cache-sdk/keys-cache-sdk.js.map +1 -0
- package/dist/cjs/keys-cache-sdk/storage.js +73 -0
- package/dist/cjs/keys-cache-sdk/storage.js.map +1 -0
- package/dist/cjs/keys-cache-sdk/types.js +3 -0
- package/dist/cjs/keys-cache-sdk/types.js.map +1 -0
- package/dist/cjs/keys-sdk/index.js +19 -0
- package/dist/cjs/keys-sdk/index.js.map +1 -0
- package/dist/cjs/keys-sdk/keys-sdk.js +280 -0
- package/dist/cjs/keys-sdk/keys-sdk.js.map +1 -0
- package/dist/cjs/keys-sdk/types.js +3 -0
- package/dist/cjs/keys-sdk/types.js.map +1 -0
- package/dist/cjs/keys-with-status-sdk/cl-chunks.js +42 -0
- package/dist/cjs/keys-with-status-sdk/cl-chunks.js.map +1 -0
- package/dist/cjs/keys-with-status-sdk/index.js +19 -0
- package/dist/cjs/keys-with-status-sdk/index.js.map +1 -0
- package/dist/cjs/keys-with-status-sdk/keys-with-status-sdk.js +220 -0
- package/dist/cjs/keys-with-status-sdk/keys-with-status-sdk.js.map +1 -0
- package/dist/cjs/keys-with-status-sdk/types.js +3 -0
- package/dist/cjs/keys-with-status-sdk/types.js.map +1 -0
- package/dist/cjs/keys-with-status-sdk/utils.js +6 -0
- package/dist/cjs/keys-with-status-sdk/utils.js.map +1 -0
- package/dist/cjs/lido-sdk-csm.js +188 -0
- package/dist/cjs/lido-sdk-csm.js.map +1 -0
- package/dist/cjs/module-sdk/calculate-share-limit.js +24 -0
- package/dist/cjs/module-sdk/calculate-share-limit.js.map +1 -0
- package/dist/cjs/module-sdk/find-module-digest.js +11 -0
- package/dist/cjs/module-sdk/find-module-digest.js.map +1 -0
- package/dist/cjs/module-sdk/index.js +19 -0
- package/dist/cjs/module-sdk/index.js.map +1 -0
- package/dist/cjs/module-sdk/module-sdk.js +200 -0
- package/dist/cjs/module-sdk/module-sdk.js.map +1 -0
- package/dist/cjs/module-sdk/types.js +10 -0
- package/dist/cjs/module-sdk/types.js.map +1 -0
- package/dist/cjs/operator-sdk/calc-bond-balance.js +21 -0
- package/dist/cjs/operator-sdk/calc-bond-balance.js.map +1 -0
- package/dist/cjs/operator-sdk/index.js +20 -0
- package/dist/cjs/operator-sdk/index.js.map +1 -0
- package/dist/cjs/operator-sdk/operator-sdk.js +158 -0
- package/dist/cjs/operator-sdk/operator-sdk.js.map +1 -0
- package/dist/cjs/operator-sdk/types.js +3 -0
- package/dist/cjs/operator-sdk/types.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/parameters-sdk/index.js +19 -0
- package/dist/cjs/parameters-sdk/index.js.map +1 -0
- package/dist/cjs/parameters-sdk/parameters-sdk.js +209 -0
- package/dist/cjs/parameters-sdk/parameters-sdk.js.map +1 -0
- package/dist/cjs/parameters-sdk/types.js +3 -0
- package/dist/cjs/parameters-sdk/types.js.map +1 -0
- package/dist/cjs/permissionless-gate-sdk/index.js +19 -0
- package/dist/cjs/permissionless-gate-sdk/index.js.map +1 -0
- package/dist/cjs/permissionless-gate-sdk/permissionless-gate-sdk.js +222 -0
- package/dist/cjs/permissionless-gate-sdk/permissionless-gate-sdk.js.map +1 -0
- package/dist/cjs/permissionless-gate-sdk/types.js +3 -0
- package/dist/cjs/permissionless-gate-sdk/types.js.map +1 -0
- package/dist/cjs/rewards-sdk/fetch-rewards-tree.js +16 -0
- package/dist/cjs/rewards-sdk/fetch-rewards-tree.js.map +1 -0
- package/dist/cjs/rewards-sdk/find-operator-rewards.js +55 -0
- package/dist/cjs/rewards-sdk/find-operator-rewards.js.map +1 -0
- package/dist/cjs/rewards-sdk/find-proof.js +18 -0
- package/dist/cjs/rewards-sdk/find-proof.js.map +1 -0
- package/dist/cjs/rewards-sdk/index.js +19 -0
- package/dist/cjs/rewards-sdk/index.js.map +1 -0
- package/dist/cjs/rewards-sdk/rewards-sdk.js +168 -0
- package/dist/cjs/rewards-sdk/rewards-sdk.js.map +1 -0
- package/dist/cjs/rewards-sdk/types.js +70 -0
- package/dist/cjs/rewards-sdk/types.js.map +1 -0
- package/dist/cjs/roles-sdk/index.js +19 -0
- package/dist/cjs/roles-sdk/index.js.map +1 -0
- package/dist/cjs/roles-sdk/roles-sdk.js +172 -0
- package/dist/cjs/roles-sdk/roles-sdk.js.map +1 -0
- package/dist/cjs/roles-sdk/types.js +3 -0
- package/dist/cjs/roles-sdk/types.js.map +1 -0
- package/dist/cjs/satellite-sdk/index.js +19 -0
- package/dist/cjs/satellite-sdk/index.js.map +1 -0
- package/dist/cjs/satellite-sdk/satellite-sdk.js +128 -0
- package/dist/cjs/satellite-sdk/satellite-sdk.js.map +1 -0
- package/dist/cjs/satellite-sdk/types.js +10 -0
- package/dist/cjs/satellite-sdk/types.js.map +1 -0
- package/dist/cjs/spending-sdk/index.js +19 -0
- package/dist/cjs/spending-sdk/index.js.map +1 -0
- package/dist/cjs/spending-sdk/spending-sdk.js +187 -0
- package/dist/cjs/spending-sdk/spending-sdk.js.map +1 -0
- package/dist/cjs/spending-sdk/types.js +3 -0
- package/dist/cjs/spending-sdk/types.js.map +1 -0
- package/dist/cjs/stealing-sdk/index.js +18 -0
- package/dist/cjs/stealing-sdk/index.js.map +1 -0
- package/dist/cjs/stealing-sdk/stealing-sdk.js +109 -0
- package/dist/cjs/stealing-sdk/stealing-sdk.js.map +1 -0
- package/dist/cjs/stealing-sdk/types.js +3 -0
- package/dist/cjs/stealing-sdk/types.js.map +1 -0
- package/dist/cjs/strikes-sdk/fetch-proofs-tree.js +15 -0
- package/dist/cjs/strikes-sdk/fetch-proofs-tree.js.map +1 -0
- package/dist/cjs/strikes-sdk/find-proof.js +27 -0
- package/dist/cjs/strikes-sdk/find-proof.js.map +1 -0
- package/dist/cjs/strikes-sdk/index.js +19 -0
- package/dist/cjs/strikes-sdk/index.js.map +1 -0
- package/dist/cjs/strikes-sdk/strikes-sdk.js +117 -0
- package/dist/cjs/strikes-sdk/strikes-sdk.js.map +1 -0
- package/dist/cjs/strikes-sdk/types.js +3 -0
- package/dist/cjs/strikes-sdk/types.js.map +1 -0
- package/dist/cjs/version.js +6 -0
- package/dist/cjs/version.js.map +1 -0
- package/dist/esm/abi/CSAccounting.js +2348 -0
- package/dist/esm/abi/CSAccounting.js.map +1 -0
- package/dist/esm/abi/CSEjector.js +687 -0
- package/dist/esm/abi/CSEjector.js.map +1 -0
- package/dist/esm/abi/CSExitPenalties.js +410 -0
- package/dist/esm/abi/CSExitPenalties.js.map +1 -0
- package/dist/esm/abi/CSFeeDistributor.js +1066 -0
- package/dist/esm/abi/CSFeeDistributor.js.map +1 -0
- package/dist/esm/abi/CSFeeOracle.js +1332 -0
- package/dist/esm/abi/CSFeeOracle.js.map +1 -0
- package/dist/esm/abi/CSMSatellite.js +187 -0
- package/dist/esm/abi/CSMSatellite.js.map +1 -0
- package/dist/esm/abi/CSModule.js +2754 -0
- package/dist/esm/abi/CSModule.js.map +1 -0
- package/dist/esm/abi/CSModuleV1Events.js +759 -0
- package/dist/esm/abi/CSModuleV1Events.js.map +1 -0
- package/dist/esm/abi/CSParametersRegistry.js +2162 -0
- package/dist/esm/abi/CSParametersRegistry.js.map +1 -0
- package/dist/esm/abi/CSStrikes.js +731 -0
- package/dist/esm/abi/CSStrikes.js.map +1 -0
- package/dist/esm/abi/HashConsensus.js +1142 -0
- package/dist/esm/abi/HashConsensus.js.map +1 -0
- package/dist/esm/abi/PermissionlessGate.js +629 -0
- package/dist/esm/abi/PermissionlessGate.js.map +1 -0
- package/dist/esm/abi/StakingRouter.js +2003 -0
- package/dist/esm/abi/StakingRouter.js.map +1 -0
- package/dist/esm/abi/ValidatorsExitBusOracle.js +40 -0
- package/dist/esm/abi/ValidatorsExitBusOracle.js.map +1 -0
- package/dist/esm/abi/VettedGate.js +1335 -0
- package/dist/esm/abi/VettedGate.js.map +1 -0
- package/dist/esm/abi/WithdrawalVault.js +29 -0
- package/dist/esm/abi/WithdrawalVault.js.map +1 -0
- package/dist/esm/abi/index.js +17 -0
- package/dist/esm/abi/index.js.map +1 -0
- package/dist/esm/accounting-sdk/accounting-sdk.js +135 -0
- package/dist/esm/accounting-sdk/accounting-sdk.js.map +1 -0
- package/dist/esm/accounting-sdk/index.js +3 -0
- package/dist/esm/accounting-sdk/index.js.map +1 -0
- package/dist/esm/accounting-sdk/types.js +2 -0
- package/dist/esm/accounting-sdk/types.js.map +1 -0
- package/dist/esm/bond-sdk/bond-sdk.js +281 -0
- package/dist/esm/bond-sdk/bond-sdk.js.map +1 -0
- package/dist/esm/bond-sdk/index.js +3 -0
- package/dist/esm/bond-sdk/index.js.map +1 -0
- package/dist/esm/bond-sdk/types.js +2 -0
- package/dist/esm/bond-sdk/types.js.map +1 -0
- package/dist/esm/common/class-primitives/bus-registry.js +25 -0
- package/dist/esm/common/class-primitives/bus-registry.js.map +1 -0
- package/dist/esm/common/class-primitives/csm-sdk-cacheable.js +21 -0
- package/dist/esm/common/class-primitives/csm-sdk-cacheable.js.map +1 -0
- package/dist/esm/common/class-primitives/csm-sdk-module.js +25 -0
- package/dist/esm/common/class-primitives/csm-sdk-module.js.map +1 -0
- package/dist/esm/common/class-primitives/index.js +3 -0
- package/dist/esm/common/class-primitives/index.js.map +1 -0
- package/dist/esm/common/constants/base.js +83 -0
- package/dist/esm/common/constants/base.js.map +1 -0
- package/dist/esm/common/constants/index.js +7 -0
- package/dist/esm/common/constants/index.js.map +1 -0
- package/dist/esm/common/constants/keys.js +25 -0
- package/dist/esm/common/constants/keys.js.map +1 -0
- package/dist/esm/common/constants/links.js +23 -0
- package/dist/esm/common/constants/links.js.map +1 -0
- package/dist/esm/common/constants/permit.js +9 -0
- package/dist/esm/common/constants/permit.js.map +1 -0
- package/dist/esm/common/constants/roles.js +13 -0
- package/dist/esm/common/constants/roles.js.map +1 -0
- package/dist/esm/common/constants/tokens.js +8 -0
- package/dist/esm/common/constants/tokens.js.map +1 -0
- package/dist/esm/common/decorators/cache.js +79 -0
- package/dist/esm/common/decorators/cache.js.map +1 -0
- package/dist/esm/common/decorators/constants.js +19 -0
- package/dist/esm/common/decorators/constants.js.map +1 -0
- package/dist/esm/common/decorators/error-handler.js +55 -0
- package/dist/esm/common/decorators/error-handler.js.map +1 -0
- package/dist/esm/common/decorators/index.js +7 -0
- package/dist/esm/common/decorators/index.js.map +1 -0
- package/dist/esm/common/decorators/logger.js +53 -0
- package/dist/esm/common/decorators/logger.js.map +1 -0
- package/dist/esm/common/decorators/types.js +2 -0
- package/dist/esm/common/decorators/types.js.map +1 -0
- package/dist/esm/common/decorators/utils.js +29 -0
- package/dist/esm/common/decorators/utils.js.map +1 -0
- package/dist/esm/common/index.js +3 -0
- package/dist/esm/common/index.js.map +1 -0
- package/dist/esm/common/types.js +2 -0
- package/dist/esm/common/types.js.map +1 -0
- package/dist/esm/common/utils/clear-empty-address.js +5 -0
- package/dist/esm/common/utils/clear-empty-address.js.map +1 -0
- package/dist/esm/common/utils/compare-lowercase.js +2 -0
- package/dist/esm/common/utils/compare-lowercase.js.map +1 -0
- package/dist/esm/common/utils/fetch-json.js +30 -0
- package/dist/esm/common/utils/fetch-json.js.map +1 -0
- package/dist/esm/common/utils/find-index-and-leaf.js +16 -0
- package/dist/esm/common/utils/find-index-and-leaf.js.map +1 -0
- package/dist/esm/common/utils/index.js +14 -0
- package/dist/esm/common/utils/index.js.map +1 -0
- package/dist/esm/common/utils/is-bigint.js +4 -0
- package/dist/esm/common/utils/is-bigint.js.map +1 -0
- package/dist/esm/common/utils/is-defined.js +10 -0
- package/dist/esm/common/utils/is-defined.js.map +1 -0
- package/dist/esm/common/utils/is-hexadecimal-string.js +17 -0
- package/dist/esm/common/utils/is-hexadecimal-string.js.map +1 -0
- package/dist/esm/common/utils/on-error.js +22 -0
- package/dist/esm/common/utils/on-error.js.map +1 -0
- package/dist/esm/common/utils/parse-deposit-data.js +11 -0
- package/dist/esm/common/utils/parse-deposit-data.js.map +1 -0
- package/dist/esm/common/utils/parse-value.js +8 -0
- package/dist/esm/common/utils/parse-value.js.map +1 -0
- package/dist/esm/common/utils/request-with-block-step.js +16 -0
- package/dist/esm/common/utils/request-with-block-step.js.map +1 -0
- package/dist/esm/common/utils/sort-events.js +2 -0
- package/dist/esm/common/utils/sort-events.js.map +1 -0
- package/dist/esm/common/utils/split-keys.js +10 -0
- package/dist/esm/common/utils/split-keys.js.map +1 -0
- package/dist/esm/common/utils/strip-permit.js +8 -0
- package/dist/esm/common/utils/strip-permit.js.map +1 -0
- package/dist/esm/core-sdk/core-sdk.js +327 -0
- package/dist/esm/core-sdk/core-sdk.js.map +1 -0
- package/dist/esm/core-sdk/index.js +3 -0
- package/dist/esm/core-sdk/index.js.map +1 -0
- package/dist/esm/core-sdk/types.js +15 -0
- package/dist/esm/core-sdk/types.js.map +1 -0
- package/dist/esm/deposit-data-sdk/constants.js +19 -0
- package/dist/esm/deposit-data-sdk/constants.js.map +1 -0
- package/dist/esm/deposit-data-sdk/deposit-data-sdk.js +156 -0
- package/dist/esm/deposit-data-sdk/deposit-data-sdk.js.map +1 -0
- package/dist/esm/deposit-data-sdk/index.js +3 -0
- package/dist/esm/deposit-data-sdk/index.js.map +1 -0
- package/dist/esm/deposit-data-sdk/parser.js +131 -0
- package/dist/esm/deposit-data-sdk/parser.js.map +1 -0
- package/dist/esm/deposit-data-sdk/signature.js +187 -0
- package/dist/esm/deposit-data-sdk/signature.js.map +1 -0
- package/dist/esm/deposit-data-sdk/types.js +16 -0
- package/dist/esm/deposit-data-sdk/types.js.map +1 -0
- package/dist/esm/deposit-data-sdk/validator.js +178 -0
- package/dist/esm/deposit-data-sdk/validator.js.map +1 -0
- package/dist/esm/deposit-queue-sdk/deposit-queue-sdk.js +113 -0
- package/dist/esm/deposit-queue-sdk/deposit-queue-sdk.js.map +1 -0
- package/dist/esm/deposit-queue-sdk/filter-batches.js +18 -0
- package/dist/esm/deposit-queue-sdk/filter-batches.js.map +1 -0
- package/dist/esm/deposit-queue-sdk/index.js +2 -0
- package/dist/esm/deposit-queue-sdk/index.js.map +1 -0
- package/dist/esm/deposit-queue-sdk/parse-batch.js +12 -0
- package/dist/esm/deposit-queue-sdk/parse-batch.js.map +1 -0
- package/dist/esm/deposit-queue-sdk/types.js +2 -0
- package/dist/esm/deposit-queue-sdk/types.js.map +1 -0
- package/dist/esm/events-sdk/events-sdk.js +163 -0
- package/dist/esm/events-sdk/events-sdk.js.map +1 -0
- package/dist/esm/events-sdk/get-node-operator-roles.js +8 -0
- package/dist/esm/events-sdk/get-node-operator-roles.js.map +1 -0
- package/dist/esm/events-sdk/index.js +5 -0
- package/dist/esm/events-sdk/index.js.map +1 -0
- package/dist/esm/events-sdk/merge.js +26 -0
- package/dist/esm/events-sdk/merge.js.map +1 -0
- package/dist/esm/events-sdk/reconstruct-invites.js +45 -0
- package/dist/esm/events-sdk/reconstruct-invites.js.map +1 -0
- package/dist/esm/events-sdk/reconstruct-operators.js +29 -0
- package/dist/esm/events-sdk/reconstruct-operators.js.map +1 -0
- package/dist/esm/events-sdk/types.js +2 -0
- package/dist/esm/events-sdk/types.js.map +1 -0
- package/dist/esm/fee-recipient-sdk/api-client.js +65 -0
- package/dist/esm/fee-recipient-sdk/api-client.js.map +1 -0
- package/dist/esm/fee-recipient-sdk/constants.js +13 -0
- package/dist/esm/fee-recipient-sdk/constants.js.map +1 -0
- package/dist/esm/fee-recipient-sdk/fee-recipient-sdk.js +200 -0
- package/dist/esm/fee-recipient-sdk/fee-recipient-sdk.js.map +1 -0
- package/dist/esm/fee-recipient-sdk/index.js +5 -0
- package/dist/esm/fee-recipient-sdk/index.js.map +1 -0
- package/dist/esm/fee-recipient-sdk/types.js +2 -0
- package/dist/esm/fee-recipient-sdk/types.js.map +1 -0
- package/dist/esm/fee-recipient-sdk/validators.js +84 -0
- package/dist/esm/fee-recipient-sdk/validators.js.map +1 -0
- package/dist/esm/frame-sdk/frame-sdk.js +101 -0
- package/dist/esm/frame-sdk/frame-sdk.js.map +1 -0
- package/dist/esm/frame-sdk/index.js +3 -0
- package/dist/esm/frame-sdk/index.js.map +1 -0
- package/dist/esm/frame-sdk/types.js +2 -0
- package/dist/esm/frame-sdk/types.js.map +1 -0
- package/dist/esm/ics-gate-sdk/fetch-proofs-tree.js +11 -0
- package/dist/esm/ics-gate-sdk/fetch-proofs-tree.js.map +1 -0
- package/dist/esm/ics-gate-sdk/find-proof.js +10 -0
- package/dist/esm/ics-gate-sdk/find-proof.js.map +1 -0
- package/dist/esm/ics-gate-sdk/ics-gate-sdk.js +316 -0
- package/dist/esm/ics-gate-sdk/ics-gate-sdk.js.map +1 -0
- package/dist/esm/ics-gate-sdk/index.js +3 -0
- package/dist/esm/ics-gate-sdk/index.js.map +1 -0
- package/dist/esm/ics-gate-sdk/types.js +2 -0
- package/dist/esm/ics-gate-sdk/types.js.map +1 -0
- package/dist/esm/index.js +25 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/keys-cache-sdk/constants.js +2 -0
- package/dist/esm/keys-cache-sdk/constants.js.map +1 -0
- package/dist/esm/keys-cache-sdk/index.js +4 -0
- package/dist/esm/keys-cache-sdk/index.js.map +1 -0
- package/dist/esm/keys-cache-sdk/keys-cache-sdk.js +156 -0
- package/dist/esm/keys-cache-sdk/keys-cache-sdk.js.map +1 -0
- package/dist/esm/keys-cache-sdk/storage.js +68 -0
- package/dist/esm/keys-cache-sdk/storage.js.map +1 -0
- package/dist/esm/keys-cache-sdk/types.js +2 -0
- package/dist/esm/keys-cache-sdk/types.js.map +1 -0
- package/dist/esm/keys-sdk/index.js +3 -0
- package/dist/esm/keys-sdk/index.js.map +1 -0
- package/dist/esm/keys-sdk/keys-sdk.js +277 -0
- package/dist/esm/keys-sdk/keys-sdk.js.map +1 -0
- package/dist/esm/keys-sdk/types.js +2 -0
- package/dist/esm/keys-sdk/types.js.map +1 -0
- package/dist/esm/keys-with-status-sdk/cl-chunks.js +35 -0
- package/dist/esm/keys-with-status-sdk/cl-chunks.js.map +1 -0
- package/dist/esm/keys-with-status-sdk/index.js +3 -0
- package/dist/esm/keys-with-status-sdk/index.js.map +1 -0
- package/dist/esm/keys-with-status-sdk/keys-with-status-sdk.js +217 -0
- package/dist/esm/keys-with-status-sdk/keys-with-status-sdk.js.map +1 -0
- package/dist/esm/keys-with-status-sdk/types.js +2 -0
- package/dist/esm/keys-with-status-sdk/types.js.map +1 -0
- package/dist/esm/keys-with-status-sdk/utils.js +2 -0
- package/dist/esm/keys-with-status-sdk/utils.js.map +1 -0
- package/dist/esm/lido-sdk-csm.js +184 -0
- package/dist/esm/lido-sdk-csm.js.map +1 -0
- package/dist/esm/module-sdk/calculate-share-limit.js +20 -0
- package/dist/esm/module-sdk/calculate-share-limit.js.map +1 -0
- package/dist/esm/module-sdk/find-module-digest.js +7 -0
- package/dist/esm/module-sdk/find-module-digest.js.map +1 -0
- package/dist/esm/module-sdk/index.js +3 -0
- package/dist/esm/module-sdk/index.js.map +1 -0
- package/dist/esm/module-sdk/module-sdk.js +197 -0
- package/dist/esm/module-sdk/module-sdk.js.map +1 -0
- package/dist/esm/module-sdk/types.js +7 -0
- package/dist/esm/module-sdk/types.js.map +1 -0
- package/dist/esm/operator-sdk/calc-bond-balance.js +17 -0
- package/dist/esm/operator-sdk/calc-bond-balance.js.map +1 -0
- package/dist/esm/operator-sdk/index.js +4 -0
- package/dist/esm/operator-sdk/index.js.map +1 -0
- package/dist/esm/operator-sdk/operator-sdk.js +155 -0
- package/dist/esm/operator-sdk/operator-sdk.js.map +1 -0
- package/dist/esm/operator-sdk/types.js +2 -0
- package/dist/esm/operator-sdk/types.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/parameters-sdk/index.js +3 -0
- package/dist/esm/parameters-sdk/index.js.map +1 -0
- package/dist/esm/parameters-sdk/parameters-sdk.js +206 -0
- package/dist/esm/parameters-sdk/parameters-sdk.js.map +1 -0
- package/dist/esm/parameters-sdk/types.js +2 -0
- package/dist/esm/parameters-sdk/types.js.map +1 -0
- package/dist/esm/permissionless-gate-sdk/index.js +3 -0
- package/dist/esm/permissionless-gate-sdk/index.js.map +1 -0
- package/dist/esm/permissionless-gate-sdk/permissionless-gate-sdk.js +221 -0
- package/dist/esm/permissionless-gate-sdk/permissionless-gate-sdk.js.map +1 -0
- package/dist/esm/permissionless-gate-sdk/types.js +2 -0
- package/dist/esm/permissionless-gate-sdk/types.js.map +1 -0
- package/dist/esm/rewards-sdk/fetch-rewards-tree.js +12 -0
- package/dist/esm/rewards-sdk/fetch-rewards-tree.js.map +1 -0
- package/dist/esm/rewards-sdk/find-operator-rewards.js +51 -0
- package/dist/esm/rewards-sdk/find-operator-rewards.js.map +1 -0
- package/dist/esm/rewards-sdk/find-proof.js +14 -0
- package/dist/esm/rewards-sdk/find-proof.js.map +1 -0
- package/dist/esm/rewards-sdk/index.js +3 -0
- package/dist/esm/rewards-sdk/index.js.map +1 -0
- package/dist/esm/rewards-sdk/rewards-sdk.js +167 -0
- package/dist/esm/rewards-sdk/rewards-sdk.js.map +1 -0
- package/dist/esm/rewards-sdk/types.js +65 -0
- package/dist/esm/rewards-sdk/types.js.map +1 -0
- package/dist/esm/roles-sdk/index.js +3 -0
- package/dist/esm/roles-sdk/index.js.map +1 -0
- package/dist/esm/roles-sdk/roles-sdk.js +169 -0
- package/dist/esm/roles-sdk/roles-sdk.js.map +1 -0
- package/dist/esm/roles-sdk/types.js +2 -0
- package/dist/esm/roles-sdk/types.js.map +1 -0
- package/dist/esm/satellite-sdk/index.js +3 -0
- package/dist/esm/satellite-sdk/index.js.map +1 -0
- package/dist/esm/satellite-sdk/satellite-sdk.js +125 -0
- package/dist/esm/satellite-sdk/satellite-sdk.js.map +1 -0
- package/dist/esm/satellite-sdk/types.js +7 -0
- package/dist/esm/satellite-sdk/types.js.map +1 -0
- package/dist/esm/spending-sdk/index.js +3 -0
- package/dist/esm/spending-sdk/index.js.map +1 -0
- package/dist/esm/spending-sdk/spending-sdk.js +190 -0
- package/dist/esm/spending-sdk/spending-sdk.js.map +1 -0
- package/dist/esm/spending-sdk/types.js +2 -0
- package/dist/esm/spending-sdk/types.js.map +1 -0
- package/dist/esm/stealing-sdk/index.js +2 -0
- package/dist/esm/stealing-sdk/index.js.map +1 -0
- package/dist/esm/stealing-sdk/stealing-sdk.js +107 -0
- package/dist/esm/stealing-sdk/stealing-sdk.js.map +1 -0
- package/dist/esm/stealing-sdk/types.js +2 -0
- package/dist/esm/stealing-sdk/types.js.map +1 -0
- package/dist/esm/strikes-sdk/fetch-proofs-tree.js +12 -0
- package/dist/esm/strikes-sdk/fetch-proofs-tree.js.map +1 -0
- package/dist/esm/strikes-sdk/find-proof.js +20 -0
- package/dist/esm/strikes-sdk/find-proof.js.map +1 -0
- package/dist/esm/strikes-sdk/index.js +3 -0
- package/dist/esm/strikes-sdk/index.js.map +1 -0
- package/dist/esm/strikes-sdk/strikes-sdk.js +115 -0
- package/dist/esm/strikes-sdk/strikes-sdk.js.map +1 -0
- package/dist/esm/strikes-sdk/types.js +2 -0
- package/dist/esm/strikes-sdk/types.js.map +1 -0
- package/dist/esm/version.js +1 -0
- package/dist/esm/version.js.map +1 -0
- package/dist/types/abi/CSAccounting.d.ts +1814 -0
- package/dist/types/abi/CSAccounting.d.ts.map +1 -0
- package/dist/types/abi/CSEjector.d.ts +533 -0
- package/dist/types/abi/CSEjector.d.ts.map +1 -0
- package/dist/types/abi/CSExitPenalties.d.ts +318 -0
- package/dist/types/abi/CSExitPenalties.d.ts.map +1 -0
- package/dist/types/abi/CSFeeDistributor.d.ts +827 -0
- package/dist/types/abi/CSFeeDistributor.d.ts.map +1 -0
- package/dist/types/abi/CSFeeOracle.d.ts +1035 -0
- package/dist/types/abi/CSFeeOracle.d.ts.map +1 -0
- package/dist/types/abi/CSMSatellite.d.ts +142 -0
- package/dist/types/abi/CSMSatellite.d.ts.map +1 -0
- package/dist/types/abi/CSModule.d.ts +2144 -0
- package/dist/types/abi/CSModule.d.ts.map +1 -0
- package/dist/types/abi/CSModuleV1Events.d.ts +602 -0
- package/dist/types/abi/CSModuleV1Events.d.ts.map +1 -0
- package/dist/types/abi/CSParametersRegistry.d.ts +1669 -0
- package/dist/types/abi/CSParametersRegistry.d.ts.map +1 -0
- package/dist/types/abi/CSStrikes.d.ts +565 -0
- package/dist/types/abi/CSStrikes.d.ts.map +1 -0
- package/dist/types/abi/HashConsensus.d.ts +887 -0
- package/dist/types/abi/HashConsensus.d.ts.map +1 -0
- package/dist/types/abi/PermissionlessGate.d.ts +485 -0
- package/dist/types/abi/PermissionlessGate.d.ts.map +1 -0
- package/dist/types/abi/StakingRouter.d.ts +1957 -0
- package/dist/types/abi/StakingRouter.d.ts.map +1 -0
- package/dist/types/abi/ValidatorsExitBusOracle.d.ts +32 -0
- package/dist/types/abi/ValidatorsExitBusOracle.d.ts.map +1 -0
- package/dist/types/abi/VettedGate.d.ts +1032 -0
- package/dist/types/abi/VettedGate.d.ts.map +1 -0
- package/dist/types/abi/WithdrawalVault.d.ts +22 -0
- package/dist/types/abi/WithdrawalVault.d.ts.map +1 -0
- package/dist/types/abi/index.d.ts +17 -0
- package/dist/types/abi/index.d.ts.map +1 -0
- package/dist/types/accounting-sdk/accounting-sdk.d.ts +24 -0
- package/dist/types/accounting-sdk/accounting-sdk.d.ts.map +1 -0
- package/dist/types/accounting-sdk/index.d.ts +3 -0
- package/dist/types/accounting-sdk/index.d.ts.map +1 -0
- package/dist/types/accounting-sdk/types.d.ts +15 -0
- package/dist/types/accounting-sdk/types.d.ts.map +1 -0
- package/dist/types/bond-sdk/bond-sdk.d.ts +26 -0
- package/dist/types/bond-sdk/bond-sdk.d.ts.map +1 -0
- package/dist/types/bond-sdk/index.d.ts +3 -0
- package/dist/types/bond-sdk/index.d.ts.map +1 -0
- package/dist/types/bond-sdk/types.d.ts +21 -0
- package/dist/types/bond-sdk/types.d.ts.map +1 -0
- package/dist/types/common/class-primitives/bus-registry.d.ts +7 -0
- package/dist/types/common/class-primitives/bus-registry.d.ts.map +1 -0
- package/dist/types/common/class-primitives/csm-sdk-cacheable.d.ts +7 -0
- package/dist/types/common/class-primitives/csm-sdk-cacheable.d.ts.map +1 -0
- package/dist/types/common/class-primitives/csm-sdk-module.d.ts +13 -0
- package/dist/types/common/class-primitives/csm-sdk-module.d.ts.map +1 -0
- package/dist/types/common/class-primitives/index.d.ts +3 -0
- package/dist/types/common/class-primitives/index.d.ts.map +1 -0
- package/dist/types/common/constants/base.d.ts +46 -0
- package/dist/types/common/constants/base.d.ts.map +1 -0
- package/dist/types/common/constants/index.d.ts +7 -0
- package/dist/types/common/constants/index.d.ts.map +1 -0
- package/dist/types/common/constants/keys.d.ts +23 -0
- package/dist/types/common/constants/keys.d.ts.map +1 -0
- package/dist/types/common/constants/links.d.ts +13 -0
- package/dist/types/common/constants/links.d.ts.map +1 -0
- package/dist/types/common/constants/permit.d.ts +3 -0
- package/dist/types/common/constants/permit.d.ts.map +1 -0
- package/dist/types/common/constants/roles.d.ts +11 -0
- package/dist/types/common/constants/roles.d.ts.map +1 -0
- package/dist/types/common/constants/tokens.d.ts +7 -0
- package/dist/types/common/constants/tokens.d.ts.map +1 -0
- package/dist/types/common/decorators/cache.d.ts +3 -0
- package/dist/types/common/decorators/cache.d.ts.map +1 -0
- package/dist/types/common/decorators/constants.d.ts +3 -0
- package/dist/types/common/decorators/constants.d.ts.map +1 -0
- package/dist/types/common/decorators/error-handler.d.ts +3 -0
- package/dist/types/common/decorators/error-handler.d.ts.map +1 -0
- package/dist/types/common/decorators/index.d.ts +7 -0
- package/dist/types/common/decorators/index.d.ts.map +1 -0
- package/dist/types/common/decorators/logger.d.ts +3 -0
- package/dist/types/common/decorators/logger.d.ts.map +1 -0
- package/dist/types/common/decorators/types.d.ts +2 -0
- package/dist/types/common/decorators/types.d.ts.map +1 -0
- package/dist/types/common/decorators/utils.d.ts +12 -0
- package/dist/types/common/decorators/utils.d.ts.map +1 -0
- package/dist/types/common/index.d.ts +3 -0
- package/dist/types/common/index.d.ts.map +1 -0
- package/dist/types/common/types.d.ts +55 -0
- package/dist/types/common/types.d.ts.map +1 -0
- package/dist/types/common/utils/clear-empty-address.d.ts +3 -0
- package/dist/types/common/utils/clear-empty-address.d.ts.map +1 -0
- package/dist/types/common/utils/compare-lowercase.d.ts +2 -0
- package/dist/types/common/utils/compare-lowercase.d.ts.map +1 -0
- package/dist/types/common/utils/fetch-json.d.ts +5 -0
- package/dist/types/common/utils/fetch-json.d.ts.map +1 -0
- package/dist/types/common/utils/find-index-and-leaf.d.ts +4 -0
- package/dist/types/common/utils/find-index-and-leaf.d.ts.map +1 -0
- package/dist/types/common/utils/index.d.ts +14 -0
- package/dist/types/common/utils/index.d.ts.map +1 -0
- package/dist/types/common/utils/is-bigint.d.ts +2 -0
- package/dist/types/common/utils/is-bigint.d.ts.map +1 -0
- package/dist/types/common/utils/is-defined.d.ts +4 -0
- package/dist/types/common/utils/is-defined.d.ts.map +1 -0
- package/dist/types/common/utils/is-hexadecimal-string.d.ts +5 -0
- package/dist/types/common/utils/is-hexadecimal-string.d.ts.map +1 -0
- package/dist/types/common/utils/on-error.d.ts +3 -0
- package/dist/types/common/utils/on-error.d.ts.map +1 -0
- package/dist/types/common/utils/parse-deposit-data.d.ts +7 -0
- package/dist/types/common/utils/parse-deposit-data.d.ts.map +1 -0
- package/dist/types/common/utils/parse-value.d.ts +2 -0
- package/dist/types/common/utils/parse-value.d.ts.map +1 -0
- package/dist/types/common/utils/request-with-block-step.d.ts +9 -0
- package/dist/types/common/utils/request-with-block-step.d.ts.map +1 -0
- package/dist/types/common/utils/sort-events.d.ts +4 -0
- package/dist/types/common/utils/sort-events.d.ts.map +1 -0
- package/dist/types/common/utils/split-keys.d.ts +3 -0
- package/dist/types/common/utils/split-keys.d.ts.map +1 -0
- package/dist/types/common/utils/strip-permit.d.ts +3 -0
- package/dist/types/common/utils/strip-permit.d.ts.map +1 -0
- package/dist/types/core-sdk/core-sdk.d.ts +6933 -0
- package/dist/types/core-sdk/core-sdk.d.ts.map +1 -0
- package/dist/types/core-sdk/index.d.ts +3 -0
- package/dist/types/core-sdk/index.d.ts.map +1 -0
- package/dist/types/core-sdk/types.d.ts +114 -0
- package/dist/types/core-sdk/types.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/constants.d.ts +13 -0
- package/dist/types/deposit-data-sdk/constants.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/deposit-data-sdk.d.ts +29 -0
- package/dist/types/deposit-data-sdk/deposit-data-sdk.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/index.d.ts +3 -0
- package/dist/types/deposit-data-sdk/index.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/parser.d.ts +10 -0
- package/dist/types/deposit-data-sdk/parser.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/signature.d.ts +30 -0
- package/dist/types/deposit-data-sdk/signature.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/types.d.ts +63 -0
- package/dist/types/deposit-data-sdk/types.d.ts.map +1 -0
- package/dist/types/deposit-data-sdk/validator.d.ts +7 -0
- package/dist/types/deposit-data-sdk/validator.d.ts.map +1 -0
- package/dist/types/deposit-queue-sdk/deposit-queue-sdk.d.ts +12 -0
- package/dist/types/deposit-queue-sdk/deposit-queue-sdk.d.ts.map +1 -0
- package/dist/types/deposit-queue-sdk/filter-batches.d.ts +3 -0
- package/dist/types/deposit-queue-sdk/filter-batches.d.ts.map +1 -0
- package/dist/types/deposit-queue-sdk/index.d.ts +3 -0
- package/dist/types/deposit-queue-sdk/index.d.ts.map +1 -0
- package/dist/types/deposit-queue-sdk/parse-batch.d.ts +3 -0
- package/dist/types/deposit-queue-sdk/parse-batch.d.ts.map +1 -0
- package/dist/types/deposit-queue-sdk/types.d.ts +30 -0
- package/dist/types/deposit-queue-sdk/types.d.ts.map +1 -0
- package/dist/types/events-sdk/events-sdk.d.ts +1050 -0
- package/dist/types/events-sdk/events-sdk.d.ts.map +1 -0
- package/dist/types/events-sdk/get-node-operator-roles.d.ts +5 -0
- package/dist/types/events-sdk/get-node-operator-roles.d.ts.map +1 -0
- package/dist/types/events-sdk/index.d.ts +5 -0
- package/dist/types/events-sdk/index.d.ts.map +1 -0
- package/dist/types/events-sdk/merge.d.ts +12 -0
- package/dist/types/events-sdk/merge.d.ts.map +1 -0
- package/dist/types/events-sdk/reconstruct-invites.d.ts +7 -0
- package/dist/types/events-sdk/reconstruct-invites.d.ts.map +1 -0
- package/dist/types/events-sdk/reconstruct-operators.d.ts +7 -0
- package/dist/types/events-sdk/reconstruct-operators.d.ts.map +1 -0
- package/dist/types/events-sdk/types.d.ts +8 -0
- package/dist/types/events-sdk/types.d.ts.map +1 -0
- package/dist/types/fee-recipient-sdk/api-client.d.ts +21 -0
- package/dist/types/fee-recipient-sdk/api-client.d.ts.map +1 -0
- package/dist/types/fee-recipient-sdk/constants.d.ts +13 -0
- package/dist/types/fee-recipient-sdk/constants.d.ts.map +1 -0
- package/dist/types/fee-recipient-sdk/fee-recipient-sdk.d.ts +71 -0
- package/dist/types/fee-recipient-sdk/fee-recipient-sdk.d.ts.map +1 -0
- package/dist/types/fee-recipient-sdk/index.d.ts +6 -0
- package/dist/types/fee-recipient-sdk/index.d.ts.map +1 -0
- package/dist/types/fee-recipient-sdk/types.d.ts +58 -0
- package/dist/types/fee-recipient-sdk/types.d.ts.map +1 -0
- package/dist/types/fee-recipient-sdk/validators.d.ts +23 -0
- package/dist/types/fee-recipient-sdk/validators.d.ts.map +1 -0
- package/dist/types/frame-sdk/frame-sdk.d.ts +9 -0
- package/dist/types/frame-sdk/frame-sdk.d.ts.map +1 -0
- package/dist/types/frame-sdk/index.d.ts +3 -0
- package/dist/types/frame-sdk/index.d.ts.map +1 -0
- package/dist/types/frame-sdk/types.d.ts +29 -0
- package/dist/types/frame-sdk/types.d.ts.map +1 -0
- package/dist/types/ics-gate-sdk/fetch-proofs-tree.d.ts +3 -0
- package/dist/types/ics-gate-sdk/fetch-proofs-tree.d.ts.map +1 -0
- package/dist/types/ics-gate-sdk/find-proof.d.ts +6 -0
- package/dist/types/ics-gate-sdk/find-proof.d.ts.map +1 -0
- package/dist/types/ics-gate-sdk/ics-gate-sdk.d.ts +36 -0
- package/dist/types/ics-gate-sdk/ics-gate-sdk.d.ts.map +1 -0
- package/dist/types/ics-gate-sdk/index.d.ts +3 -0
- package/dist/types/ics-gate-sdk/index.d.ts.map +1 -0
- package/dist/types/ics-gate-sdk/types.d.ts +39 -0
- package/dist/types/ics-gate-sdk/types.d.ts.map +1 -0
- package/dist/types/index.d.ts +25 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/keys-cache-sdk/constants.d.ts +2 -0
- package/dist/types/keys-cache-sdk/constants.d.ts.map +1 -0
- package/dist/types/keys-cache-sdk/index.d.ts +4 -0
- package/dist/types/keys-cache-sdk/index.d.ts.map +1 -0
- package/dist/types/keys-cache-sdk/keys-cache-sdk.d.ts +40 -0
- package/dist/types/keys-cache-sdk/keys-cache-sdk.d.ts.map +1 -0
- package/dist/types/keys-cache-sdk/storage.d.ts +6 -0
- package/dist/types/keys-cache-sdk/storage.d.ts.map +1 -0
- package/dist/types/keys-cache-sdk/types.d.ts +6 -0
- package/dist/types/keys-cache-sdk/types.d.ts.map +1 -0
- package/dist/types/keys-sdk/index.d.ts +3 -0
- package/dist/types/keys-sdk/index.d.ts.map +1 -0
- package/dist/types/keys-sdk/keys-sdk.d.ts +24 -0
- package/dist/types/keys-sdk/keys-sdk.d.ts.map +1 -0
- package/dist/types/keys-sdk/types.d.ts +43 -0
- package/dist/types/keys-sdk/types.d.ts.map +1 -0
- package/dist/types/keys-with-status-sdk/cl-chunks.d.ts +6 -0
- package/dist/types/keys-with-status-sdk/cl-chunks.d.ts.map +1 -0
- package/dist/types/keys-with-status-sdk/index.d.ts +3 -0
- package/dist/types/keys-with-status-sdk/index.d.ts.map +1 -0
- package/dist/types/keys-with-status-sdk/keys-with-status-sdk.d.ts +26 -0
- package/dist/types/keys-with-status-sdk/keys-with-status-sdk.d.ts.map +1 -0
- package/dist/types/keys-with-status-sdk/types.d.ts +52 -0
- package/dist/types/keys-with-status-sdk/types.d.ts.map +1 -0
- package/dist/types/keys-with-status-sdk/utils.d.ts +2 -0
- package/dist/types/keys-with-status-sdk/utils.d.ts.map +1 -0
- package/dist/types/lido-sdk-csm.d.ts +49 -0
- package/dist/types/lido-sdk-csm.d.ts.map +1 -0
- package/dist/types/module-sdk/calculate-share-limit.d.ts +3 -0
- package/dist/types/module-sdk/calculate-share-limit.d.ts.map +1 -0
- package/dist/types/module-sdk/find-module-digest.d.ts +3 -0
- package/dist/types/module-sdk/find-module-digest.d.ts.map +1 -0
- package/dist/types/module-sdk/index.d.ts +3 -0
- package/dist/types/module-sdk/index.d.ts.map +1 -0
- package/dist/types/module-sdk/module-sdk.d.ts +21 -0
- package/dist/types/module-sdk/module-sdk.d.ts.map +1 -0
- package/dist/types/module-sdk/types.d.ts +82 -0
- package/dist/types/module-sdk/types.d.ts.map +1 -0
- package/dist/types/operator-sdk/calc-bond-balance.d.ts +9 -0
- package/dist/types/operator-sdk/calc-bond-balance.d.ts.map +1 -0
- package/dist/types/operator-sdk/index.d.ts +4 -0
- package/dist/types/operator-sdk/index.d.ts.map +1 -0
- package/dist/types/operator-sdk/operator-sdk.d.ts +21 -0
- package/dist/types/operator-sdk/operator-sdk.d.ts.map +1 -0
- package/dist/types/operator-sdk/types.d.ts +20 -0
- package/dist/types/operator-sdk/types.d.ts.map +1 -0
- package/dist/types/parameters-sdk/index.d.ts +3 -0
- package/dist/types/parameters-sdk/index.d.ts.map +1 -0
- package/dist/types/parameters-sdk/parameters-sdk.d.ts +24 -0
- package/dist/types/parameters-sdk/parameters-sdk.d.ts.map +1 -0
- package/dist/types/parameters-sdk/types.d.ts +34 -0
- package/dist/types/parameters-sdk/types.d.ts.map +1 -0
- package/dist/types/permissionless-gate-sdk/index.d.ts +3 -0
- package/dist/types/permissionless-gate-sdk/index.d.ts.map +1 -0
- package/dist/types/permissionless-gate-sdk/permissionless-gate-sdk.d.ts +19 -0
- package/dist/types/permissionless-gate-sdk/permissionless-gate-sdk.d.ts.map +1 -0
- package/dist/types/permissionless-gate-sdk/types.d.ts +27 -0
- package/dist/types/permissionless-gate-sdk/types.d.ts.map +1 -0
- package/dist/types/rewards-sdk/fetch-rewards-tree.d.ts +3 -0
- package/dist/types/rewards-sdk/fetch-rewards-tree.d.ts.map +1 -0
- package/dist/types/rewards-sdk/find-operator-rewards.d.ts +4 -0
- package/dist/types/rewards-sdk/find-operator-rewards.d.ts.map +1 -0
- package/dist/types/rewards-sdk/find-proof.d.ts +6 -0
- package/dist/types/rewards-sdk/find-proof.d.ts.map +1 -0
- package/dist/types/rewards-sdk/index.d.ts +3 -0
- package/dist/types/rewards-sdk/index.d.ts.map +1 -0
- package/dist/types/rewards-sdk/rewards-sdk.d.ts +30 -0
- package/dist/types/rewards-sdk/rewards-sdk.d.ts.map +1 -0
- package/dist/types/rewards-sdk/types.d.ts +81 -0
- package/dist/types/rewards-sdk/types.d.ts.map +1 -0
- package/dist/types/roles-sdk/index.d.ts +3 -0
- package/dist/types/roles-sdk/index.d.ts.map +1 -0
- package/dist/types/roles-sdk/roles-sdk.d.ts +14 -0
- package/dist/types/roles-sdk/roles-sdk.d.ts.map +1 -0
- package/dist/types/roles-sdk/types.d.ts +17 -0
- package/dist/types/roles-sdk/types.d.ts.map +1 -0
- package/dist/types/satellite-sdk/index.d.ts +3 -0
- package/dist/types/satellite-sdk/index.d.ts.map +1 -0
- package/dist/types/satellite-sdk/satellite-sdk.d.ts +11 -0
- package/dist/types/satellite-sdk/satellite-sdk.d.ts.map +1 -0
- package/dist/types/satellite-sdk/types.d.ts +23 -0
- package/dist/types/satellite-sdk/types.d.ts.map +1 -0
- package/dist/types/spending-sdk/index.d.ts +3 -0
- package/dist/types/spending-sdk/index.d.ts.map +1 -0
- package/dist/types/spending-sdk/spending-sdk.d.ts +28 -0
- package/dist/types/spending-sdk/spending-sdk.d.ts.map +1 -0
- package/dist/types/spending-sdk/types.d.ts +17 -0
- package/dist/types/spending-sdk/types.d.ts.map +1 -0
- package/dist/types/stealing-sdk/index.d.ts +3 -0
- package/dist/types/stealing-sdk/index.d.ts.map +1 -0
- package/dist/types/stealing-sdk/stealing-sdk.d.ts +18 -0
- package/dist/types/stealing-sdk/stealing-sdk.d.ts.map +1 -0
- package/dist/types/stealing-sdk/types.d.ts +17 -0
- package/dist/types/stealing-sdk/types.d.ts.map +1 -0
- package/dist/types/strikes-sdk/fetch-proofs-tree.d.ts +3 -0
- package/dist/types/strikes-sdk/fetch-proofs-tree.d.ts.map +1 -0
- package/dist/types/strikes-sdk/find-proof.d.ts +9 -0
- package/dist/types/strikes-sdk/find-proof.d.ts.map +1 -0
- package/dist/types/strikes-sdk/index.d.ts +3 -0
- package/dist/types/strikes-sdk/index.d.ts.map +1 -0
- package/dist/types/strikes-sdk/strikes-sdk.d.ts +20 -0
- package/dist/types/strikes-sdk/strikes-sdk.d.ts.map +1 -0
- package/dist/types/strikes-sdk/types.d.ts +10 -0
- package/dist/types/strikes-sdk/types.d.ts.map +1 -0
- package/dist/types/version.d.ts +2 -0
- package/dist/types/version.d.ts.map +1 -0
- package/package.json +259 -0
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
|
|
2
|
+
var useValue = arguments.length > 2;
|
|
3
|
+
for (var i = 0; i < initializers.length; i++) {
|
|
4
|
+
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
|
|
5
|
+
}
|
|
6
|
+
return useValue ? value : void 0;
|
|
7
|
+
};
|
|
8
|
+
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
|
|
9
|
+
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
|
|
10
|
+
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
|
|
11
|
+
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
|
|
12
|
+
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
|
|
13
|
+
var _, done = false;
|
|
14
|
+
for (var i = decorators.length - 1; i >= 0; i--) {
|
|
15
|
+
var context = {};
|
|
16
|
+
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
|
|
17
|
+
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
|
|
18
|
+
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
|
|
19
|
+
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
|
|
20
|
+
if (kind === "accessor") {
|
|
21
|
+
if (result === void 0) continue;
|
|
22
|
+
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
|
|
23
|
+
if (_ = accept(result.get)) descriptor.get = _;
|
|
24
|
+
if (_ = accept(result.set)) descriptor.set = _;
|
|
25
|
+
if (_ = accept(result.init)) initializers.unshift(_);
|
|
26
|
+
}
|
|
27
|
+
else if (_ = accept(result)) {
|
|
28
|
+
if (kind === "field") initializers.unshift(_);
|
|
29
|
+
else descriptor[key] = _;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (target) Object.defineProperty(target, contextIn.name, descriptor);
|
|
33
|
+
done = true;
|
|
34
|
+
};
|
|
35
|
+
import { CsmSDKModule } from '../common/class-primitives/csm-sdk-module.js';
|
|
36
|
+
import { Cache, ErrorHandler, Logger } from '../common/decorators/index.js';
|
|
37
|
+
import { CSM_CONTRACT_NAMES } from '../common/index.js';
|
|
38
|
+
import { compareLowercase, toHexString } from '../common/utils/index.js';
|
|
39
|
+
import { parseDepositData, removeKey } from './parser.js';
|
|
40
|
+
import { ValidationErrorCode, } from './types.js';
|
|
41
|
+
import { validateDepositData, validateDepositDataSync } from './validator.js';
|
|
42
|
+
let DepositDataSDK = (() => {
|
|
43
|
+
var _a;
|
|
44
|
+
let _classSuper = CsmSDKModule;
|
|
45
|
+
let _instanceExtraInitializers = [];
|
|
46
|
+
let _parseDepositData_decorators;
|
|
47
|
+
let _removeKey_decorators;
|
|
48
|
+
let _validateDepositData_decorators;
|
|
49
|
+
let _validateDepositDataSync_decorators;
|
|
50
|
+
let _checkUploadedKeys_decorators;
|
|
51
|
+
let _checkCachedKeys_decorators;
|
|
52
|
+
return _a = class DepositDataSDK extends _classSuper {
|
|
53
|
+
/**
|
|
54
|
+
* Parse deposit data JSON with enhanced error handling
|
|
55
|
+
*/
|
|
56
|
+
parseDepositData(json) {
|
|
57
|
+
return parseDepositData(json);
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Remove key at specified index with comprehensive validation
|
|
61
|
+
*/
|
|
62
|
+
removeKey(json, index) {
|
|
63
|
+
return removeKey(json, index);
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Validation of deposit data including signature verification
|
|
67
|
+
*/
|
|
68
|
+
async validateDepositData(depositData) {
|
|
69
|
+
const chainId = this.core.chainId;
|
|
70
|
+
const wc = this.core.getContractAddress(CSM_CONTRACT_NAMES.withdrawalVault);
|
|
71
|
+
const blockNumber = await this.core.client.getBlockNumber();
|
|
72
|
+
const errors = await validateDepositData(depositData, {
|
|
73
|
+
chainId,
|
|
74
|
+
withdrawalCredentials: wc,
|
|
75
|
+
currentBlockNumber: Number(blockNumber),
|
|
76
|
+
});
|
|
77
|
+
// Extract pubkeys for additional checks
|
|
78
|
+
const pubkeys = depositData.map((data) => data.pubkey);
|
|
79
|
+
// Check for cached duplicates
|
|
80
|
+
const duplicateErrors = this.checkCachedKeys(pubkeys);
|
|
81
|
+
// Check for previously uploaded keys
|
|
82
|
+
const uploadedDuplicateErrors = await this.checkUploadedKeys(pubkeys.map(toHexString));
|
|
83
|
+
// Merge all errors
|
|
84
|
+
return [...errors, ...duplicateErrors, ...uploadedDuplicateErrors];
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Quick synchronous validation without signature verification
|
|
88
|
+
*/
|
|
89
|
+
validateDepositDataSync(depositData) {
|
|
90
|
+
const chainId = this.core.chainId;
|
|
91
|
+
const wc = this.core.getContractAddress(CSM_CONTRACT_NAMES.withdrawalVault);
|
|
92
|
+
return validateDepositDataSync(depositData, {
|
|
93
|
+
chainId,
|
|
94
|
+
withdrawalCredentials: wc,
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
async checkUploadedKeys(pubkeys) {
|
|
98
|
+
const keys = await this.bus.get('keysWithStatus')?.getApiKeys(pubkeys);
|
|
99
|
+
const errors = [];
|
|
100
|
+
if (!keys)
|
|
101
|
+
return errors;
|
|
102
|
+
pubkeys.forEach((pubkey, index) => {
|
|
103
|
+
const isUploaded = keys.find((key) => compareLowercase(key.key, pubkey));
|
|
104
|
+
if (isUploaded) {
|
|
105
|
+
errors.push({
|
|
106
|
+
index,
|
|
107
|
+
message: `pubkey was previously submitted`,
|
|
108
|
+
field: 'pubkey',
|
|
109
|
+
code: ValidationErrorCode.PREVIOUSLY_SUBMITTED,
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
return errors;
|
|
114
|
+
}
|
|
115
|
+
checkCachedKeys(pubkeys) {
|
|
116
|
+
const keysCache = this.bus.get('keysCache');
|
|
117
|
+
const errors = [];
|
|
118
|
+
if (!keysCache)
|
|
119
|
+
return errors;
|
|
120
|
+
pubkeys.forEach((pubkey, index) => {
|
|
121
|
+
if (keysCache.isDuplicate(pubkey)) {
|
|
122
|
+
errors.push({
|
|
123
|
+
index,
|
|
124
|
+
message: `pubkey already exists in cache`,
|
|
125
|
+
field: 'pubkey',
|
|
126
|
+
code: ValidationErrorCode.DUPLICATE_PUBKEY,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
return errors;
|
|
131
|
+
}
|
|
132
|
+
constructor() {
|
|
133
|
+
super(...arguments);
|
|
134
|
+
__runInitializers(this, _instanceExtraInitializers);
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
(() => {
|
|
138
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
139
|
+
_parseDepositData_decorators = [Logger('Utils:')];
|
|
140
|
+
_removeKey_decorators = [Logger('Utils:')];
|
|
141
|
+
_validateDepositData_decorators = [Logger('Utils:')];
|
|
142
|
+
_validateDepositDataSync_decorators = [Logger('Utils:')];
|
|
143
|
+
_checkUploadedKeys_decorators = [Logger('API:'), ErrorHandler(), Cache(60 * 1000)];
|
|
144
|
+
_checkCachedKeys_decorators = [Logger('Utils:'), ErrorHandler()];
|
|
145
|
+
__esDecorate(_a, null, _parseDepositData_decorators, { kind: "method", name: "parseDepositData", static: false, private: false, access: { has: obj => "parseDepositData" in obj, get: obj => obj.parseDepositData }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
146
|
+
__esDecorate(_a, null, _removeKey_decorators, { kind: "method", name: "removeKey", static: false, private: false, access: { has: obj => "removeKey" in obj, get: obj => obj.removeKey }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
147
|
+
__esDecorate(_a, null, _validateDepositData_decorators, { kind: "method", name: "validateDepositData", static: false, private: false, access: { has: obj => "validateDepositData" in obj, get: obj => obj.validateDepositData }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
148
|
+
__esDecorate(_a, null, _validateDepositDataSync_decorators, { kind: "method", name: "validateDepositDataSync", static: false, private: false, access: { has: obj => "validateDepositDataSync" in obj, get: obj => obj.validateDepositDataSync }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
149
|
+
__esDecorate(_a, null, _checkUploadedKeys_decorators, { kind: "method", name: "checkUploadedKeys", static: false, private: false, access: { has: obj => "checkUploadedKeys" in obj, get: obj => obj.checkUploadedKeys }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
150
|
+
__esDecorate(_a, null, _checkCachedKeys_decorators, { kind: "method", name: "checkCachedKeys", static: false, private: false, access: { has: obj => "checkCachedKeys" in obj, get: obj => obj.checkCachedKeys }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
151
|
+
if (_metadata) Object.defineProperty(_a, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
152
|
+
})(),
|
|
153
|
+
_a;
|
|
154
|
+
})();
|
|
155
|
+
export { DepositDataSDK };
|
|
156
|
+
//# sourceMappingURL=deposit-data-sdk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deposit-data-sdk.js","sourceRoot":"","sources":["../../../src/deposit-data-sdk/deposit-data-sdk.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/deposit-data-sdk/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { MAX_JSON_LENGTH } from './constants.js';
|
|
2
|
+
/**
|
|
3
|
+
* Normalizes hex values in JSON by removing '0x' prefixes
|
|
4
|
+
*/
|
|
5
|
+
const normalizeHexInJson = (text) => {
|
|
6
|
+
return text.replace(/"0x/gm, '"');
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Validates and parses JSON string into DepositData array
|
|
10
|
+
* This function combines validation and parsing logic
|
|
11
|
+
*/
|
|
12
|
+
const parseAndValidateJson = (data) => {
|
|
13
|
+
// Check for empty data
|
|
14
|
+
if (!data || data.trim() === '') {
|
|
15
|
+
return {
|
|
16
|
+
depositData: [],
|
|
17
|
+
error: 'Deposit data should not be empty',
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
// Check size limit
|
|
21
|
+
if (data.length > MAX_JSON_LENGTH) {
|
|
22
|
+
return {
|
|
23
|
+
depositData: [],
|
|
24
|
+
error: `Deposit data is too big (max ${Math.round(MAX_JSON_LENGTH / 1024 / 1024)}MB)`,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
// Parse JSON
|
|
28
|
+
let parsed;
|
|
29
|
+
try {
|
|
30
|
+
parsed = JSON.parse(data);
|
|
31
|
+
}
|
|
32
|
+
catch (error) {
|
|
33
|
+
return {
|
|
34
|
+
depositData: [],
|
|
35
|
+
error: 'Invalid JSON format',
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
// Ensure we have an array
|
|
39
|
+
const depositData = Array.isArray(parsed) ? parsed : [parsed];
|
|
40
|
+
// Validate array is not empty
|
|
41
|
+
if (depositData.length === 0) {
|
|
42
|
+
return {
|
|
43
|
+
depositData: [],
|
|
44
|
+
error: 'Should have at least 1 key',
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
// Basic validation of each item
|
|
48
|
+
for (const [index, item] of depositData.entries()) {
|
|
49
|
+
if (!item || typeof item !== 'object') {
|
|
50
|
+
return {
|
|
51
|
+
depositData: [],
|
|
52
|
+
error: `Item at index ${index} should be an object`,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
// Check for required fields
|
|
56
|
+
const requiredFields = [
|
|
57
|
+
'pubkey',
|
|
58
|
+
'withdrawal_credentials',
|
|
59
|
+
'amount',
|
|
60
|
+
'signature',
|
|
61
|
+
'deposit_message_root',
|
|
62
|
+
'deposit_data_root',
|
|
63
|
+
'fork_version',
|
|
64
|
+
];
|
|
65
|
+
for (const field of requiredFields) {
|
|
66
|
+
if (!(field in item)) {
|
|
67
|
+
return {
|
|
68
|
+
depositData: [],
|
|
69
|
+
error: `Item at index ${index} is missing required field: ${field}`,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
return { depositData };
|
|
75
|
+
};
|
|
76
|
+
/**
|
|
77
|
+
* Parse deposit data JSON with comprehensive error handling
|
|
78
|
+
*/
|
|
79
|
+
export const parseDepositData = (jsonDepositData) => {
|
|
80
|
+
const normalizedJson = normalizeHexInJson(jsonDepositData);
|
|
81
|
+
const result = parseAndValidateJson(normalizedJson);
|
|
82
|
+
if (result.error) {
|
|
83
|
+
return {
|
|
84
|
+
success: false,
|
|
85
|
+
error: result.error,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
return {
|
|
89
|
+
success: true,
|
|
90
|
+
data: result.depositData,
|
|
91
|
+
};
|
|
92
|
+
};
|
|
93
|
+
/**
|
|
94
|
+
* Remove a key at specified index with enhanced error handling
|
|
95
|
+
*/
|
|
96
|
+
export const removeKey = (jsonDepositData, index) => {
|
|
97
|
+
// Validate index parameter
|
|
98
|
+
if (!Number.isInteger(index) || index < 0) {
|
|
99
|
+
return {
|
|
100
|
+
success: false,
|
|
101
|
+
error: 'Index must be a non-negative integer',
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
// Parse the JSON first
|
|
105
|
+
const parseResult = parseDepositData(jsonDepositData);
|
|
106
|
+
if (!parseResult.success || !parseResult.data) {
|
|
107
|
+
return {
|
|
108
|
+
success: false,
|
|
109
|
+
error: parseResult.error || 'Failed to parse deposit data',
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
const depositData = parseResult.data;
|
|
113
|
+
// Validate index is within bounds
|
|
114
|
+
if (index >= depositData.length) {
|
|
115
|
+
return {
|
|
116
|
+
success: false,
|
|
117
|
+
error: `Index ${index} is out of bounds (array length: ${depositData.length})`,
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
// Remove the item
|
|
121
|
+
const updatedData = Array.from(depositData);
|
|
122
|
+
updatedData.splice(index, 1);
|
|
123
|
+
// Return result
|
|
124
|
+
const json = updatedData.length > 0 ? JSON.stringify(updatedData, null, 2) : '';
|
|
125
|
+
return {
|
|
126
|
+
success: true,
|
|
127
|
+
data: updatedData,
|
|
128
|
+
json,
|
|
129
|
+
};
|
|
130
|
+
};
|
|
131
|
+
//# sourceMappingURL=parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../src/deposit-data-sdk/parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Alternative BLS signature verification implementation for Ethereum deposit data.
|
|
3
|
+
*
|
|
4
|
+
* This implementation follows the Ethereum consensus specification closely:
|
|
5
|
+
* - Proper SSZ serialization using @chainsafe/ssz
|
|
6
|
+
* - Clear separation of domain computation, signing root, and verification
|
|
7
|
+
* - Better error handling and type safety
|
|
8
|
+
* - Compatible with both @chainsafe/bls and bls-eth-wasm
|
|
9
|
+
*
|
|
10
|
+
* Reference:
|
|
11
|
+
* - https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/beacon-chain.md#bls-signatures
|
|
12
|
+
* - https://github.com/ethereum/consensus-specs/blob/dev/specs/phase0/deposit-contract.md
|
|
13
|
+
*/
|
|
14
|
+
import { ByteVectorType, ContainerType, UintBigintType } from '@chainsafe/ssz';
|
|
15
|
+
import bls from 'bls-eth-wasm';
|
|
16
|
+
import { hexToBytes, toHex } from 'viem';
|
|
17
|
+
import { DOMAIN_DEPOSIT, FIXED_FORK_VERSION } from './constants.js';
|
|
18
|
+
/**
|
|
19
|
+
* SSZ Types following Ethereum consensus spec
|
|
20
|
+
*/
|
|
21
|
+
/** DepositMessage as per consensus spec */
|
|
22
|
+
const DepositMessageSSZ = new ContainerType({
|
|
23
|
+
pubkey: new ByteVectorType(48),
|
|
24
|
+
withdrawal_credentials: new ByteVectorType(32),
|
|
25
|
+
amount: new UintBigintType(8),
|
|
26
|
+
});
|
|
27
|
+
/** ForkData for computing fork-specific domain */
|
|
28
|
+
const ForkDataSSZ = new ContainerType({
|
|
29
|
+
current_version: new ByteVectorType(4),
|
|
30
|
+
genesis_validators_root: new ByteVectorType(32),
|
|
31
|
+
});
|
|
32
|
+
/** SigningData for computing signing root */
|
|
33
|
+
const SigningDataSSZ = new ContainerType({
|
|
34
|
+
object_root: new ByteVectorType(32),
|
|
35
|
+
domain: new ByteVectorType(32),
|
|
36
|
+
});
|
|
37
|
+
/**
|
|
38
|
+
* BLS initialization
|
|
39
|
+
*/
|
|
40
|
+
let blsInitialized = false;
|
|
41
|
+
const ensureBLSInit = async () => {
|
|
42
|
+
if (!blsInitialized) {
|
|
43
|
+
await bls.init(bls.BLS12_381);
|
|
44
|
+
blsInitialized = true;
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Helper to ensure hex strings have 0x prefix
|
|
49
|
+
*/
|
|
50
|
+
const ensureHex = (value) => {
|
|
51
|
+
return (value.startsWith('0x') ? value : `0x${value}`);
|
|
52
|
+
};
|
|
53
|
+
/**
|
|
54
|
+
* Get fork version for the chain
|
|
55
|
+
* @throws {Error} If fork version is not found
|
|
56
|
+
*/
|
|
57
|
+
const getForkVersion = (chainId) => {
|
|
58
|
+
const version = FIXED_FORK_VERSION[chainId];
|
|
59
|
+
if (!version) {
|
|
60
|
+
throw new Error(`Fork version not found for chain ${chainId}`);
|
|
61
|
+
}
|
|
62
|
+
// Fork version is 4 bytes, pad if necessary
|
|
63
|
+
const hex = version.padStart(8, '0');
|
|
64
|
+
return hexToBytes(ensureHex(hex));
|
|
65
|
+
};
|
|
66
|
+
/**
|
|
67
|
+
* Compute fork data root using SSZ
|
|
68
|
+
*
|
|
69
|
+
* per consensus spec:
|
|
70
|
+
* def compute_fork_data_root(current_version: Version, genesis_validators_root: Root) -> Root:
|
|
71
|
+
* return hash_tree_root(ForkData(
|
|
72
|
+
* current_version=current_version,
|
|
73
|
+
* genesis_validators_root=genesis_validators_root,
|
|
74
|
+
* ))
|
|
75
|
+
*/
|
|
76
|
+
const computeForkDataRoot = (currentVersion, genesisValidatorsRoot) => {
|
|
77
|
+
const forkData = {
|
|
78
|
+
current_version: currentVersion,
|
|
79
|
+
genesis_validators_root: genesisValidatorsRoot,
|
|
80
|
+
};
|
|
81
|
+
return ForkDataSSZ.hashTreeRoot(forkData);
|
|
82
|
+
};
|
|
83
|
+
/**
|
|
84
|
+
* Compute domain using domain type and fork data root
|
|
85
|
+
*
|
|
86
|
+
* per consensus spec:
|
|
87
|
+
* def compute_domain(domain_type: DomainType, fork_version: Version=None, genesis_validators_root: Root=None) -> Domain:
|
|
88
|
+
* if fork_version is None:
|
|
89
|
+
* fork_version = config.GENESIS_FORK_VERSION
|
|
90
|
+
* if genesis_validators_root is None:
|
|
91
|
+
* genesis_validators_root = Root()
|
|
92
|
+
* fork_data_root = compute_fork_data_root(fork_version, genesis_validators_root)
|
|
93
|
+
* return Domain(domain_type + fork_data_root[:28])
|
|
94
|
+
*/
|
|
95
|
+
const computeDomain = (domainType, forkVersion, genesisValidatorsRoot) => {
|
|
96
|
+
const forkDataRoot = computeForkDataRoot(forkVersion, genesisValidatorsRoot);
|
|
97
|
+
// Domain is domain_type (4 bytes) + first 28 bytes of fork_data_root
|
|
98
|
+
const domain = new Uint8Array(32);
|
|
99
|
+
domain.set(domainType, 0);
|
|
100
|
+
domain.set(forkDataRoot.slice(0, 28), 4);
|
|
101
|
+
return domain;
|
|
102
|
+
};
|
|
103
|
+
/**
|
|
104
|
+
* Compute signing root from object root and domain
|
|
105
|
+
*
|
|
106
|
+
* per consensus spec:
|
|
107
|
+
* def compute_signing_root(ssz_object: SSZObject, domain: Domain) -> Root:
|
|
108
|
+
* return hash_tree_root(SigningData(
|
|
109
|
+
* object_root=hash_tree_root(ssz_object),
|
|
110
|
+
* domain=domain,
|
|
111
|
+
* ))
|
|
112
|
+
*/
|
|
113
|
+
const computeSigningRoot = (objectRoot, domain) => {
|
|
114
|
+
const signingData = {
|
|
115
|
+
object_root: objectRoot,
|
|
116
|
+
domain: domain,
|
|
117
|
+
};
|
|
118
|
+
return SigningDataSSZ.hashTreeRoot(signingData);
|
|
119
|
+
};
|
|
120
|
+
/**
|
|
121
|
+
* Compute deposit message root (hash tree root of DepositMessage)
|
|
122
|
+
*/
|
|
123
|
+
const computeDepositMessageRoot = (message) => {
|
|
124
|
+
return DepositMessageSSZ.hashTreeRoot(message);
|
|
125
|
+
};
|
|
126
|
+
/**
|
|
127
|
+
* Verify BLS signature for deposit data following Ethereum consensus spec
|
|
128
|
+
*
|
|
129
|
+
* @param data - Deposit data to verify
|
|
130
|
+
* @param chainId - Chain ID (mainnet or testnet)
|
|
131
|
+
* @returns Promise<boolean> - True if signature is valid
|
|
132
|
+
*
|
|
133
|
+
* @example
|
|
134
|
+
* const isValid = await verifyDepositSignature(depositData, CHAINS.Mainnet);
|
|
135
|
+
* if (!isValid) {
|
|
136
|
+
* console.error('Invalid signature');
|
|
137
|
+
* }
|
|
138
|
+
*/
|
|
139
|
+
export const verifyDepositSignature = async (data, chainId) => {
|
|
140
|
+
try {
|
|
141
|
+
// Initialize BLS library
|
|
142
|
+
await ensureBLSInit();
|
|
143
|
+
// Parse input data
|
|
144
|
+
const pubkey = hexToBytes(ensureHex(data.pubkey));
|
|
145
|
+
const signature = hexToBytes(ensureHex(data.signature));
|
|
146
|
+
const withdrawalCredentials = hexToBytes(ensureHex(data.withdrawal_credentials));
|
|
147
|
+
const amount = BigInt(data.amount);
|
|
148
|
+
// Validate input sizes
|
|
149
|
+
if (pubkey.length !== 48 || signature.length !== 96 || withdrawalCredentials.length !== 32) {
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
// Build DepositMessage
|
|
153
|
+
const depositMessage = {
|
|
154
|
+
pubkey,
|
|
155
|
+
withdrawal_credentials: withdrawalCredentials,
|
|
156
|
+
amount,
|
|
157
|
+
};
|
|
158
|
+
// Step 1: Compute deposit message root
|
|
159
|
+
const messageRoot = computeDepositMessageRoot(depositMessage);
|
|
160
|
+
// Verify deposit_message_root matches
|
|
161
|
+
const providedMessageRoot = ensureHex(data.deposit_message_root);
|
|
162
|
+
if (toHex(messageRoot).toLowerCase() !== providedMessageRoot.toLowerCase()) {
|
|
163
|
+
return false;
|
|
164
|
+
}
|
|
165
|
+
// Step 2: Get chain-specific parameters
|
|
166
|
+
const forkVersion = getForkVersion(chainId);
|
|
167
|
+
// IMPORTANT: Per Ethereum spec, deposit signatures use ZERO genesis_validators_root
|
|
168
|
+
// "The sole exception to the mixing-in of the fork version is signatures on deposits"
|
|
169
|
+
// Reference: staking-deposit-cli uses ZERO_BYTES32 for deposits
|
|
170
|
+
const genesisValidatorsRoot = new Uint8Array(32); // All zeros
|
|
171
|
+
// Step 3: Compute domain
|
|
172
|
+
const domainType = hexToBytes(DOMAIN_DEPOSIT);
|
|
173
|
+
const domain = computeDomain(domainType, forkVersion, genesisValidatorsRoot);
|
|
174
|
+
// Step 4: Compute signing root
|
|
175
|
+
const signingRoot = computeSigningRoot(messageRoot, domain);
|
|
176
|
+
// Step 5: Verify BLS signature
|
|
177
|
+
const publicKey = new bls.PublicKey();
|
|
178
|
+
publicKey.deserialize(pubkey);
|
|
179
|
+
const sig = new bls.Signature();
|
|
180
|
+
sig.deserialize(signature);
|
|
181
|
+
return publicKey.verify(sig, signingRoot);
|
|
182
|
+
}
|
|
183
|
+
catch {
|
|
184
|
+
return false;
|
|
185
|
+
}
|
|
186
|
+
};
|
|
187
|
+
//# sourceMappingURL=signature.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/deposit-data-sdk/signature.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export var ValidationErrorCode;
|
|
2
|
+
(function (ValidationErrorCode) {
|
|
3
|
+
ValidationErrorCode["INVALID_PUBKEY"] = "INVALID_PUBKEY";
|
|
4
|
+
ValidationErrorCode["INVALID_SIGNATURE"] = "INVALID_SIGNATURE";
|
|
5
|
+
ValidationErrorCode["INVALID_WITHDRAWAL_CREDENTIALS"] = "INVALID_WITHDRAWAL_CREDENTIALS";
|
|
6
|
+
ValidationErrorCode["INVALID_AMOUNT"] = "INVALID_AMOUNT";
|
|
7
|
+
ValidationErrorCode["INVALID_NETWORK"] = "INVALID_NETWORK";
|
|
8
|
+
ValidationErrorCode["INVALID_FORK_VERSION"] = "INVALID_FORK_VERSION";
|
|
9
|
+
ValidationErrorCode["INVALID_DEPOSIT_ROOT"] = "INVALID_DEPOSIT_ROOT";
|
|
10
|
+
ValidationErrorCode["DUPLICATE_PUBKEY"] = "DUPLICATE_PUBKEY";
|
|
11
|
+
ValidationErrorCode["PREVIOUSLY_SUBMITTED"] = "PREVIOUSLY_SUBMITTED";
|
|
12
|
+
ValidationErrorCode["INVALID_BLS_SIGNATURE"] = "INVALID_BLS_SIGNATURE";
|
|
13
|
+
ValidationErrorCode["MISSING_FIELD"] = "MISSING_FIELD";
|
|
14
|
+
ValidationErrorCode["INVALID_FORMAT"] = "INVALID_FORMAT";
|
|
15
|
+
})(ValidationErrorCode || (ValidationErrorCode = {}));
|
|
16
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/deposit-data-sdk/types.ts"],"names":[],"mappings":"AAuBA,MAAM,CAAN,IAAY,mBAaX;AAbD,WAAY,mBAAmB;IAC7B,wDAAiC,CAAA;IACjC,8DAAuC,CAAA;IACvC,wFAAiE,CAAA;IACjE,wDAAiC,CAAA;IACjC,0DAAmC,CAAA;IACnC,oEAA6C,CAAA;IAC7C,oEAA6C,CAAA;IAC7C,4DAAqC,CAAA;IACrC,oEAA6C,CAAA;IAC7C,sEAA+C,CAAA;IAC/C,sDAA+B,CAAA;IAC/B,wDAAiC,CAAA;AACnC,CAAC,EAbW,mBAAmB,KAAnB,mBAAmB,QAa9B"}
|