mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-02-01 05:14:49 +00:00
Refactor is_valid_indexed_attestation
: extract verify_attestation_custody
This commit is contained in:
parent
7509ecb742
commit
8ae7f5b6fa
@ -52,6 +52,7 @@
|
|||||||
- [`get_latest_slot_for_shard`](#get_latest_slot_for_shard)
|
- [`get_latest_slot_for_shard`](#get_latest_slot_for_shard)
|
||||||
- [`get_offset_slots`](#get_offset_slots)
|
- [`get_offset_slots`](#get_offset_slots)
|
||||||
- [Predicates](#predicates)
|
- [Predicates](#predicates)
|
||||||
|
- [`verify_attestation_custody`](#verify_attestation_custody)
|
||||||
- [Updated `is_valid_indexed_attestation`](#updated-is_valid_indexed_attestation)
|
- [Updated `is_valid_indexed_attestation`](#updated-is_valid_indexed_attestation)
|
||||||
- [`is_shard_attestation`](#is_shard_attestation)
|
- [`is_shard_attestation`](#is_shard_attestation)
|
||||||
- [`is_winning_attestation`](#is_winning_attestation)
|
- [`is_winning_attestation`](#is_winning_attestation)
|
||||||
@ -414,7 +415,7 @@ def unpack_compact_validator(compact_validator: uint64) -> Tuple[ValidatorIndex,
|
|||||||
```python
|
```python
|
||||||
def committee_to_compact_committee(state: BeaconState, committee: Sequence[ValidatorIndex]) -> CompactCommittee:
|
def committee_to_compact_committee(state: BeaconState, committee: Sequence[ValidatorIndex]) -> CompactCommittee:
|
||||||
"""
|
"""
|
||||||
Given a state and a list of validator indices, outputs the CompactCommittee representing them.
|
Given a state and a list of validator indices, outputs the ``CompactCommittee`` representing them.
|
||||||
"""
|
"""
|
||||||
validators = [state.validators[i] for i in committee]
|
validators = [state.validators[i] for i in committee]
|
||||||
compact_validators = [
|
compact_validators = [
|
||||||
@ -569,6 +570,37 @@ def get_offset_slots(state: BeaconState, shard: Shard) -> Sequence[Slot]:
|
|||||||
|
|
||||||
### Predicates
|
### Predicates
|
||||||
|
|
||||||
|
#### `verify_attestation_custody`
|
||||||
|
|
||||||
|
```python
|
||||||
|
def verify_attestation_custody(state: BeaconState, indexed_attestation: IndexedAttestation) -> bool:
|
||||||
|
"""
|
||||||
|
Check if ``indexed_attestation`` has valid signature against non-empty custody bits.
|
||||||
|
"""
|
||||||
|
attestation = indexed_attestation.attestation
|
||||||
|
aggregation_bits = attestation.aggregation_bits
|
||||||
|
domain = get_domain(state, DOMAIN_BEACON_ATTESTER, attestation.data.target.epoch)
|
||||||
|
all_pubkeys = []
|
||||||
|
all_signing_roots = []
|
||||||
|
for block_index, custody_bits in enumerate(attestation.custody_bits_blocks):
|
||||||
|
assert len(custody_bits) == len(indexed_attestation.committee)
|
||||||
|
for participant, aggregation_bit, custody_bit in zip(
|
||||||
|
indexed_attestation.committee, aggregation_bits, custody_bits
|
||||||
|
):
|
||||||
|
if aggregation_bit:
|
||||||
|
all_pubkeys.append(state.validators[participant].pubkey)
|
||||||
|
# Note: only 2N distinct message hashes
|
||||||
|
attestation_wrapper = AttestationCustodyBitWrapper(
|
||||||
|
attestation_data_root=hash_tree_root(attestation.data),
|
||||||
|
block_index=block_index,
|
||||||
|
bit=custody_bit,
|
||||||
|
)
|
||||||
|
all_signing_roots.append(compute_signing_root(attestation_wrapper, domain))
|
||||||
|
else:
|
||||||
|
assert not custody_bit
|
||||||
|
return bls.AggregateVerify(all_pubkeys, all_signing_roots, signature=attestation.signature)
|
||||||
|
```
|
||||||
|
|
||||||
#### Updated `is_valid_indexed_attestation`
|
#### Updated `is_valid_indexed_attestation`
|
||||||
|
|
||||||
Note that this replaces the Phase 0 `is_valid_indexed_attestation`.
|
Note that this replaces the Phase 0 `is_valid_indexed_attestation`.
|
||||||
@ -584,34 +616,17 @@ def is_valid_indexed_attestation(state: BeaconState, indexed_attestation: Indexe
|
|||||||
if not any(aggregation_bits) or len(aggregation_bits) != len(indexed_attestation.committee):
|
if not any(aggregation_bits) or len(aggregation_bits) != len(indexed_attestation.committee):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
domain = get_domain(state, DOMAIN_BEACON_ATTESTER, attestation.data.target.epoch)
|
|
||||||
all_pubkeys = []
|
|
||||||
all_signing_roots = []
|
|
||||||
if len(attestation.custody_bits_blocks) == 0:
|
if len(attestation.custody_bits_blocks) == 0:
|
||||||
# fall back on phase0 behavior if there is no shard data.
|
# fall back on phase0 behavior if there is no shard data.
|
||||||
|
domain = get_domain(state, DOMAIN_BEACON_ATTESTER, attestation.data.target.epoch)
|
||||||
|
all_pubkeys = []
|
||||||
for participant, aggregation_bit in zip(indexed_attestation.committee, aggregation_bits):
|
for participant, aggregation_bit in zip(indexed_attestation.committee, aggregation_bits):
|
||||||
if aggregation_bit:
|
if aggregation_bit:
|
||||||
all_pubkeys.append(state.validators[participant].pubkey)
|
all_pubkeys.append(state.validators[participant].pubkey)
|
||||||
signing_root = compute_signing_root(indexed_attestation.attestation.data, domain)
|
signing_root = compute_signing_root(indexed_attestation.attestation.data, domain)
|
||||||
return bls.FastAggregateVerify(all_pubkeys, signing_root, signature=attestation.signature)
|
return bls.FastAggregateVerify(all_pubkeys, signing_root, signature=attestation.signature)
|
||||||
else:
|
else:
|
||||||
for block_index, custody_bits in enumerate(attestation.custody_bits_blocks):
|
return verify_attestation_custody(state, indexed_attestation)
|
||||||
assert len(custody_bits) == len(indexed_attestation.committee)
|
|
||||||
for participant, aggregation_bit, custody_bit in zip(
|
|
||||||
indexed_attestation.committee, aggregation_bits, custody_bits
|
|
||||||
):
|
|
||||||
if aggregation_bit:
|
|
||||||
all_pubkeys.append(state.validators[participant].pubkey)
|
|
||||||
# Note: only 2N distinct message hashes
|
|
||||||
attestation_wrapper = AttestationCustodyBitWrapper(
|
|
||||||
attestation_data_root=hash_tree_root(attestation.data),
|
|
||||||
block_index=block_index,
|
|
||||||
bit=custody_bit
|
|
||||||
)
|
|
||||||
all_signing_roots.append(compute_signing_root(attestation_wrapper, domain))
|
|
||||||
else:
|
|
||||||
assert not custody_bit
|
|
||||||
return bls.AggregateVerify(all_pubkeys, all_signing_roots, signature=attestation.signature)
|
|
||||||
```
|
```
|
||||||
|
|
||||||
#### `is_shard_attestation`
|
#### `is_shard_attestation`
|
||||||
|
Loading…
x
Reference in New Issue
Block a user