move Attestation-related types/logging from base to phase0 types (#6207)

This commit is contained in:
tersec 2024-04-16 21:01:30 +02:00 committed by GitHub
parent bd3c9af0f8
commit bb2ca747bc
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 58 additions and 54 deletions

View File

@ -250,20 +250,6 @@ type
CommitteeValidatorsBits* = BitList[Limit MAX_VALIDATORS_PER_COMMITTEE] CommitteeValidatorsBits* = BitList[Limit MAX_VALIDATORS_PER_COMMITTEE]
# https://github.com/ethereum/consensus-specs/blob/v1.4.0-beta.6/specs/phase0/beacon-chain.md#attestation
Attestation* = object
aggregation_bits*: CommitteeValidatorsBits
data*: AttestationData
signature*: ValidatorSig
TrustedAttestation* = object
# The Trusted version, at the moment, implies that the cryptographic signature was checked.
# It DOES NOT imply that the state transition was verified.
# Currently the code MUST verify the state transition as soon as the signature is verified
aggregation_bits*: CommitteeValidatorsBits
data*: AttestationData
signature*: TrustedSig
ForkDigest* = distinct array[4, byte] ForkDigest* = distinct array[4, byte]
# https://github.com/ethereum/consensus-specs/blob/v1.4.0-beta.6/specs/phase0/beacon-chain.md#forkdata # https://github.com/ethereum/consensus-specs/blob/v1.4.0-beta.6/specs/phase0/beacon-chain.md#forkdata
@ -318,7 +304,6 @@ type
## Earliest epoch when voluntary exit can be processed ## Earliest epoch when voluntary exit can be processed
validator_index*: uint64 # `ValidatorIndex` after validation validator_index*: uint64 # `ValidatorIndex` after validation
SomeAttestation* = Attestation | TrustedAttestation
SomeIndexedAttestation* = IndexedAttestation | TrustedIndexedAttestation SomeIndexedAttestation* = IndexedAttestation | TrustedIndexedAttestation
SomeProposerSlashing* = ProposerSlashing | TrustedProposerSlashing SomeProposerSlashing* = ProposerSlashing | TrustedProposerSlashing
SomeAttesterSlashing* = AttesterSlashing | TrustedAttesterSlashing SomeAttesterSlashing* = AttesterSlashing | TrustedAttesterSlashing
@ -430,17 +415,6 @@ type
message*: BeaconBlockHeader message*: BeaconBlockHeader
signature*: TrustedSig signature*: TrustedSig
# https://github.com/ethereum/consensus-specs/blob/v1.4.0/specs/phase0/validator.md#aggregateandproof
AggregateAndProof* = object
aggregator_index*: uint64 # `ValidatorIndex` after validation
aggregate*: Attestation
selection_proof*: ValidatorSig
# https://github.com/ethereum/consensus-specs/blob/v1.4.0/specs/phase0/validator.md#signedaggregateandproof
SignedAggregateAndProof* = object
message*: AggregateAndProof
signature*: ValidatorSig
SyncCommitteeCache* = object SyncCommitteeCache* = object
current_sync_committee*: array[SYNC_COMMITTEE_SIZE, ValidatorIndex] current_sync_committee*: array[SYNC_COMMITTEE_SIZE, ValidatorIndex]
next_sync_committee*: array[SYNC_COMMITTEE_SIZE, ValidatorIndex] next_sync_committee*: array[SYNC_COMMITTEE_SIZE, ValidatorIndex]
@ -842,16 +816,6 @@ func shortLog*(v: PendingAttestation): auto =
proposer_index: v.proposer_index proposer_index: v.proposer_index
) )
func shortLog*(v: SomeAttestation): auto =
(
aggregation_bits: v.aggregation_bits,
data: shortLog(v.data),
signature: shortLog(v.signature)
)
template asTrusted*(x: Attestation): TrustedAttestation =
isomorphicCast[TrustedAttestation](x)
func shortLog*(v: SomeIndexedAttestation): auto = func shortLog*(v: SomeIndexedAttestation): auto =
( (
attestating_indices: v.attesting_indices, attestating_indices: v.attesting_indices,
@ -894,7 +858,6 @@ func shortLog*(v: SomeSignedVoluntaryExit): auto =
) )
chronicles.formatIt AttestationData: it.shortLog chronicles.formatIt AttestationData: it.shortLog
chronicles.formatIt Attestation: it.shortLog
chronicles.formatIt Checkpoint: it.shortLog chronicles.formatIt Checkpoint: it.shortLog
const const
@ -926,23 +889,6 @@ func init*(T: type GraffitiBytes, input: string): GraffitiBytes
raise newException(ValueError, "The graffiti value should be 32 characters or less") raise newException(ValueError, "The graffiti value should be 32 characters or less")
distinctBase(result)[0 ..< input.len] = toBytes(input) distinctBase(result)[0 ..< input.len] = toBytes(input)
func init*(
T: type Attestation,
indices_in_committee: openArray[uint64],
committee_len: int,
data: AttestationData,
signature: ValidatorSig): Result[T, cstring] =
var bits = CommitteeValidatorsBits.init(committee_len)
for index_in_committee in indices_in_committee:
if index_in_committee >= committee_len.uint64: return err("Invalid index for committee")
bits.setBit index_in_committee
ok Attestation(
aggregation_bits: bits,
data: data,
signature: signature
)
func defaultGraffitiBytes*(): GraffitiBytes = func defaultGraffitiBytes*(): GraffitiBytes =
const graffitiBytes = const graffitiBytes =
toBytes("Nimbus/" & fullVersionStr) toBytes("Nimbus/" & fullVersionStr)

View File

@ -257,6 +257,31 @@ type
root* {.dontSerialize.}: Eth2Digest # cached root of signed beacon block root* {.dontSerialize.}: Eth2Digest # cached root of signed beacon block
# https://github.com/ethereum/consensus-specs/blob/v1.4.0-beta.6/specs/phase0/beacon-chain.md#attestation
Attestation* = object
aggregation_bits*: CommitteeValidatorsBits
data*: AttestationData
signature*: ValidatorSig
TrustedAttestation* = object
# The Trusted version, at the moment, implies that the cryptographic signature was checked.
# It DOES NOT imply that the state transition was verified.
# Currently the code MUST verify the state transition as soon as the signature is verified
aggregation_bits*: CommitteeValidatorsBits
data*: AttestationData
signature*: TrustedSig
# https://github.com/ethereum/consensus-specs/blob/v1.4.0/specs/phase0/validator.md#aggregateandproof
AggregateAndProof* = object
aggregator_index*: uint64 # `ValidatorIndex` after validation
aggregate*: Attestation
selection_proof*: ValidatorSig
# https://github.com/ethereum/consensus-specs/blob/v1.4.0/specs/phase0/validator.md#signedaggregateandproof
SignedAggregateAndProof* = object
message*: AggregateAndProof
signature*: ValidatorSig
SomeSignedBeaconBlock* = SomeSignedBeaconBlock* =
SignedBeaconBlock | SignedBeaconBlock |
SigVerifiedSignedBeaconBlock | SigVerifiedSignedBeaconBlock |
@ -270,6 +295,7 @@ type
BeaconBlockBody | BeaconBlockBody |
SigVerifiedBeaconBlockBody | SigVerifiedBeaconBlockBody |
TrustedBeaconBlockBody TrustedBeaconBlockBody
SomeAttestation* = Attestation | TrustedAttestation
EpochInfo* = object EpochInfo* = object
## Information about the outcome of epoch processing ## Information about the outcome of epoch processing
@ -277,6 +303,7 @@ type
balances*: TotalBalances balances*: TotalBalances
chronicles.formatIt BeaconBlock: it.shortLog chronicles.formatIt BeaconBlock: it.shortLog
chronicles.formatIt Attestation: it.shortLog
func clear*(info: var EpochInfo) = func clear*(info: var EpochInfo) =
info.validators.setLen(0) info.validators.setLen(0)
@ -314,6 +341,16 @@ func shortLog*(v: SomeSignedBeaconBlock): auto =
signature: shortLog(v.signature) signature: shortLog(v.signature)
) )
func shortLog*(v: SomeAttestation): auto =
(
aggregation_bits: v.aggregation_bits,
data: shortLog(v.data),
signature: shortLog(v.signature)
)
template asTrusted*(x: Attestation): TrustedAttestation =
isomorphicCast[TrustedAttestation](x)
template asSigned*( template asSigned*(
x: SigVerifiedSignedBeaconBlock | x: SigVerifiedSignedBeaconBlock |
MsgTrustedSignedBeaconBlock | MsgTrustedSignedBeaconBlock |
@ -341,3 +378,20 @@ template asTrusted*(
SigVerifiedSignedBeaconBlock | SigVerifiedSignedBeaconBlock |
MsgTrustedSignedBeaconBlock): TrustedSignedBeaconBlock = MsgTrustedSignedBeaconBlock): TrustedSignedBeaconBlock =
isomorphicCast[TrustedSignedBeaconBlock](x) isomorphicCast[TrustedSignedBeaconBlock](x)
func init*(
T: type Attestation,
indices_in_committee: openArray[uint64],
committee_len: int,
data: AttestationData,
signature: ValidatorSig): Result[T, cstring] =
var bits = CommitteeValidatorsBits.init(committee_len)
for index_in_committee in indices_in_committee:
if index_in_committee >= committee_len.uint64: return err("Invalid index for committee")
bits.setBit index_in_committee
ok Attestation(
aggregation_bits: bits,
data: data,
signature: signature
)

View File

@ -8,6 +8,7 @@
{.push raises: [].} {.push raises: [].}
import ".."/datatypes/altair import ".."/datatypes/altair
from ".."/datatypes/phase0 import Attestation
from ".."/datatypes/bellatrix import ExecutionPayloadHeader from ".."/datatypes/bellatrix import ExecutionPayloadHeader
from ".."/eth2_merkleization import hash_tree_root from ".."/eth2_merkleization import hash_tree_root

View File

@ -8,6 +8,7 @@
{.push raises: [].} {.push raises: [].}
import ".."/datatypes/[altair, capella] import ".."/datatypes/[altair, capella]
from ".."/datatypes/phase0 import Attestation
from stew/byteutils import to0xHex from stew/byteutils import to0xHex
from ../eth2_merkleization import fromSszBytes, hash_tree_root, toSszType from ../eth2_merkleization import fromSszBytes, hash_tree_root, toSszType

View File

@ -10,6 +10,7 @@
import ".."/datatypes/[altair, deneb] import ".."/datatypes/[altair, deneb]
from stew/byteutils import to0xHex from stew/byteutils import to0xHex
from ".."/datatypes/phase0 import Attestation
from ../datatypes/bellatrix import ExecutionAddress from ../datatypes/bellatrix import ExecutionAddress
from ".."/datatypes/capella import SignedBLSToExecutionChange from ".."/datatypes/capella import SignedBLSToExecutionChange
from ".."/eth2_merkleization import hash_tree_root from ".."/eth2_merkleization import hash_tree_root

View File

@ -10,6 +10,7 @@
import ".."/datatypes/[altair, electra] import ".."/datatypes/[altair, electra]
from stew/byteutils import to0xHex from stew/byteutils import to0xHex
from ".."/datatypes/phase0 import Attestation
from ../datatypes/bellatrix import ExecutionAddress from ../datatypes/bellatrix import ExecutionAddress
from ".."/datatypes/capella import SignedBLSToExecutionChange from ".."/datatypes/capella import SignedBLSToExecutionChange
from ".."/datatypes/deneb import BlobsBundle, KzgCommitments from ".."/datatypes/deneb import BlobsBundle, KzgCommitments