use account_utils::{eth2_keystore::keypair_from_secret, mnemonic_from_phrase}; use clap::ArgMatches; use eth2_wallet::bip39::Seed; use eth2_wallet::{recover_validator_secret_from_mnemonic, KeyType}; use ssz::{Decode, Encode}; use std::fs::File; use std::io::{Read, Write}; use std::path::PathBuf; use types::{BeaconState, EthSpec}; pub fn run(matches: &ArgMatches) -> Result<(), String> { let path = matches .value_of("ssz-state") .ok_or("ssz-state not specified")? .parse::() .map_err(|e| format!("Unable to parse ssz-state: {}", e))?; let mnemonic_phrase = matches .value_of("mnemonic") .ok_or("mnemonic not specified")?; let mut state: BeaconState = { let mut file = File::open(&path).map_err(|e| format!("Unable to open file: {}", e))?; let mut ssz = vec![]; file.read_to_end(&mut ssz) .map_err(|e| format!("Unable to read file: {}", e))?; BeaconState::from_ssz_bytes(&ssz).map_err(|e| format!("Unable to decode SSZ: {:?}", e))? }; let mnemonic = mnemonic_from_phrase(mnemonic_phrase)?; let seed = Seed::new(&mnemonic, ""); for (index, validator) in state.validators.iter_mut().enumerate() { let (secret, _) = recover_validator_secret_from_mnemonic(seed.as_bytes(), index as u32, KeyType::Voting) .map_err(|e| format!("Unable to generate validator key: {:?}", e))?; let keypair = keypair_from_secret(secret.as_bytes()) .map_err(|e| format!("Unable build keystore: {:?}", e))?; eprintln!("{}: {}", index, keypair.pk); validator.pubkey = keypair.pk.into(); } let mut file = File::create(path).map_err(|e| format!("Unable to create file: {}", e))?; file.write_all(&state.as_ssz_bytes()) .map_err(|e| format!("Unable to write to file: {}", e))?; Ok(()) }