@lodestar/state-transition 1.23.0-dev.105a38808f → 1.23.0-dev.10d15dce1f
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/lib/block/index.d.ts +3 -3
- package/lib/block/index.js +4 -4
- package/lib/block/index.js.map +1 -1
- package/lib/block/isValidIndexedAttestation.js +3 -7
- package/lib/block/isValidIndexedAttestation.js.map +1 -1
- package/lib/block/processAttestationPhase0.d.ts +2 -2
- package/lib/block/processAttestationPhase0.js +6 -10
- package/lib/block/processAttestationPhase0.js.map +1 -1
- package/lib/block/processAttestations.d.ts +1 -1
- package/lib/block/processAttestations.js.map +1 -1
- package/lib/block/processAttestationsAltair.d.ts +1 -1
- package/lib/block/processAttestationsAltair.js +1 -1
- package/lib/block/processAttestationsAltair.js.map +1 -1
- package/lib/block/processAttesterSlashing.d.ts +1 -1
- package/lib/block/processAttesterSlashing.js +2 -2
- package/lib/block/processAttesterSlashing.js.map +1 -1
- package/lib/block/processBlockHeader.js.map +1 -1
- package/lib/block/processBlsToExecutionChange.js +1 -1
- package/lib/block/processBlsToExecutionChange.js.map +1 -1
- package/lib/block/processConsolidationRequest.js +56 -10
- package/lib/block/processConsolidationRequest.js.map +1 -1
- package/lib/block/processDeposit.d.ts +5 -2
- package/lib/block/processDeposit.js +32 -36
- package/lib/block/processDeposit.js.map +1 -1
- package/lib/block/processDepositRequest.d.ts +1 -2
- package/lib/block/processDepositRequest.js +11 -3
- package/lib/block/processDepositRequest.js.map +1 -1
- package/lib/block/processEth1Data.js +1 -3
- package/lib/block/processEth1Data.js.map +1 -1
- package/lib/block/processExecutionPayload.d.ts +1 -1
- package/lib/block/processExecutionPayload.js +2 -2
- package/lib/block/processExecutionPayload.js.map +1 -1
- package/lib/block/processOperations.d.ts +5 -5
- package/lib/block/processOperations.js +5 -5
- package/lib/block/processOperations.js.map +1 -1
- package/lib/block/processProposerSlashing.d.ts +1 -1
- package/lib/block/processProposerSlashing.js +1 -1
- package/lib/block/processProposerSlashing.js.map +1 -1
- package/lib/block/processRandao.js +1 -1
- package/lib/block/processRandao.js.map +1 -1
- package/lib/block/processSyncCommittee.d.ts +1 -1
- package/lib/block/processSyncCommittee.js +3 -5
- package/lib/block/processSyncCommittee.js.map +1 -1
- package/lib/block/processVoluntaryExit.js +1 -1
- package/lib/block/processVoluntaryExit.js.map +1 -1
- package/lib/block/processWithdrawalRequest.d.ts +1 -1
- package/lib/block/processWithdrawalRequest.js +2 -2
- package/lib/block/processWithdrawalRequest.js.map +1 -1
- package/lib/block/processWithdrawals.d.ts +1 -1
- package/lib/block/processWithdrawals.js +4 -3
- package/lib/block/processWithdrawals.js.map +1 -1
- package/lib/block/slashValidator.d.ts +1 -1
- package/lib/block/slashValidator.js.map +1 -1
- package/lib/cache/epochCache.d.ts +7 -7
- package/lib/cache/epochCache.js +20 -26
- package/lib/cache/epochCache.js.map +1 -1
- package/lib/cache/epochTransitionCache.d.ts +1 -6
- package/lib/cache/epochTransitionCache.js +3 -5
- package/lib/cache/epochTransitionCache.js.map +1 -1
- package/lib/cache/pubkeyCache.d.ts +1 -1
- package/lib/cache/pubkeyCache.js.map +1 -1
- package/lib/cache/stateCache.d.ts +1 -1
- package/lib/cache/stateCache.js +2 -0
- package/lib/cache/stateCache.js.map +1 -1
- package/lib/cache/syncCommitteeCache.d.ts +2 -2
- package/lib/cache/types.d.ts +1 -1
- package/lib/constants/constants.d.ts +3 -4
- package/lib/constants/constants.js +4 -4
- package/lib/constants/constants.js.map +1 -1
- package/lib/epoch/computeUnrealizedCheckpoints.js +1 -1
- package/lib/epoch/computeUnrealizedCheckpoints.js.map +1 -1
- package/lib/epoch/getAttestationDeltas.d.ts +1 -1
- package/lib/epoch/getAttestationDeltas.js +2 -2
- package/lib/epoch/getAttestationDeltas.js.map +1 -1
- package/lib/epoch/getRewardsAndPenalties.js +1 -1
- package/lib/epoch/getRewardsAndPenalties.js.map +1 -1
- package/lib/epoch/index.d.ts +5 -5
- package/lib/epoch/index.js +6 -6
- package/lib/epoch/index.js.map +1 -1
- package/lib/epoch/processEffectiveBalanceUpdates.d.ts +1 -1
- package/lib/epoch/processEffectiveBalanceUpdates.js +4 -7
- package/lib/epoch/processEffectiveBalanceUpdates.js.map +1 -1
- package/lib/epoch/processEth1DataReset.d.ts +1 -1
- package/lib/epoch/processHistoricalRootsUpdate.d.ts +1 -1
- package/lib/epoch/processHistoricalSummariesUpdate.d.ts +1 -1
- package/lib/epoch/processJustificationAndFinalization.js.map +1 -1
- package/lib/epoch/processPendingConsolidations.js +7 -12
- package/lib/epoch/processPendingConsolidations.js.map +1 -1
- package/lib/epoch/{processPendingBalanceDeposits.d.ts → processPendingDeposits.d.ts} +4 -4
- package/lib/epoch/processPendingDeposits.js +102 -0
- package/lib/epoch/processPendingDeposits.js.map +1 -0
- package/lib/epoch/processRandaoMixesReset.d.ts +1 -1
- package/lib/epoch/processRegistryUpdates.d.ts +1 -1
- package/lib/epoch/processRegistryUpdates.js +1 -1
- package/lib/epoch/processRegistryUpdates.js.map +1 -1
- package/lib/epoch/processSlashings.js.map +1 -1
- package/lib/epoch/processSlashingsReset.d.ts +1 -1
- package/lib/epoch/processSyncCommitteeUpdates.js.map +1 -1
- package/lib/metrics.d.ts +2 -2
- package/lib/metrics.js +2 -0
- package/lib/metrics.js.map +1 -1
- package/lib/signatureSets/attesterSlashings.d.ts +2 -2
- package/lib/signatureSets/attesterSlashings.js +3 -5
- package/lib/signatureSets/attesterSlashings.js.map +1 -1
- package/lib/signatureSets/blsToExecutionChange.d.ts +2 -2
- package/lib/signatureSets/blsToExecutionChange.js +1 -1
- package/lib/signatureSets/blsToExecutionChange.js.map +1 -1
- package/lib/signatureSets/index.d.ts +1 -1
- package/lib/signatureSets/index.js +2 -2
- package/lib/signatureSets/index.js.map +1 -1
- package/lib/signatureSets/indexedAttestation.d.ts +1 -1
- package/lib/signatureSets/indexedAttestation.js.map +1 -1
- package/lib/signatureSets/proposer.d.ts +1 -1
- package/lib/signatureSets/proposer.js.map +1 -1
- package/lib/signatureSets/proposerSlashings.d.ts +1 -1
- package/lib/signatureSets/proposerSlashings.js +2 -4
- package/lib/signatureSets/proposerSlashings.js.map +1 -1
- package/lib/signatureSets/randao.d.ts +1 -1
- package/lib/signatureSets/randao.js +1 -1
- package/lib/signatureSets/randao.js.map +1 -1
- package/lib/signatureSets/voluntaryExits.d.ts +1 -1
- package/lib/signatureSets/voluntaryExits.js +1 -1
- package/lib/signatureSets/voluntaryExits.js.map +1 -1
- package/lib/slot/index.js.map +1 -1
- package/lib/slot/upgradeStateToAltair.d.ts +1 -1
- package/lib/slot/upgradeStateToAltair.js +5 -4
- package/lib/slot/upgradeStateToAltair.js.map +1 -1
- package/lib/slot/upgradeStateToBellatrix.js.map +1 -1
- package/lib/slot/upgradeStateToCapella.js +1 -0
- package/lib/slot/upgradeStateToCapella.js.map +1 -1
- package/lib/slot/upgradeStateToDeneb.js +1 -0
- package/lib/slot/upgradeStateToDeneb.js.map +1 -1
- package/lib/slot/upgradeStateToElectra.d.ts +1 -2
- package/lib/slot/upgradeStateToElectra.js +19 -36
- package/lib/slot/upgradeStateToElectra.js.map +1 -1
- package/lib/stateTransition.d.ts +3 -3
- package/lib/stateTransition.js +6 -6
- package/lib/stateTransition.js.map +1 -1
- package/lib/util/aggregator.js +2 -2
- package/lib/util/aggregator.js.map +1 -1
- package/lib/util/attestation.d.ts +1 -1
- package/lib/util/attestation.js.map +1 -1
- package/lib/util/blindedBlock.d.ts +1 -1
- package/lib/util/blindedBlock.js +5 -9
- package/lib/util/blindedBlock.js.map +1 -1
- package/lib/util/blockRoot.d.ts +1 -1
- package/lib/util/blockRoot.js.map +1 -1
- package/lib/util/calculateCommitteeAssignments.js.map +1 -1
- package/lib/util/computeAnchorCheckpoint.js +1 -1
- package/lib/util/computeAnchorCheckpoint.js.map +1 -1
- package/lib/util/deposit.js +2 -6
- package/lib/util/deposit.js.map +1 -1
- package/lib/util/domain.d.ts +1 -1
- package/lib/util/electra.d.ts +0 -1
- package/lib/util/electra.js +19 -27
- package/lib/util/electra.js.map +1 -1
- package/lib/util/epoch.d.ts +1 -1
- package/lib/util/epochShuffling.d.ts +2 -1
- package/lib/util/epochShuffling.js +33 -14
- package/lib/util/epochShuffling.js.map +1 -1
- package/lib/util/execution.d.ts +2 -2
- package/lib/util/execution.js +6 -10
- package/lib/util/execution.js.map +1 -1
- package/lib/util/genesis.d.ts +2 -2
- package/lib/util/genesis.js +12 -7
- package/lib/util/genesis.js.map +1 -1
- package/lib/util/index.d.ts +0 -1
- package/lib/util/index.js +0 -1
- package/lib/util/index.js.map +1 -1
- package/lib/util/interop.js +1 -1
- package/lib/util/interop.js.map +1 -1
- package/lib/util/loadState/loadState.js +2 -2
- package/lib/util/loadState/loadState.js.map +1 -1
- package/lib/util/loadState/loadValidator.js +1 -3
- package/lib/util/loadState/loadValidator.js.map +1 -1
- package/lib/util/rootCache.d.ts +1 -1
- package/lib/util/seed.d.ts +2 -2
- package/lib/util/seed.js +1 -1
- package/lib/util/seed.js.map +1 -1
- package/lib/util/shufflingDecisionRoot.js +5 -11
- package/lib/util/shufflingDecisionRoot.js.map +1 -1
- package/lib/util/slot.d.ts +1 -1
- package/lib/util/slot.js +1 -1
- package/lib/util/slot.js.map +1 -1
- package/lib/util/syncCommittee.d.ts +2 -2
- package/lib/util/validator.d.ts +1 -2
- package/lib/util/validator.js +3 -11
- package/lib/util/validator.js.map +1 -1
- package/lib/util/weakSubjectivity.js +1 -1
- package/lib/util/weakSubjectivity.js.map +1 -1
- package/package.json +9 -8
- package/lib/epoch/processPendingBalanceDeposits.js +0 -68
- package/lib/epoch/processPendingBalanceDeposits.js.map +0 -1
- package/lib/util/shuffle.d.ts +0 -9
- package/lib/util/shuffle.js +0 -196
- package/lib/util/shuffle.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processJustificationAndFinalization.js","sourceRoot":"","sources":["../../src/epoch/processJustificationAndFinalization.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"processJustificationAndFinalization.js","sourceRoot":"","sources":["../../src/epoch/processJustificationAndFinalization.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { decreaseBalance, increaseBalance } from "../util/balance.js";
|
|
2
|
-
import {
|
|
3
|
-
import { switchToCompoundingValidator } from "../util/electra.js";
|
|
2
|
+
import { getMaxEffectiveBalance } from "../util/validator.js";
|
|
4
3
|
/**
|
|
5
4
|
* Starting from Electra:
|
|
6
5
|
* Process every `pendingConsolidation` in `state.pendingConsolidations`.
|
|
@@ -19,7 +18,6 @@ export function processPendingConsolidations(state, cache) {
|
|
|
19
18
|
let nextPendingConsolidation = 0;
|
|
20
19
|
const validators = state.validators;
|
|
21
20
|
const cachedBalances = cache.balances;
|
|
22
|
-
const newCompoundingValidators = new Set();
|
|
23
21
|
for (const pendingConsolidation of state.pendingConsolidations.getAllReadonly()) {
|
|
24
22
|
const { sourceIndex, targetIndex } = pendingConsolidation;
|
|
25
23
|
const sourceValidator = validators.getReadonly(sourceIndex);
|
|
@@ -30,20 +28,17 @@ export function processPendingConsolidations(state, cache) {
|
|
|
30
28
|
if (sourceValidator.withdrawableEpoch > nextEpoch) {
|
|
31
29
|
break;
|
|
32
30
|
}
|
|
33
|
-
// Churn any target excess active balance of target and raise its max
|
|
34
|
-
switchToCompoundingValidator(state, targetIndex);
|
|
35
|
-
newCompoundingValidators.add(targetIndex);
|
|
36
31
|
// Move active balance to target. Excess balance is withdrawable.
|
|
37
|
-
const
|
|
38
|
-
|
|
39
|
-
|
|
32
|
+
const maxEffectiveBalance = getMaxEffectiveBalance(state.validators.getReadonly(sourceIndex).withdrawalCredentials);
|
|
33
|
+
const sourceEffectiveBalance = Math.min(state.balances.get(sourceIndex), maxEffectiveBalance);
|
|
34
|
+
decreaseBalance(state, sourceIndex, sourceEffectiveBalance);
|
|
35
|
+
increaseBalance(state, targetIndex, sourceEffectiveBalance);
|
|
40
36
|
if (cachedBalances) {
|
|
41
|
-
cachedBalances[sourceIndex] -=
|
|
42
|
-
cachedBalances[targetIndex] +=
|
|
37
|
+
cachedBalances[sourceIndex] -= sourceEffectiveBalance;
|
|
38
|
+
cachedBalances[targetIndex] += sourceEffectiveBalance;
|
|
43
39
|
}
|
|
44
40
|
nextPendingConsolidation++;
|
|
45
41
|
}
|
|
46
|
-
cache.newCompoundingValidators = newCompoundingValidators;
|
|
47
42
|
state.pendingConsolidations = state.pendingConsolidations.sliceFrom(nextPendingConsolidation);
|
|
48
43
|
}
|
|
49
44
|
//# sourceMappingURL=processPendingConsolidations.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processPendingConsolidations.js","sourceRoot":"","sources":["../../src/epoch/processPendingConsolidations.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"processPendingConsolidations.js","sourceRoot":"","sources":["../../src/epoch/processPendingConsolidations.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,eAAe,EAAE,eAAe,EAAC,MAAM,oBAAoB,CAAC;AACpE,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;AAE5D;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,4BAA4B,CAAC,KAA+B,EAAE,KAA2B;IACvG,MAAM,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC;IAC3C,IAAI,wBAAwB,GAAG,CAAC,CAAC;IACjC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;IACpC,MAAM,cAAc,GAAG,KAAK,CAAC,QAAQ,CAAC;IAEtC,KAAK,MAAM,oBAAoB,IAAI,KAAK,CAAC,qBAAqB,CAAC,cAAc,EAAE,EAAE,CAAC;QAChF,MAAM,EAAC,WAAW,EAAE,WAAW,EAAC,GAAG,oBAAoB,CAAC;QACxD,MAAM,eAAe,GAAG,UAAU,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAE5D,IAAI,eAAe,CAAC,OAAO,EAAE,CAAC;YAC5B,wBAAwB,EAAE,CAAC;YAC3B,SAAS;QACX,CAAC;QAED,IAAI,eAAe,CAAC,iBAAiB,GAAG,SAAS,EAAE,CAAC;YAClD,MAAM;QACR,CAAC;QACD,iEAAiE;QACjE,MAAM,mBAAmB,GAAG,sBAAsB,CAAC,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,qBAAqB,CAAC,CAAC;QACpH,MAAM,sBAAsB,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,mBAAmB,CAAC,CAAC;QAC9F,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,sBAAsB,CAAC,CAAC;QAC5D,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,sBAAsB,CAAC,CAAC;QAC5D,IAAI,cAAc,EAAE,CAAC;YACnB,cAAc,CAAC,WAAW,CAAC,IAAI,sBAAsB,CAAC;YACtD,cAAc,CAAC,WAAW,CAAC,IAAI,sBAAsB,CAAC;QACxD,CAAC;QAED,wBAAwB,EAAE,CAAC;IAC7B,CAAC;IAED,KAAK,CAAC,qBAAqB,GAAG,KAAK,CAAC,qBAAqB,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC;AAChG,CAAC"}
|
|
@@ -3,10 +3,10 @@ import { CachedBeaconStateElectra, EpochTransitionCache } from "../types.js";
|
|
|
3
3
|
* Starting from Electra:
|
|
4
4
|
* Process pending balance deposits from state subject to churn limit and depsoitBalanceToConsume.
|
|
5
5
|
* For each eligible `deposit`, call `increaseBalance()`.
|
|
6
|
-
* Remove the processed deposits from `state.
|
|
6
|
+
* Remove the processed deposits from `state.pendingDeposits`.
|
|
7
7
|
* Update `state.depositBalanceToConsume` for the next epoch
|
|
8
8
|
*
|
|
9
|
-
* TODO Electra: Update ssz library to support batch push to `
|
|
9
|
+
* TODO Electra: Update ssz library to support batch push to `pendingDeposits`
|
|
10
10
|
*/
|
|
11
|
-
export declare function
|
|
12
|
-
//# sourceMappingURL=
|
|
11
|
+
export declare function processPendingDeposits(state: CachedBeaconStateElectra, cache: EpochTransitionCache): void;
|
|
12
|
+
//# sourceMappingURL=processPendingDeposits.d.ts.map
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { FAR_FUTURE_EPOCH, ForkSeq, GENESIS_SLOT, MAX_PENDING_DEPOSITS_PER_EPOCH } from "@lodestar/params";
|
|
2
|
+
import { addValidatorToRegistry, isValidDepositSignature } from "../block/processDeposit.js";
|
|
3
|
+
import { increaseBalance } from "../util/balance.js";
|
|
4
|
+
import { computeStartSlotAtEpoch } from "../util/epoch.js";
|
|
5
|
+
import { getActivationExitChurnLimit } from "../util/validator.js";
|
|
6
|
+
/**
|
|
7
|
+
* Starting from Electra:
|
|
8
|
+
* Process pending balance deposits from state subject to churn limit and depsoitBalanceToConsume.
|
|
9
|
+
* For each eligible `deposit`, call `increaseBalance()`.
|
|
10
|
+
* Remove the processed deposits from `state.pendingDeposits`.
|
|
11
|
+
* Update `state.depositBalanceToConsume` for the next epoch
|
|
12
|
+
*
|
|
13
|
+
* TODO Electra: Update ssz library to support batch push to `pendingDeposits`
|
|
14
|
+
*/
|
|
15
|
+
export function processPendingDeposits(state, cache) {
|
|
16
|
+
const nextEpoch = state.epochCtx.epoch + 1;
|
|
17
|
+
const availableForProcessing = state.depositBalanceToConsume + BigInt(getActivationExitChurnLimit(state.epochCtx));
|
|
18
|
+
let processedAmount = 0;
|
|
19
|
+
let nextDepositIndex = 0;
|
|
20
|
+
const depositsToPostpone = [];
|
|
21
|
+
let isChurnLimitReached = false;
|
|
22
|
+
const finalizedSlot = computeStartSlotAtEpoch(state.finalizedCheckpoint.epoch);
|
|
23
|
+
for (const deposit of state.pendingDeposits.getAllReadonly()) {
|
|
24
|
+
// Do not process deposit requests if Eth1 bridge deposits are not yet applied.
|
|
25
|
+
if (
|
|
26
|
+
// Is deposit request
|
|
27
|
+
deposit.slot > GENESIS_SLOT &&
|
|
28
|
+
// There are pending Eth1 bridge deposits
|
|
29
|
+
state.eth1DepositIndex < state.depositRequestsStartIndex) {
|
|
30
|
+
break;
|
|
31
|
+
}
|
|
32
|
+
// Check if deposit has been finalized, otherwise, stop processing.
|
|
33
|
+
if (deposit.slot > finalizedSlot) {
|
|
34
|
+
break;
|
|
35
|
+
}
|
|
36
|
+
// Check if number of processed deposits has not reached the limit, otherwise, stop processing.
|
|
37
|
+
if (nextDepositIndex >= MAX_PENDING_DEPOSITS_PER_EPOCH) {
|
|
38
|
+
break;
|
|
39
|
+
}
|
|
40
|
+
// Read validator state
|
|
41
|
+
let isValidatorExited = false;
|
|
42
|
+
let isValidatorWithdrawn = false;
|
|
43
|
+
const validatorIndex = state.epochCtx.getValidatorIndex(deposit.pubkey);
|
|
44
|
+
if (validatorIndex !== null) {
|
|
45
|
+
const validator = state.validators.getReadonly(validatorIndex);
|
|
46
|
+
isValidatorExited = validator.exitEpoch < FAR_FUTURE_EPOCH;
|
|
47
|
+
isValidatorWithdrawn = validator.withdrawableEpoch < nextEpoch;
|
|
48
|
+
}
|
|
49
|
+
if (isValidatorWithdrawn) {
|
|
50
|
+
// Deposited balance will never become active. Increase balance but do not consume churn
|
|
51
|
+
applyPendingDeposit(state, deposit, cache);
|
|
52
|
+
}
|
|
53
|
+
else if (isValidatorExited) {
|
|
54
|
+
// Validator is exiting, postpone the deposit until after withdrawable epoch
|
|
55
|
+
depositsToPostpone.push(deposit);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
// Check if deposit fits in the churn, otherwise, do no more deposit processing in this epoch.
|
|
59
|
+
isChurnLimitReached = processedAmount + deposit.amount > availableForProcessing;
|
|
60
|
+
if (isChurnLimitReached) {
|
|
61
|
+
break;
|
|
62
|
+
}
|
|
63
|
+
// Consume churn and apply deposit.
|
|
64
|
+
processedAmount += deposit.amount;
|
|
65
|
+
applyPendingDeposit(state, deposit, cache);
|
|
66
|
+
}
|
|
67
|
+
// Regardless of how the deposit was handled, we move on in the queue.
|
|
68
|
+
nextDepositIndex++;
|
|
69
|
+
}
|
|
70
|
+
const remainingPendingDeposits = state.pendingDeposits.sliceFrom(nextDepositIndex);
|
|
71
|
+
state.pendingDeposits = remainingPendingDeposits;
|
|
72
|
+
// TODO Electra: add a function in ListCompositeTreeView to support batch push operation
|
|
73
|
+
for (const deposit of depositsToPostpone) {
|
|
74
|
+
state.pendingDeposits.push(deposit);
|
|
75
|
+
}
|
|
76
|
+
// Accumulate churn only if the churn limit has been hit.
|
|
77
|
+
if (isChurnLimitReached) {
|
|
78
|
+
state.depositBalanceToConsume = availableForProcessing - BigInt(processedAmount);
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
state.depositBalanceToConsume = 0n;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
function applyPendingDeposit(state, deposit, cache) {
|
|
85
|
+
const validatorIndex = state.epochCtx.getValidatorIndex(deposit.pubkey);
|
|
86
|
+
const { pubkey, withdrawalCredentials, amount, signature } = deposit;
|
|
87
|
+
const cachedBalances = cache.balances;
|
|
88
|
+
if (validatorIndex === null) {
|
|
89
|
+
// Verify the deposit signature (proof of possession) which is not checked by the deposit contract
|
|
90
|
+
if (isValidDepositSignature(state.config, pubkey, withdrawalCredentials, amount, signature)) {
|
|
91
|
+
addValidatorToRegistry(ForkSeq.electra, state, pubkey, withdrawalCredentials, amount);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
// Increase balance
|
|
96
|
+
increaseBalance(state, validatorIndex, amount);
|
|
97
|
+
if (cachedBalances) {
|
|
98
|
+
cachedBalances[validatorIndex] += amount;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=processPendingDeposits.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processPendingDeposits.js","sourceRoot":"","sources":["../../src/epoch/processPendingDeposits.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ForkSeq } from "@lodestar/params";
|
|
2
|
-
import {
|
|
2
|
+
import { CachedBeaconStateAllForks, EpochTransitionCache } from "../types.js";
|
|
3
3
|
/**
|
|
4
4
|
* Update validator registry for validators that activate + exit
|
|
5
5
|
*
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ForkSeq } from "@lodestar/params";
|
|
2
|
-
import { computeActivationExitEpoch } from "../util/index.js";
|
|
3
2
|
import { initiateValidatorExit } from "../block/index.js";
|
|
3
|
+
import { computeActivationExitEpoch } from "../util/index.js";
|
|
4
4
|
/**
|
|
5
5
|
* Update validator registry for validators that activate + exit
|
|
6
6
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processRegistryUpdates.js","sourceRoot":"","sources":["../../src/epoch/processRegistryUpdates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAC,
|
|
1
|
+
{"version":3,"file":"processRegistryUpdates.js","sourceRoot":"","sources":["../../src/epoch/processRegistryUpdates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,kBAAkB,CAAC;AACzC,OAAO,EAAC,qBAAqB,EAAC,MAAM,mBAAmB,CAAC;AAExD,OAAO,EAAC,0BAA0B,EAAC,MAAM,kBAAkB,CAAC;AAE5D;;;;;;;;;;;;;GAaG;AACH,MAAM,UAAU,sBAAsB,CACpC,IAAa,EACb,KAAgC,EAChC,KAA2B;IAE3B,MAAM,EAAC,QAAQ,EAAC,GAAG,KAAK,CAAC;IAEzB,oDAAoD;IACpD,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;IAEpC,mFAAmF;IAEnF,oBAAoB;IACpB,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,cAAc,EAAE,CAAC;QACzC,kDAAkD;QAClD,0EAA0E;QAC1E,qBAAqB,CAAC,IAAI,EAAE,KAAK,EAAE,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,mCAAmC;IACnC,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,iCAAiC,EAAE,CAAC;QAC5D,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,0BAA0B,GAAG,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC;IACxE,CAAC;IAED,MAAM,aAAa,GAAG,KAAK,CAAC,mBAAmB,CAAC,KAAK,CAAC;IACtD,wFAAwF;IACxF,MAAM,GAAG,GACP,IAAI,GAAG,OAAO,CAAC,OAAO;QACpB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,4BAA4B,CAAC,MAAM,EAAE,QAAQ,CAAC,oBAAoB,CAAC;QACpF,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,MAAM,CAAC;IAChD,MAAM,eAAe,GAAG,0BAA0B,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IACvE,sDAAsD;IACtD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;QAC7B,MAAM,cAAc,GAAG,KAAK,CAAC,4BAA4B,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACjD,kCAAkC;QAClC,IAAI,SAAS,CAAC,0BAA0B,GAAG,aAAa,EAAE,CAAC;YACzD,iGAAiG;YACjG,kFAAkF;YAClF,iHAAiH;YACjH,sEAAsE;YACtE,MAAM;QACR,CAAC;QACD,SAAS,CAAC,eAAe,GAAG,eAAe,CAAC;IAC9C,CAAC;AACH,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processSlashings.js","sourceRoot":"","sources":["../../src/epoch/processSlashings.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,2BAA2B,EAC3B,OAAO,EACP,gCAAgC,EAChC,uCAAuC,EACvC,0CAA0C,GAC3C,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"processSlashings.js","sourceRoot":"","sources":["../../src/epoch/processSlashings.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"processSyncCommitteeUpdates.js","sourceRoot":"","sources":["../../src/epoch/processSyncCommitteeUpdates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,6BAA6B,EAAC,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAC,gCAAgC,EAAU,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAC,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"processSyncCommitteeUpdates.js","sourceRoot":"","sources":["../../src/epoch/processSyncCommitteeUpdates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,6BAA6B,EAAC,MAAM,iBAAiB,CAAC;AAC9D,OAAO,EAAC,gCAAgC,EAAU,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAC,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAEpC,OAAO,EAAC,2BAA2B,EAAC,MAAM,iBAAiB,CAAC;AAE5D;;;;;GAKG;AACH,MAAM,UAAU,2BAA2B,CAAC,IAAa,EAAE,KAA8B;IACvF,MAAM,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,GAAG,CAAC,CAAC;IAE3C,IAAI,SAAS,GAAG,gCAAgC,KAAK,CAAC,EAAE,CAAC;QACvD,MAAM,sBAAsB,GAAG,KAAK,CAAC,QAAQ,CAAC,iBAAiB,CAAC;QAChE,MAAM,EAAC,0BAA0B,EAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;QAEpD,MAAM,wBAAwB,GAAG,2BAA2B,CAC1D,IAAI,EACJ,KAAK,EACL,sBAAsB,EACtB,0BAA0B,CAC3B,CAAC;QACF,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;QAEpC,iFAAiF;QACjF,MAAM,wBAAwB,GAAG,wBAAwB,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC;QAE/G,gCAAgC;QAChC,KAAK,CAAC,oBAAoB,GAAG,KAAK,CAAC,iBAAiB,CAAC;QACrD,KAAK,CAAC,iBAAiB,GAAG,GAAG,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC;YAC1D,OAAO,EAAE,wBAAwB;YACjC,eAAe,EAAE,6BAA6B,CAAC,wBAAwB,CAAC,CAAC,OAAO,EAAE;SACnF,CAAC,CAAC;QAEH,6BAA6B;QAC7B,KAAK,CAAC,QAAQ,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC;IACtE,CAAC;AACH,CAAC"}
|
package/lib/metrics.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Epoch } from "@lodestar/types";
|
|
2
2
|
import { Gauge, Histogram } from "@lodestar/utils";
|
|
3
|
-
import { CachedBeaconStateAllForks } from "./types.js";
|
|
4
|
-
import { StateCloneSource, StateHashTreeRootSource } from "./stateTransition.js";
|
|
5
3
|
import { EpochTransitionStep } from "./epoch/index.js";
|
|
4
|
+
import { StateCloneSource, StateHashTreeRootSource } from "./stateTransition.js";
|
|
5
|
+
import { CachedBeaconStateAllForks } from "./types.js";
|
|
6
6
|
export type BeaconStateTransitionMetrics = {
|
|
7
7
|
epochTransitionTime: Histogram;
|
|
8
8
|
epochTransitionCommitTime: Histogram;
|
package/lib/metrics.js
CHANGED
|
@@ -31,9 +31,11 @@ export function onPostStateMetrics(postState, metrics) {
|
|
|
31
31
|
// This cache is populated during epoch transition, and should be preserved for performance.
|
|
32
32
|
// If the cache is missing too often, means that our clone strategy is not working well.
|
|
33
33
|
function isValidatorsNodesPopulated(state) {
|
|
34
|
+
// biome-ignore lint/complexity/useLiteralKeys: It is a private attribute
|
|
34
35
|
return state.validators["nodesPopulated"] === true;
|
|
35
36
|
}
|
|
36
37
|
function isBalancesNodesPopulated(state) {
|
|
38
|
+
// biome-ignore lint/complexity/useLiteralKeys: It is a private attribute
|
|
37
39
|
return state.balances["nodesPopulated"] === true;
|
|
38
40
|
}
|
|
39
41
|
//# sourceMappingURL=metrics.js.map
|
package/lib/metrics.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../src/metrics.ts"],"names":[],"mappings":"AAsCA,MAAM,UAAU,mBAAmB,CACjC,KAAgC,EAChC,OAAqC,EACrC,MAAwB;IAExB,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IAEvD,IAAI,wBAAwB,CAAC,KAAK,CAAC,EAAE,CAAC;QACpC,OAAO,CAAC,iCAAiC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC1D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,kCAAkC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC3D,CAAC;IAED,IAAI,0BAA0B,CAAC,KAAK,CAAC,EAAE,CAAC;QACtC,OAAO,CAAC,mCAAmC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC5D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,oCAAoC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC7D,CAAC;AACH,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,SAAoC,EAAE,OAAqC;IAC5G,IAAI,wBAAwB,CAAC,SAAS,CAAC,EAAE,CAAC;QACxC,OAAO,CAAC,kCAAkC,CAAC,GAAG,EAAE,CAAC;IACnD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,mCAAmC,CAAC,GAAG,EAAE,CAAC;IACpD,CAAC;IAED,IAAI,0BAA0B,CAAC,SAAS,CAAC,EAAE,CAAC;QAC1C,OAAO,CAAC,oCAAoC,CAAC,GAAG,EAAE,CAAC;IACrD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,qCAAqC,CAAC,GAAG,EAAE,CAAC;IACtD,CAAC;AACH,CAAC;AAED,oFAAoF;AACpF,4FAA4F;AAC5F,wFAAwF;AACxF,SAAS,0BAA0B,CAAC,KAAgC;IAClE,OAAO,KAAK,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;AACrD,CAAC;AAED,SAAS,wBAAwB,CAAC,KAAgC;IAChE,OAAO,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;AACnD,CAAC"}
|
|
1
|
+
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../src/metrics.ts"],"names":[],"mappings":"AAsCA,MAAM,UAAU,mBAAmB,CACjC,KAAgC,EAChC,OAAqC,EACrC,MAAwB;IAExB,OAAO,CAAC,mBAAmB,CAAC,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IAEvD,IAAI,wBAAwB,CAAC,KAAK,CAAC,EAAE,CAAC;QACpC,OAAO,CAAC,iCAAiC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC1D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,kCAAkC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC3D,CAAC;IAED,IAAI,0BAA0B,CAAC,KAAK,CAAC,EAAE,CAAC;QACtC,OAAO,CAAC,mCAAmC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC5D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,oCAAoC,CAAC,GAAG,CAAC,EAAC,MAAM,EAAC,CAAC,CAAC;IAC7D,CAAC;AACH,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,SAAoC,EAAE,OAAqC;IAC5G,IAAI,wBAAwB,CAAC,SAAS,CAAC,EAAE,CAAC;QACxC,OAAO,CAAC,kCAAkC,CAAC,GAAG,EAAE,CAAC;IACnD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,mCAAmC,CAAC,GAAG,EAAE,CAAC;IACpD,CAAC;IAED,IAAI,0BAA0B,CAAC,SAAS,CAAC,EAAE,CAAC;QAC1C,OAAO,CAAC,oCAAoC,CAAC,GAAG,EAAE,CAAC;IACrD,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,qCAAqC,CAAC,GAAG,EAAE,CAAC;IACtD,CAAC;AACH,CAAC;AAED,oFAAoF;AACpF,4FAA4F;AAC5F,wFAAwF;AACxF,SAAS,0BAA0B,CAAC,KAAgC;IAClE,yEAAyE;IACzE,OAAO,KAAK,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;AACrD,CAAC;AAED,SAAS,wBAAwB,CAAC,KAAgC;IAChE,yEAAyE;IACzE,OAAO,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAC;AACnD,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ISignatureSet } from "../util/index.js";
|
|
1
|
+
import { AttesterSlashing, IndexedAttestationBigint, SignedBeaconBlock } from "@lodestar/types";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/index.js";
|
|
4
4
|
/** Get signature sets from all AttesterSlashing objects in a block */
|
|
5
5
|
export declare function getAttesterSlashingsSignatureSets(state: CachedBeaconStateAllForks, signedBlock: SignedBeaconBlock): ISignatureSet[];
|
|
6
6
|
/** Get signature sets from a single AttesterSlashing object */
|
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
import { ssz } from "@lodestar/types";
|
|
2
1
|
import { DOMAIN_BEACON_ATTESTER } from "@lodestar/params";
|
|
3
|
-
import {
|
|
2
|
+
import { ssz } from "@lodestar/types";
|
|
3
|
+
import { SignatureSetType, computeSigningRoot, computeStartSlotAtEpoch } from "../util/index.js";
|
|
4
4
|
/** Get signature sets from all AttesterSlashing objects in a block */
|
|
5
5
|
export function getAttesterSlashingsSignatureSets(state, signedBlock) {
|
|
6
|
-
return signedBlock.message.body.attesterSlashings
|
|
7
|
-
.map((attesterSlashing) => getAttesterSlashingSignatureSets(state, attesterSlashing))
|
|
8
|
-
.flat(1);
|
|
6
|
+
return signedBlock.message.body.attesterSlashings.flatMap((attesterSlashing) => getAttesterSlashingSignatureSets(state, attesterSlashing));
|
|
9
7
|
}
|
|
10
8
|
/** Get signature sets from a single AttesterSlashing object */
|
|
11
9
|
export function getAttesterSlashingSignatureSets(state, attesterSlashing) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"attesterSlashings.js","sourceRoot":"","sources":["../../src/signatureSets/attesterSlashings.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"attesterSlashings.js","sourceRoot":"","sources":["../../src/signatureSets/attesterSlashings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAgE,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAEnG,OAAO,EAAgB,gBAAgB,EAAE,kBAAkB,EAAE,uBAAuB,EAAC,MAAM,kBAAkB,CAAC;AAE9G,sEAAsE;AACtE,MAAM,UAAU,iCAAiC,CAC/C,KAAgC,EAChC,WAA8B;IAE9B,OAAO,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,gBAAgB,EAAE,EAAE,CAC7E,gCAAgC,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAC1D,CAAC;AACJ,CAAC;AAED,+DAA+D;AAC/D,MAAM,UAAU,gCAAgC,CAC9C,KAAgC,EAChC,gBAAkC;IAElC,OAAO,CAAC,gBAAgB,CAAC,YAAY,EAAE,gBAAgB,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CACxF,uCAAuC,CAAC,KAAK,EAAE,WAAW,CAAC,CAC5D,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,uCAAuC,CACrD,KAAgC,EAChC,kBAA4C;IAE5C,MAAM,IAAI,GAAG,uBAAuB,CAAC,MAAM,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,KAAe,CAAC,CAAC,CAAC;IAC7F,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,sBAAsB,EAAE,IAAI,CAAC,CAAC;IAEhF,OAAO;QACL,IAAI,EAAE,gBAAgB,CAAC,SAAS;QAChC,OAAO,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QACvF,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,qBAAqB,EAAE,kBAAkB,CAAC,IAAI,EAAE,MAAM,CAAC;QAClG,SAAS,EAAE,kBAAkB,CAAC,SAAS;KACxC,CAAC;AACJ,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { capella } from "@lodestar/types";
|
|
2
1
|
import { BeaconConfig } from "@lodestar/config";
|
|
3
|
-
import {
|
|
2
|
+
import { capella } from "@lodestar/types";
|
|
4
3
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
4
|
+
import { ISignatureSet } from "../util/index.js";
|
|
5
5
|
export declare function verifyBlsToExecutionChangeSignature(state: CachedBeaconStateAllForks, signedBLSToExecutionChange: capella.SignedBLSToExecutionChange): boolean;
|
|
6
6
|
/**
|
|
7
7
|
* Extract signatures to allow validating all block signatures at once
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { PublicKey } from "@chainsafe/blst";
|
|
2
2
|
import { DOMAIN_BLS_TO_EXECUTION_CHANGE, ForkName } from "@lodestar/params";
|
|
3
3
|
import { ssz } from "@lodestar/types";
|
|
4
|
-
import {
|
|
4
|
+
import { SignatureSetType, computeSigningRoot, verifySignatureSet } from "../util/index.js";
|
|
5
5
|
export function verifyBlsToExecutionChangeSignature(state, signedBLSToExecutionChange) {
|
|
6
6
|
return verifySignatureSet(getBlsToExecutionChangeSignatureSet(state.config, signedBLSToExecutionChange));
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"blsToExecutionChange.js","sourceRoot":"","sources":["../../src/signatureSets/blsToExecutionChange.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"blsToExecutionChange.js","sourceRoot":"","sources":["../../src/signatureSets/blsToExecutionChange.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;AAE1C,OAAO,EAAC,8BAA8B,EAAE,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAU,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAG7C,OAAO,EAAgB,gBAAgB,EAAE,kBAAkB,EAAE,kBAAkB,EAAC,MAAM,kBAAkB,CAAC;AAEzG,MAAM,UAAU,mCAAmC,CACjD,KAAgC,EAChC,0BAA8D;IAE9D,OAAO,kBAAkB,CAAC,mCAAmC,CAAC,KAAK,CAAC,MAAM,EAAE,0BAA0B,CAAC,CAAC,CAAC;AAC3G,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mCAAmC,CACjD,MAAoB,EACpB,0BAA8D;IAE9D,4CAA4C;IAC5C,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC;IACtC,MAAM,MAAM,GAAG,MAAM,CAAC,eAAe,CAAC,aAAa,EAAE,8BAA8B,CAAC,CAAC;IAErF,OAAO;QACL,IAAI,EAAE,gBAAgB,CAAC,MAAM;QAC7B,+FAA+F;QAC/F,yDAAyD;QACzD,MAAM,EAAE,SAAS,CAAC,SAAS,CAAC,0BAA0B,CAAC,OAAO,CAAC,aAAa,EAAE,IAAI,CAAC;QACnF,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,oBAAoB,EAAE,0BAA0B,CAAC,OAAO,EAAE,MAAM,CAAC;QAC7G,SAAS,EAAE,0BAA0B,CAAC,SAAS;KAChD,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,oCAAoC,CAClD,MAAoB,EACpB,WAAsC;IAEtC,OAAO,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,oBAAoB,EAAE,EAAE,CACjF,mCAAmC,CAAC,MAAM,EAAE,oBAAoB,CAAC,CAClE,CAAC;AACJ,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { SignedBeaconBlock } from "@lodestar/types";
|
|
2
|
-
import { ISignatureSet } from "../util/index.js";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/index.js";
|
|
4
4
|
export * from "./attesterSlashings.js";
|
|
5
5
|
export * from "./indexedAttestation.js";
|
|
6
6
|
export * from "./proposer.js";
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { ForkSeq } from "@lodestar/params";
|
|
2
2
|
import { getSyncCommitteeSignatureSet } from "../block/processSyncCommittee.js";
|
|
3
|
-
import { getProposerSlashingsSignatureSets } from "./proposerSlashings.js";
|
|
4
3
|
import { getAttesterSlashingsSignatureSets } from "./attesterSlashings.js";
|
|
4
|
+
import { getBlsToExecutionChangeSignatureSets } from "./blsToExecutionChange.js";
|
|
5
5
|
import { getAttestationsSignatureSets } from "./indexedAttestation.js";
|
|
6
6
|
import { getBlockProposerSignatureSet } from "./proposer.js";
|
|
7
|
+
import { getProposerSlashingsSignatureSets } from "./proposerSlashings.js";
|
|
7
8
|
import { getRandaoRevealSignatureSet } from "./randao.js";
|
|
8
9
|
import { getVoluntaryExitsSignatureSets } from "./voluntaryExits.js";
|
|
9
|
-
import { getBlsToExecutionChangeSignatureSets } from "./blsToExecutionChange.js";
|
|
10
10
|
export * from "./attesterSlashings.js";
|
|
11
11
|
export * from "./indexedAttestation.js";
|
|
12
12
|
export * from "./proposer.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/signatureSets/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/signatureSets/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,kBAAkB,CAAC;AAEzC,OAAO,EAAC,4BAA4B,EAAC,MAAM,kCAAkC,CAAC;AAG9E,OAAO,EAAC,iCAAiC,EAAC,MAAM,wBAAwB,CAAC;AACzE,OAAO,EAAC,oCAAoC,EAAC,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAC,4BAA4B,EAAC,MAAM,yBAAyB,CAAC;AACrE,OAAO,EAAC,4BAA4B,EAAC,MAAM,eAAe,CAAC;AAC3D,OAAO,EAAC,iCAAiC,EAAC,MAAM,wBAAwB,CAAC;AACzE,OAAO,EAAC,2BAA2B,EAAC,MAAM,aAAa,CAAC;AACxD,OAAO,EAAC,8BAA8B,EAAC,MAAM,qBAAqB,CAAC;AAEnE,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC;AACxC,cAAc,eAAe,CAAC;AAC9B,cAAc,wBAAwB,CAAC;AACvC,cAAc,aAAa,CAAC;AAC5B,cAAc,qBAAqB,CAAC;AACpC,cAAc,2BAA2B,CAAC;AAE1C;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CACnC,KAAgC,EAChC,WAA8B,EAC9B,IAGC;IAED,yBAAyB;IACzB,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAE/D,MAAM,aAAa,GAAG;QACpB,2BAA2B,CAAC,KAAK,EAAE,WAAW,CAAC,OAAO,CAAC;QACvD,GAAG,iCAAiC,CAAC,KAAK,EAAE,WAAW,CAAC;QACxD,GAAG,iCAAiC,CAAC,KAAK,EAAE,WAAW,CAAC;QACxD,GAAG,4BAA4B,CAAC,KAAK,EAAE,WAAW,CAAC;QACnD,GAAG,8BAA8B,CAAC,KAAK,EAAE,WAAW,CAAC;KACtD,CAAC;IAEF,IAAI,CAAC,IAAI,EAAE,qBAAqB,EAAE,CAAC;QACjC,aAAa,CAAC,IAAI,CAAC,4BAA4B,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,2DAA2D;IAC3D,IAAI,IAAI,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;QAC3B,MAAM,yBAAyB,GAAG,4BAA4B,CAC5D,KAAgC,EAC/B,WAAwC,CAAC,OAAO,CAClD,CAAC;QACF,2FAA2F;QAC3F,IAAI,yBAAyB,EAAE,CAAC;YAC9B,aAAa,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAED,0BAA0B;IAC1B,IAAI,IAAI,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAM,iCAAiC,GAAG,oCAAoC,CAC5E,KAAK,CAAC,MAAM,EACZ,WAAwC,CACzC,CAAC;QACF,IAAI,iCAAiC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACjD,aAAa,CAAC,IAAI,CAAC,GAAG,iCAAiC,CAAC,CAAC;QAC3D,CAAC;IACH,CAAC;IAED,OAAO,aAAa,CAAC;AACvB,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { SignedBeaconBlock, phase0 } from "@lodestar/types";
|
|
2
|
-
import { ISignatureSet } from "../util/index.js";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/index.js";
|
|
4
4
|
export declare function getAttestationDataSigningRoot(state: CachedBeaconStateAllForks, data: phase0.AttestationData): Uint8Array;
|
|
5
5
|
export declare function getAttestationWithIndicesSignatureSet(state: CachedBeaconStateAllForks, attestation: Pick<phase0.Attestation, "data" | "signature">, attestingIndices: number[]): ISignatureSet;
|
|
6
6
|
export declare function getIndexedAttestationSignatureSet(state: CachedBeaconStateAllForks, indexedAttestation: phase0.IndexedAttestation): ISignatureSet;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"indexedAttestation.js","sourceRoot":"","sources":["../../src/signatureSets/indexedAttestation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAA4B,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"indexedAttestation.js","sourceRoot":"","sources":["../../src/signatureSets/indexedAttestation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAA4B,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAE/D,OAAO,EAEL,kBAAkB,EAClB,uBAAuB,EACvB,yCAAyC,GAC1C,MAAM,kBAAkB,CAAC;AAE1B,MAAM,UAAU,6BAA6B,CAC3C,KAAgC,EAChC,IAA4B;IAE5B,MAAM,IAAI,GAAG,uBAAuB,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACxD,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,sBAAsB,EAAE,IAAI,CAAC,CAAC;IAEhF,OAAO,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,eAAe,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;AACtE,CAAC;AAED,MAAM,UAAU,qCAAqC,CACnD,KAAgC,EAChC,WAA2D,EAC3D,gBAA0B;IAE1B,OAAO,yCAAyC,CAC9C,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAC3D,6BAA6B,CAAC,KAAK,EAAE,WAAW,CAAC,IAAI,CAAC,EACtD,WAAW,CAAC,SAAS,CACtB,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,iCAAiC,CAC/C,KAAgC,EAChC,kBAA6C;IAE7C,OAAO,qCAAqC,CAAC,KAAK,EAAE,kBAAkB,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,CAAC;AAC/G,CAAC;AAED,MAAM,UAAU,4BAA4B,CAC1C,KAAgC,EAChC,WAA8B;IAE9B,wFAAwF;IACxF,OAAO,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAC/D,iCAAiC,CAC/B,KAAK,EACL,KAAK,CAAC,QAAQ,CAAC,qBAAqB,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,WAAW,CAAC,CACrG,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { SignedBeaconBlock, SignedBlindedBeaconBlock, phase0 } from "@lodestar/types";
|
|
2
|
-
import { ISignatureSet } from "../util/signatureSets.js";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/signatureSets.js";
|
|
4
4
|
export declare function verifyProposerSignature(state: CachedBeaconStateAllForks, signedBlock: SignedBeaconBlock | SignedBlindedBeaconBlock): boolean;
|
|
5
5
|
export declare function getBlockProposerSignatureSet(state: CachedBeaconStateAllForks, signedBlock: SignedBeaconBlock | SignedBlindedBeaconBlock): ISignatureSet;
|
|
6
6
|
export declare function getBlockHeaderProposerSignatureSet(state: CachedBeaconStateAllForks, signedBlockHeader: phase0.SignedBeaconBlockHeader): ISignatureSet;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"proposer.js","sourceRoot":"","sources":["../../src/signatureSets/proposer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAA8C,oBAAoB,EAAU,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"proposer.js","sourceRoot":"","sources":["../../src/signatureSets/proposer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAA8C,oBAAoB,EAAU,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAE/G,OAAO,EAAC,kBAAkB,EAAC,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAgB,gBAAgB,EAAE,kBAAkB,EAAC,MAAM,0BAA0B,CAAC;AAE7F,MAAM,UAAU,uBAAuB,CACrC,KAAgC,EAChC,WAAyD;IAEzD,MAAM,YAAY,GAAG,4BAA4B,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACtE,OAAO,kBAAkB,CAAC,YAAY,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,4BAA4B,CAC1C,KAAgC,EAChC,WAAyD;IAEzD,MAAM,EAAC,MAAM,EAAE,QAAQ,EAAC,GAAG,KAAK,CAAC;IACjC,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,sBAAsB,EAAE,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9F,MAAM,SAAS,GAAG,oBAAoB,CAAC,WAAW,CAAC,OAAO,CAAC;QACzD,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,kBAAkB;QAC3E,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC;IAE9D,OAAO;QACL,IAAI,EAAE,gBAAgB,CAAC,MAAM;QAC7B,MAAM,EAAE,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC;QAChE,WAAW,EAAE,kBAAkB,CAAC,SAAS,EAAE,WAAW,CAAC,OAAO,EAAE,MAAM,CAAC;QACvE,SAAS,EAAE,WAAW,CAAC,SAAS;KACjC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kCAAkC,CAChD,KAAgC,EAChC,iBAAiD;IAEjD,MAAM,EAAC,MAAM,EAAE,QAAQ,EAAC,GAAG,KAAK,CAAC;IACjC,MAAM,MAAM,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,sBAAsB,EAAE,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAEpG,OAAO;QACL,IAAI,EAAE,gBAAgB,CAAC,MAAM;QAC7B,MAAM,EAAE,QAAQ,CAAC,YAAY,CAAC,iBAAiB,CAAC,OAAO,CAAC,aAAa,CAAC;QACtE,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,OAAO,EAAE,MAAM,CAAC;QAChG,SAAS,EAAE,iBAAiB,CAAC,SAAS;KACvC,CAAC;AACJ,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { SignedBeaconBlock, phase0 } from "@lodestar/types";
|
|
2
|
-
import { ISignatureSet } from "../util/index.js";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/index.js";
|
|
4
4
|
/**
|
|
5
5
|
* Extract signatures to allow validating all block signatures at once
|
|
6
6
|
*/
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DOMAIN_BEACON_PROPOSER } from "@lodestar/params";
|
|
2
2
|
import { ssz } from "@lodestar/types";
|
|
3
|
-
import {
|
|
3
|
+
import { SignatureSetType, computeSigningRoot } from "../util/index.js";
|
|
4
4
|
/**
|
|
5
5
|
* Extract signatures to allow validating all block signatures at once
|
|
6
6
|
*/
|
|
@@ -20,8 +20,6 @@ export function getProposerSlashingSignatureSets(state, proposerSlashing) {
|
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
22
|
export function getProposerSlashingsSignatureSets(state, signedBlock) {
|
|
23
|
-
return signedBlock.message.body.proposerSlashings
|
|
24
|
-
.map((proposerSlashing) => getProposerSlashingSignatureSets(state, proposerSlashing))
|
|
25
|
-
.flat(1);
|
|
23
|
+
return signedBlock.message.body.proposerSlashings.flatMap((proposerSlashing) => getProposerSlashingSignatureSets(state, proposerSlashing));
|
|
26
24
|
}
|
|
27
25
|
//# sourceMappingURL=proposerSlashings.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"proposerSlashings.js","sourceRoot":"","sources":["../../src/signatureSets/proposerSlashings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAA4B,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"proposerSlashings.js","sourceRoot":"","sources":["../../src/signatureSets/proposerSlashings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,sBAAsB,EAAC,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAA4B,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAE/D,OAAO,EAAgB,gBAAgB,EAAE,kBAAkB,EAAC,MAAM,kBAAkB,CAAC;AAErF;;GAEG;AACH,MAAM,UAAU,gCAAgC,CAC9C,KAAgC,EAChC,gBAAyC;IAEzC,MAAM,EAAC,QAAQ,EAAC,GAAG,KAAK,CAAC;IACzB,MAAM,MAAM,GAAG,QAAQ,CAAC,YAAY,CAAC,gBAAgB,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAE3F,kHAAkH;IAClH,iHAAiH;IACjH,OAAO,CAAC,gBAAgB,CAAC,aAAa,EAAE,gBAAgB,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,EAAiB,EAAE;QAC1G,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CACnC,KAAK,CAAC,IAAI,EACV,sBAAsB,EACtB,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,IAAc,CAAC,CAC5C,CAAC;QAEF,OAAO;YACL,IAAI,EAAE,gBAAgB,CAAC,MAAM;YAC7B,MAAM;YACN,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,uBAAuB,EAAE,YAAY,CAAC,OAAO,EAAE,MAAM,CAAC;YACjG,SAAS,EAAE,YAAY,CAAC,SAAS;SAClC,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,iCAAiC,CAC/C,KAAgC,EAChC,WAA8B;IAE9B,OAAO,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,gBAAgB,EAAE,EAAE,CAC7E,gCAAgC,CAAC,KAAK,EAAE,gBAAgB,CAAC,CAC1D,CAAC;AACJ,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { BeaconBlock } from "@lodestar/types";
|
|
2
|
-
import { ISignatureSet } from "../util/index.js";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/index.js";
|
|
4
4
|
export declare function verifyRandaoSignature(state: CachedBeaconStateAllForks, block: BeaconBlock): boolean;
|
|
5
5
|
/**
|
|
6
6
|
* Extract signatures to allow validating all block signatures at once
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DOMAIN_RANDAO } from "@lodestar/params";
|
|
2
2
|
import { ssz } from "@lodestar/types";
|
|
3
|
-
import { computeEpochAtSlot, computeSigningRoot,
|
|
3
|
+
import { SignatureSetType, computeEpochAtSlot, computeSigningRoot, verifySignatureSet, } from "../util/index.js";
|
|
4
4
|
export function verifyRandaoSignature(state, block) {
|
|
5
5
|
return verifySignatureSet(getRandaoRevealSignatureSet(state, block));
|
|
6
6
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"randao.js","sourceRoot":"","sources":["../../src/signatureSets/randao.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAc,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"randao.js","sourceRoot":"","sources":["../../src/signatureSets/randao.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAc,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAEjD,OAAO,EAEL,gBAAgB,EAChB,kBAAkB,EAClB,kBAAkB,EAClB,kBAAkB,GACnB,MAAM,kBAAkB,CAAC;AAE1B,MAAM,UAAU,qBAAqB,CAAC,KAAgC,EAAE,KAAkB;IACxF,OAAO,kBAAkB,CAAC,2BAA2B,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;AACvE,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,2BAA2B,CAAC,KAAgC,EAAE,KAAkB;IAC9F,MAAM,EAAC,QAAQ,EAAC,GAAG,KAAK,CAAC;IACzB,qCAAqC;IACrC,MAAM,KAAK,GAAG,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC7C,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,EAAE,aAAa,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IAE7E,OAAO;QACL,IAAI,EAAE,gBAAgB,CAAC,MAAM;QAC7B,MAAM,EAAE,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,aAAa,CAAC;QAClD,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC;QACzD,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,YAAY;KACnC,CAAC;AACJ,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { SignedBeaconBlock, phase0 } from "@lodestar/types";
|
|
2
|
-
import { ISignatureSet } from "../util/index.js";
|
|
3
2
|
import { CachedBeaconStateAllForks } from "../types.js";
|
|
3
|
+
import { ISignatureSet } from "../util/index.js";
|
|
4
4
|
export declare function verifyVoluntaryExitSignature(state: CachedBeaconStateAllForks, signedVoluntaryExit: phase0.SignedVoluntaryExit): boolean;
|
|
5
5
|
/**
|
|
6
6
|
* Extract signatures to allow validating all block signatures at once
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ssz } from "@lodestar/types";
|
|
2
|
-
import { computeSigningRoot, computeStartSlotAtEpoch,
|
|
2
|
+
import { SignatureSetType, computeSigningRoot, computeStartSlotAtEpoch, verifySignatureSet, } from "../util/index.js";
|
|
3
3
|
export function verifyVoluntaryExitSignature(state, signedVoluntaryExit) {
|
|
4
4
|
return verifySignatureSet(getVoluntaryExitSignatureSet(state, signedVoluntaryExit));
|
|
5
5
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"voluntaryExits.js","sourceRoot":"","sources":["../../src/signatureSets/voluntaryExits.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,GAAG,EAAC,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"voluntaryExits.js","sourceRoot":"","sources":["../../src/signatureSets/voluntaryExits.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAE/D,OAAO,EAEL,gBAAgB,EAChB,kBAAkB,EAClB,uBAAuB,EACvB,kBAAkB,GACnB,MAAM,kBAAkB,CAAC;AAE1B,MAAM,UAAU,4BAA4B,CAC1C,KAAgC,EAChC,mBAA+C;IAE/C,OAAO,kBAAkB,CAAC,4BAA4B,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC;AACtF,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,4BAA4B,CAC1C,KAAgC,EAChC,mBAA+C;IAE/C,MAAM,EAAC,QAAQ,EAAC,GAAG,KAAK,CAAC;IACzB,MAAM,IAAI,GAAG,uBAAuB,CAAC,mBAAmB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACxE,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,yBAAyB,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAExE,OAAO;QACL,IAAI,EAAE,gBAAgB,CAAC,MAAM;QAC7B,MAAM,EAAE,QAAQ,CAAC,YAAY,CAAC,mBAAmB,CAAC,OAAO,CAAC,cAAc,CAAC;QACzE,WAAW,EAAE,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAAC,OAAO,EAAE,MAAM,CAAC;QAC9F,SAAS,EAAE,mBAAmB,CAAC,SAAS;KACzC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,8BAA8B,CAC5C,KAAgC,EAChC,WAA8B;IAE9B,OAAO,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE,CACnE,4BAA4B,CAAC,KAAK,EAAE,aAAa,CAAC,CACnD,CAAC;AACJ,CAAC"}
|
package/lib/slot/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/slot/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAC,yBAAyB,EAAC,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/slot/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAC,yBAAyB,EAAC,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAC,SAAS,EAAC,MAAM,uBAAuB,CAAC;AAGhD,OAAO,EAAC,oBAAoB,EAAC,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAC,uBAAuB,EAAC,MAAM,8BAA8B,CAAC;AACrE,OAAO,EAAC,qBAAqB,EAAC,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAC,qBAAqB,EAAC,MAAM,4BAA4B,CAAC;AAEjE;;GAEG;AACH,MAAM,UAAU,WAAW,CAAC,KAAgC;IAC1D,mBAAmB;IACnB,gEAAgE;IAChE,MAAM,iBAAiB,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;IAC/C,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,GAAG,yBAAyB,EAAE,iBAAiB,CAAC,CAAC;IAEhF,uCAAuC;IACvC,IAAI,eAAe,CAAC,KAAK,CAAC,iBAAiB,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE,CAAC;QAClE,KAAK,CAAC,iBAAiB,CAAC,SAAS,GAAG,iBAAiB,CAAC;IACxD,CAAC;IAED,mBAAmB;IACnB,gEAAgE;IAChE,MAAM,iBAAiB,GAAG,KAAK,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;IACjE,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,GAAG,yBAAyB,EAAE,iBAAiB,CAAC,CAAC;AAClF,CAAC"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { ssz } from "@lodestar/types";
|
|
2
1
|
import { ForkSeq } from "@lodestar/params";
|
|
3
|
-
import {
|
|
2
|
+
import { ssz } from "@lodestar/types";
|
|
3
|
+
import { getAttestationParticipationStatus } from "../block/processAttestationsAltair.js";
|
|
4
|
+
import { getCachedBeaconState } from "../cache/stateCache.js";
|
|
5
|
+
import { RootCache, newZeroedArray } from "../util/index.js";
|
|
4
6
|
import { getNextSyncCommittee } from "../util/syncCommittee.js";
|
|
5
7
|
import { sumTargetUnslashedBalanceIncrements } from "../util/targetUnslashedBalance.js";
|
|
6
|
-
import { getCachedBeaconState } from "../cache/stateCache.js";
|
|
7
|
-
import { getAttestationParticipationStatus } from "../block/processAttestationsAltair.js";
|
|
8
8
|
/**
|
|
9
9
|
* Upgrade a state from phase0 to altair.
|
|
10
10
|
*/
|
|
@@ -75,6 +75,7 @@ export function upgradeStateToAltair(statePhase0) {
|
|
|
75
75
|
//
|
|
76
76
|
// TODO: This could only drop the caches of index 15,16. However this would couple this code tightly with SSZ ViewDU
|
|
77
77
|
// internals. If the cache is not cleared, consuming the ViewDU instance could break in strange ways.
|
|
78
|
+
// biome-ignore lint/complexity/useLiteralKeys: It is a protected attribute
|
|
78
79
|
stateAltair["clearCache"]();
|
|
79
80
|
// TODO: describe issue. Compute progressive target balances
|
|
80
81
|
//
|