45 lines
1.5 KiB
Python
Raw Normal View History

2019-05-31 11:32:53 +02:00
from eth2spec.test.helpers.keys import privkeys
2019-06-22 16:56:16 +02:00
from eth2spec.utils.bls import bls_sign, bls_aggregate_signatures
2019-06-24 16:26:21 +02:00
from eth2spec.utils.hash_function import hash
2019-05-31 11:32:53 +02:00
def get_valid_early_derived_secret_reveal(spec, state, epoch=None):
current_epoch = spec.get_current_epoch(state)
revealed_index = spec.get_active_validator_indices(state, current_epoch)[-1]
masker_index = spec.get_active_validator_indices(state, current_epoch)[0]
if epoch is None:
epoch = current_epoch + spec.CUSTODY_PERIOD_TO_RANDAO_PADDING
2019-06-22 16:56:16 +02:00
# Generate the secret that is being revealed
2019-05-31 11:32:53 +02:00
reveal = bls_sign(
2019-06-20 20:25:22 +02:00
message_hash=spec.hash_tree_root(spec.Epoch(epoch)),
2019-05-31 11:32:53 +02:00
privkey=privkeys[revealed_index],
domain=spec.get_domain(
state=state,
domain_type=spec.DOMAIN_RANDAO,
message_epoch=epoch,
),
)
2019-06-24 16:26:21 +02:00
# Generate the mask (any random 32 bytes that don't reveal the masker's secret will do)
mask = hash(reveal)
2019-06-22 16:56:16 +02:00
# Generate masker's signature on the mask
masker_signature = bls_sign(
message_hash=mask,
2019-05-31 11:32:53 +02:00
privkey=privkeys[masker_index],
domain=spec.get_domain(
state=state,
domain_type=spec.DOMAIN_RANDAO,
message_epoch=epoch,
),
)
2019-06-22 16:56:16 +02:00
masked_reveal = bls_aggregate_signatures([reveal, masker_signature])
2019-05-31 11:32:53 +02:00
return spec.EarlyDerivedSecretReveal(
revealed_index=revealed_index,
epoch=epoch,
2019-06-22 16:56:16 +02:00
reveal=masked_reveal,
2019-05-31 11:32:53 +02:00
masker_index=masker_index,
mask=mask,
)