mirror of
https://github.com/sigp/lighthouse.git
synced 2026-03-10 20:22:02 +00:00
* upgrade clap to v4.5 * cli fixes * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * value parser for mnemonic * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * merge unstable * default --format val * fix eth sim * fix eth sim * merge conflicts * resolve beta compiler issue * add num args, version * add custom flag parser, make rate limiter flags clap friendly * remove unneeded check * fmt * update * alphabetic order * resolve merge conflict * fix test * resolve conflicts * fix test * revert removed if statement * fmt got me again * fix broken flag * make cli * make cli * update * remove -e files * update * cli help updates * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * cli help updates * md files * merge conflict * merge conflicts * md * help text, text width, and a few flag fixes * fmt * merge * revert * revert * resolve merge conflicts * merge conflicts * revert simulator changes * require at least one arg * fix eth sim cli * resolve merge conflicts * book changes * md changes * cli check * cli check * retry cli check * retry cli check * Merge branch 'unstable' of https://github.com/sigp/lighthouse into upgrade-clap-cli * cli * Merge remote-tracking branch 'origin/unstable' into upgrade-clap-cli * Update CLI docs for Goerli removal * Fix cargo lock
70 lines
2.8 KiB
Rust
70 lines
2.8 KiB
Rust
use clap::ArgMatches;
|
|
use clap_utils::{parse_optional, parse_required};
|
|
use ssz::Encode;
|
|
use std::fs::File;
|
|
use std::io::Write;
|
|
use std::time::{SystemTime, UNIX_EPOCH};
|
|
use types::{
|
|
EthSpec, ExecutionPayloadHeader, ExecutionPayloadHeaderBellatrix,
|
|
ExecutionPayloadHeaderCapella, ExecutionPayloadHeaderDeneb, ExecutionPayloadHeaderElectra,
|
|
ForkName,
|
|
};
|
|
|
|
pub fn run<E: EthSpec>(matches: &ArgMatches) -> Result<(), String> {
|
|
let eth1_block_hash = parse_required(matches, "execution-block-hash")?;
|
|
let genesis_time = parse_optional(matches, "genesis-time")?.unwrap_or(
|
|
SystemTime::now()
|
|
.duration_since(UNIX_EPOCH)
|
|
.map_err(|e| format!("Unable to get time: {:?}", e))?
|
|
.as_secs(),
|
|
);
|
|
let base_fee_per_gas = parse_required(matches, "base-fee-per-gas")?;
|
|
let gas_limit = parse_required(matches, "gas-limit")?;
|
|
let file_name = matches
|
|
.get_one::<String>("file")
|
|
.ok_or("No file supplied")?;
|
|
let fork_name: ForkName = parse_optional(matches, "fork")?.unwrap_or(ForkName::Bellatrix);
|
|
|
|
let execution_payload_header: ExecutionPayloadHeader<E> = match fork_name {
|
|
ForkName::Base | ForkName::Altair => return Err("invalid fork name".to_string()),
|
|
ForkName::Bellatrix => ExecutionPayloadHeader::Bellatrix(ExecutionPayloadHeaderBellatrix {
|
|
gas_limit,
|
|
base_fee_per_gas,
|
|
timestamp: genesis_time,
|
|
block_hash: eth1_block_hash,
|
|
prev_randao: eth1_block_hash.into_root(),
|
|
..ExecutionPayloadHeaderBellatrix::default()
|
|
}),
|
|
ForkName::Capella => ExecutionPayloadHeader::Capella(ExecutionPayloadHeaderCapella {
|
|
gas_limit,
|
|
base_fee_per_gas,
|
|
timestamp: genesis_time,
|
|
block_hash: eth1_block_hash,
|
|
prev_randao: eth1_block_hash.into_root(),
|
|
..ExecutionPayloadHeaderCapella::default()
|
|
}),
|
|
ForkName::Deneb => ExecutionPayloadHeader::Deneb(ExecutionPayloadHeaderDeneb {
|
|
gas_limit,
|
|
base_fee_per_gas,
|
|
timestamp: genesis_time,
|
|
block_hash: eth1_block_hash,
|
|
prev_randao: eth1_block_hash.into_root(),
|
|
..ExecutionPayloadHeaderDeneb::default()
|
|
}),
|
|
ForkName::Electra => ExecutionPayloadHeader::Electra(ExecutionPayloadHeaderElectra {
|
|
gas_limit,
|
|
base_fee_per_gas,
|
|
timestamp: genesis_time,
|
|
block_hash: eth1_block_hash,
|
|
prev_randao: eth1_block_hash.into_root(),
|
|
..ExecutionPayloadHeaderElectra::default()
|
|
}),
|
|
};
|
|
|
|
let mut file = File::create(file_name).map_err(|_| "Unable to create file".to_string())?;
|
|
let bytes = execution_payload_header.as_ssz_bytes();
|
|
file.write_all(bytes.as_slice())
|
|
.map_err(|_| "Unable to write to file".to_string())?;
|
|
Ok(())
|
|
}
|