From f7ed1864471632b670e8454c8f9d43fb7c43f000 Mon Sep 17 00:00:00 2001 From: Hsiao-Wei Wang Date: Mon, 1 Jul 2019 10:46:22 +0800 Subject: [PATCH 1/2] Use `Checkpoint` --- specs/validator/0_beacon-chain-validator.md | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/specs/validator/0_beacon-chain-validator.md b/specs/validator/0_beacon-chain-validator.md index 0e9583a070..aa41ca0ce6 100644 --- a/specs/validator/0_beacon-chain-validator.md +++ b/specs/validator/0_beacon-chain-validator.md @@ -301,10 +301,8 @@ Set `attestation_data.beacon_block_root = signing_root(head_block)`. ##### FFG vote -- Set `attestation_data.source_epoch = head_state.current_justified_epoch`. -- Set `attestation_data.source_root = head_state.current_justified_root`. -- Set `attestation_data.target_epoch = get_current_epoch(head_state)` -- Set `attestation_data.target_root = epoch_boundary_block_root` where `epoch_boundary_block_root` is the root of block at the most recent epoch boundary. +- Set `attestation_data.source = head_state.current_justified_checkpoint`. +- Set `attestation_data.target = Checkpoint(epoch=get_current_epoch(head_state), root=epoch_boundary_block_root)` where `epoch_boundary_block_root` is the root of block at the most recent epoch boundary. *Note*: `epoch_boundary_block_root` can be looked up in the state using: @@ -318,7 +316,7 @@ Construct `attestation_data.crosslink` via the following. - Set `attestation_data.crosslink.shard = shard` where `shard` is the shard associated with the validator's committee. - Let `parent_crosslink = head_state.current_crosslinks[shard]`. - Set `attestation_data.crosslink.start_epoch = parent_crosslink.end_epoch`. -- Set `attestation_data.crosslink.end_epoch = min(attestation_data.target_epoch, parent_crosslink.end_epoch + MAX_EPOCHS_PER_CROSSLINK)`. +- Set `attestation_data.crosslink.end_epoch = min(attestation_data.target.epoch, parent_crosslink.end_epoch + MAX_EPOCHS_PER_CROSSLINK)`. - Set `attestation_data.crosslink.parent_root = hash_tree_root(head_state.current_crosslinks[shard])`. - Set `attestation_data.crosslink.data_root = ZERO_HASH`. *Note*: This is a stub for Phase 0. @@ -389,7 +387,7 @@ To avoid "attester slashings", a validator must not sign two conflicting [`Attes Specifically, when signing an `Attestation`, a validator should perform the following steps in the following order: -1. Save a record to hard disk that an attestation has been signed for source (i.e. `attestation_data.source_epoch`) and target (i.e. `compute_epoch_of_slot(attestation_data.slot)`). +1. Save a record to hard disk that an attestation has been signed for source (i.e. `attestation_data.source.epoch`) and target (i.e. `compute_epoch_of_slot(attestation_data.slot)`). 2. Generate and broadcast attestation. If the software crashes at some point within this routine, then when the validator comes back online, the hard disk has the record of the *potentially* signed/broadcast attestation and can effectively avoid slashing. From 4f360a58e2a17549b74a92b59a2245cf8138e9d7 Mon Sep 17 00:00:00 2001 From: Hsiao-Wei Wang Date: Mon, 1 Jul 2019 10:58:09 +0800 Subject: [PATCH 2/2] Fix outdated `fork.slot` and `attestation_data.slot` --- specs/validator/0_beacon-chain-validator.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/specs/validator/0_beacon-chain-validator.md b/specs/validator/0_beacon-chain-validator.md index aa41ca0ce6..63ccf10bfc 100644 --- a/specs/validator/0_beacon-chain-validator.md +++ b/specs/validator/0_beacon-chain-validator.md @@ -212,7 +212,7 @@ epoch_signature = bls_sign( privkey=validator.privkey, # privkey stored locally, not in state message_hash=hash_tree_root(compute_epoch_of_slot(block.slot)), domain=get_domain( - fork=fork, # `fork` is the fork object at the slot `block.slot` + fork=fork, # `fork` is the fork object at the epoch `compute_epoch_of_slot(block.slot)` epoch=compute_epoch_of_slot(block.slot), domain_type=DOMAIN_RANDAO, ) @@ -251,7 +251,7 @@ block_signature = bls_sign( privkey=validator.privkey, # privkey store locally, not in state message_hash=signing_root(block), domain=get_domain( - fork=fork, # `fork` is the fork object at the slot `block.slot` + fork=fork, # `fork` is the fork object at the epoch `compute_epoch_of_slot(block.slot)` epoch=compute_epoch_of_slot(block.slot), domain_type=DOMAIN_BEACON_BLOCK, ) @@ -355,8 +355,8 @@ signed_attestation_data = bls_sign( privkey=validator.privkey, # privkey stored locally, not in state message_hash=attestation_message, domain=get_domain( - fork=fork, # `fork` is the fork object at the slot, `attestation_data.slot` - epoch=compute_epoch_of_slot(attestation_data.slot), + fork=fork, # `fork` is the fork object at epoch `target.epoch` + epoch=target.epoch, domain_type=DOMAIN_ATTESTATION, ) ) @@ -387,7 +387,7 @@ To avoid "attester slashings", a validator must not sign two conflicting [`Attes Specifically, when signing an `Attestation`, a validator should perform the following steps in the following order: -1. Save a record to hard disk that an attestation has been signed for source (i.e. `attestation_data.source.epoch`) and target (i.e. `compute_epoch_of_slot(attestation_data.slot)`). +1. Save a record to hard disk that an attestation has been signed for source (i.e. `attestation_data.source.epoch`) and target (i.e. `attestation_data.target.epoch`). 2. Generate and broadcast attestation. If the software crashes at some point within this routine, then when the validator comes back online, the hard disk has the record of the *potentially* signed/broadcast attestation and can effectively avoid slashing.