Merge branch 'json-rpc-blobs-updates' of https://github.com/realbigsean/lighthouse into blob-syncing
This commit is contained in:
commit
ce097ac8d2
@ -154,8 +154,8 @@ pub struct ExecutionBlockWithTransactions<T: EthSpec> {
|
|||||||
pub extra_data: VariableList<u8, T::MaxExtraDataBytes>,
|
pub extra_data: VariableList<u8, T::MaxExtraDataBytes>,
|
||||||
pub base_fee_per_gas: Uint256,
|
pub base_fee_per_gas: Uint256,
|
||||||
#[superstruct(only(Eip4844))]
|
#[superstruct(only(Eip4844))]
|
||||||
#[serde(with = "eth2_serde_utils::u64_hex_be")]
|
#[serde(with = "eth2_serde_utils::u256_hex_be")]
|
||||||
pub excess_blobs: u64,
|
pub excess_data_gas: Uint256,
|
||||||
#[serde(rename = "hash")]
|
#[serde(rename = "hash")]
|
||||||
pub block_hash: ExecutionBlockHash,
|
pub block_hash: ExecutionBlockHash,
|
||||||
pub transactions: Vec<Transaction>,
|
pub transactions: Vec<Transaction>,
|
||||||
@ -227,7 +227,7 @@ impl<T: EthSpec> From<ExecutionPayload<T>> for ExecutionBlockWithTransactions<T>
|
|||||||
timestamp: block.timestamp,
|
timestamp: block.timestamp,
|
||||||
extra_data: block.extra_data,
|
extra_data: block.extra_data,
|
||||||
base_fee_per_gas: block.base_fee_per_gas,
|
base_fee_per_gas: block.base_fee_per_gas,
|
||||||
excess_blobs: block.excess_blobs,
|
excess_data_gas: block.excess_data_gas,
|
||||||
block_hash: block.block_hash,
|
block_hash: block.block_hash,
|
||||||
transactions: block
|
transactions: block
|
||||||
.transactions
|
.transactions
|
||||||
|
@ -857,7 +857,6 @@ impl HttpJsonRpc {
|
|||||||
) -> Result<PayloadStatusV1, Error> {
|
) -> Result<PayloadStatusV1, Error> {
|
||||||
let supported_apis = self.get_cached_supported_apis().await?;
|
let supported_apis = self.get_cached_supported_apis().await?;
|
||||||
if supported_apis.new_payload_v2 {
|
if supported_apis.new_payload_v2 {
|
||||||
// FIXME: I haven't thought at all about how to handle 4844..
|
|
||||||
self.new_payload_v2(execution_payload).await
|
self.new_payload_v2(execution_payload).await
|
||||||
} else if supported_apis.new_payload_v1 {
|
} else if supported_apis.new_payload_v1 {
|
||||||
self.new_payload_v1(execution_payload).await
|
self.new_payload_v1(execution_payload).await
|
||||||
@ -875,7 +874,6 @@ impl HttpJsonRpc {
|
|||||||
) -> Result<ExecutionPayload<T>, Error> {
|
) -> Result<ExecutionPayload<T>, Error> {
|
||||||
let supported_apis = self.get_cached_supported_apis().await?;
|
let supported_apis = self.get_cached_supported_apis().await?;
|
||||||
if supported_apis.get_payload_v2 {
|
if supported_apis.get_payload_v2 {
|
||||||
// FIXME: I haven't thought at all about how to handle 4844..
|
|
||||||
self.get_payload_v2(fork_name, payload_id).await
|
self.get_payload_v2(fork_name, payload_id).await
|
||||||
} else if supported_apis.new_payload_v1 {
|
} else if supported_apis.new_payload_v1 {
|
||||||
self.get_payload_v1(fork_name, payload_id).await
|
self.get_payload_v1(fork_name, payload_id).await
|
||||||
@ -893,7 +891,6 @@ impl HttpJsonRpc {
|
|||||||
) -> Result<ForkchoiceUpdatedResponse, Error> {
|
) -> Result<ForkchoiceUpdatedResponse, Error> {
|
||||||
let supported_apis = self.get_cached_supported_apis().await?;
|
let supported_apis = self.get_cached_supported_apis().await?;
|
||||||
if supported_apis.forkchoice_updated_v2 {
|
if supported_apis.forkchoice_updated_v2 {
|
||||||
// FIXME: I haven't thought at all about how to handle 4844..
|
|
||||||
self.forkchoice_updated_v2(forkchoice_state, payload_attributes)
|
self.forkchoice_updated_v2(forkchoice_state, payload_attributes)
|
||||||
.await
|
.await
|
||||||
} else if supported_apis.forkchoice_updated_v1 {
|
} else if supported_apis.forkchoice_updated_v1 {
|
||||||
|
@ -64,7 +64,7 @@ pub struct JsonPayloadIdResponse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[superstruct(
|
#[superstruct(
|
||||||
variants(V1, V2, V3),
|
variants(V1, V2),
|
||||||
variant_attributes(
|
variant_attributes(
|
||||||
derive(Debug, PartialEq, Default, Serialize, Deserialize,),
|
derive(Debug, PartialEq, Default, Serialize, Deserialize,),
|
||||||
serde(bound = "T: EthSpec", rename_all = "camelCase"),
|
serde(bound = "T: EthSpec", rename_all = "camelCase"),
|
||||||
@ -94,15 +94,18 @@ pub struct JsonExecutionPayload<T: EthSpec> {
|
|||||||
pub extra_data: VariableList<u8, T::MaxExtraDataBytes>,
|
pub extra_data: VariableList<u8, T::MaxExtraDataBytes>,
|
||||||
#[serde(with = "eth2_serde_utils::u256_hex_be")]
|
#[serde(with = "eth2_serde_utils::u256_hex_be")]
|
||||||
pub base_fee_per_gas: Uint256,
|
pub base_fee_per_gas: Uint256,
|
||||||
#[superstruct(only(V3))]
|
#[superstruct(only(V2))]
|
||||||
// FIXME: can't easily make this an option because of custom deserialization..
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
#[serde(with = "eth2_serde_utils::u64_hex_be")]
|
#[serde(default)]
|
||||||
pub excess_blobs: u64,
|
#[serde(with = "eth2_serde_utils::u256_hex_be_opt")]
|
||||||
|
pub excess_data_gas: Option<Uint256>,
|
||||||
pub block_hash: ExecutionBlockHash,
|
pub block_hash: ExecutionBlockHash,
|
||||||
#[serde(with = "ssz_types::serde_utils::list_of_hex_var_list")]
|
#[serde(with = "ssz_types::serde_utils::list_of_hex_var_list")]
|
||||||
pub transactions:
|
pub transactions:
|
||||||
VariableList<Transaction<T::MaxBytesPerTransaction>, T::MaxTransactionsPerPayload>,
|
VariableList<Transaction<T::MaxBytesPerTransaction>, T::MaxTransactionsPerPayload>,
|
||||||
#[superstruct(only(V2, V3))]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
#[serde(default)]
|
||||||
|
#[superstruct(only(V2))]
|
||||||
pub withdrawals: Option<VariableList<JsonWithdrawal, T::MaxWithdrawalsPerPayload>>,
|
pub withdrawals: Option<VariableList<JsonWithdrawal, T::MaxWithdrawalsPerPayload>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,43 +178,24 @@ impl<T: EthSpec> JsonExecutionPayload<T> {
|
|||||||
})
|
})
|
||||||
.ok_or(Error::BadConversion("Null withdrawal field converting JsonExecutionPayloadV2 -> ExecutionPayloadCapella".to_string()))?
|
.ok_or(Error::BadConversion("Null withdrawal field converting JsonExecutionPayloadV2 -> ExecutionPayloadCapella".to_string()))?
|
||||||
})),
|
})),
|
||||||
ForkName::Eip4844 => Err(Error::UnsupportedForkVariant("JsonExecutionPayloadV2 -> ExecutionPayloadEip4844 not implemented yet as it might never be".to_string())),
|
ForkName::Eip4844 => Ok(ExecutionPayload::Eip4844(ExecutionPayloadEip4844 {
|
||||||
_ => Err(Error::UnsupportedForkVariant(format!("Unsupported conversion from JsonExecutionPayloadV2 for {}", fork_name))),
|
parent_hash: v2.parent_hash,
|
||||||
}
|
fee_recipient: v2.fee_recipient,
|
||||||
JsonExecutionPayload::V3(v3) => match fork_name {
|
state_root: v2.state_root,
|
||||||
ForkName::Merge => Ok(ExecutionPayload::Merge(ExecutionPayloadMerge {
|
receipts_root: v2.receipts_root,
|
||||||
parent_hash: v3.parent_hash,
|
logs_bloom: v2.logs_bloom,
|
||||||
fee_recipient: v3.fee_recipient,
|
prev_randao: v2.prev_randao,
|
||||||
state_root: v3.state_root,
|
block_number: v2.block_number,
|
||||||
receipts_root: v3.receipts_root,
|
gas_limit: v2.gas_limit,
|
||||||
logs_bloom: v3.logs_bloom,
|
gas_used: v2.gas_used,
|
||||||
prev_randao: v3.prev_randao,
|
timestamp: v2.timestamp,
|
||||||
block_number: v3.block_number,
|
extra_data: v2.extra_data,
|
||||||
gas_limit: v3.gas_limit,
|
base_fee_per_gas: v2.base_fee_per_gas,
|
||||||
gas_used: v3.gas_used,
|
excess_data_gas: v2.excess_data_gas.ok_or(Error::BadConversion("Null `excess_data_gas` field converting JsonExecutionPayloadV2 -> ExecutionPayloadEip4844".to_string()))?,
|
||||||
timestamp: v3.timestamp,
|
block_hash: v2.block_hash,
|
||||||
extra_data: v3.extra_data,
|
transactions: v2.transactions,
|
||||||
base_fee_per_gas: v3.base_fee_per_gas,
|
|
||||||
block_hash: v3.block_hash,
|
|
||||||
transactions: v3.transactions,
|
|
||||||
})),
|
|
||||||
ForkName::Capella => Ok(ExecutionPayload::Capella(ExecutionPayloadCapella {
|
|
||||||
parent_hash: v3.parent_hash,
|
|
||||||
fee_recipient: v3.fee_recipient,
|
|
||||||
state_root: v3.state_root,
|
|
||||||
receipts_root: v3.receipts_root,
|
|
||||||
logs_bloom: v3.logs_bloom,
|
|
||||||
prev_randao: v3.prev_randao,
|
|
||||||
block_number: v3.block_number,
|
|
||||||
gas_limit: v3.gas_limit,
|
|
||||||
gas_used: v3.gas_used,
|
|
||||||
timestamp: v3.timestamp,
|
|
||||||
extra_data: v3.extra_data,
|
|
||||||
base_fee_per_gas: v3.base_fee_per_gas,
|
|
||||||
block_hash: v3.block_hash,
|
|
||||||
transactions: v3.transactions,
|
|
||||||
#[cfg(feature = "withdrawals")]
|
#[cfg(feature = "withdrawals")]
|
||||||
withdrawals: v3
|
withdrawals: v2
|
||||||
.withdrawals
|
.withdrawals
|
||||||
.map(|v| {
|
.map(|v| {
|
||||||
Into::<Vec<_>>::into(v)
|
Into::<Vec<_>>::into(v)
|
||||||
@ -220,36 +204,7 @@ impl<T: EthSpec> JsonExecutionPayload<T> {
|
|||||||
.collect::<Vec<_>>()
|
.collect::<Vec<_>>()
|
||||||
.into()
|
.into()
|
||||||
})
|
})
|
||||||
.ok_or(Error::BadConversion("Null withdrawal field converting JsonExecutionPayloadV3 -> ExecutionPayloadCapella".to_string()))?
|
.ok_or(Error::BadConversion("Null withdrawal field converting JsonExecutionPayloadV2 -> ExecutionPayloadEip4844".to_string()))?
|
||||||
})),
|
|
||||||
ForkName::Eip4844 => Ok(ExecutionPayload::Eip4844(ExecutionPayloadEip4844 {
|
|
||||||
parent_hash: v3.parent_hash,
|
|
||||||
fee_recipient: v3.fee_recipient,
|
|
||||||
state_root: v3.state_root,
|
|
||||||
receipts_root: v3.receipts_root,
|
|
||||||
logs_bloom: v3.logs_bloom,
|
|
||||||
prev_randao: v3.prev_randao,
|
|
||||||
block_number: v3.block_number,
|
|
||||||
gas_limit: v3.gas_limit,
|
|
||||||
gas_used: v3.gas_used,
|
|
||||||
timestamp: v3.timestamp,
|
|
||||||
extra_data: v3.extra_data,
|
|
||||||
base_fee_per_gas: v3.base_fee_per_gas,
|
|
||||||
// FIXME: excess_blobs probably will be an option whenever the engine API is finalized
|
|
||||||
excess_blobs: v3.excess_blobs,
|
|
||||||
block_hash: v3.block_hash,
|
|
||||||
transactions: v3.transactions,
|
|
||||||
#[cfg(feature = "withdrawals")]
|
|
||||||
withdrawals: v3
|
|
||||||
.withdrawals
|
|
||||||
.map(|v| {
|
|
||||||
Vec::from(v)
|
|
||||||
.into_iter()
|
|
||||||
.map(Into::into)
|
|
||||||
.collect::<Vec<_>>()
|
|
||||||
.into()
|
|
||||||
})
|
|
||||||
.ok_or(Error::BadConversion("Null withdrawal field converting JsonExecutionPayloadV3 -> ExecutionPayloadEip4844".to_string()))?,
|
|
||||||
})),
|
})),
|
||||||
_ => Err(Error::UnsupportedForkVariant(format!("Unsupported conversion from JsonExecutionPayloadV2 for {}", fork_name))),
|
_ => Err(Error::UnsupportedForkVariant(format!("Unsupported conversion from JsonExecutionPayloadV2 for {}", fork_name))),
|
||||||
}
|
}
|
||||||
@ -306,6 +261,7 @@ impl<T: EthSpec> TryFrom<ExecutionPayload<T>> for JsonExecutionPayloadV2<T> {
|
|||||||
timestamp: merge.timestamp,
|
timestamp: merge.timestamp,
|
||||||
extra_data: merge.extra_data,
|
extra_data: merge.extra_data,
|
||||||
base_fee_per_gas: merge.base_fee_per_gas,
|
base_fee_per_gas: merge.base_fee_per_gas,
|
||||||
|
excess_data_gas: None,
|
||||||
block_hash: merge.block_hash,
|
block_hash: merge.block_hash,
|
||||||
transactions: merge.transactions,
|
transactions: merge.transactions,
|
||||||
withdrawals: None,
|
withdrawals: None,
|
||||||
@ -323,6 +279,7 @@ impl<T: EthSpec> TryFrom<ExecutionPayload<T>> for JsonExecutionPayloadV2<T> {
|
|||||||
timestamp: capella.timestamp,
|
timestamp: capella.timestamp,
|
||||||
extra_data: capella.extra_data,
|
extra_data: capella.extra_data,
|
||||||
base_fee_per_gas: capella.base_fee_per_gas,
|
base_fee_per_gas: capella.base_fee_per_gas,
|
||||||
|
excess_data_gas: None,
|
||||||
block_hash: capella.block_hash,
|
block_hash: capella.block_hash,
|
||||||
transactions: capella.transactions,
|
transactions: capella.transactions,
|
||||||
#[cfg(feature = "withdrawals")]
|
#[cfg(feature = "withdrawals")]
|
||||||
@ -336,10 +293,33 @@ impl<T: EthSpec> TryFrom<ExecutionPayload<T>> for JsonExecutionPayloadV2<T> {
|
|||||||
#[cfg(not(feature = "withdrawals"))]
|
#[cfg(not(feature = "withdrawals"))]
|
||||||
withdrawals: None,
|
withdrawals: None,
|
||||||
}),
|
}),
|
||||||
ExecutionPayload::Eip4844(_) => Err(Error::UnsupportedForkVariant(format!(
|
ExecutionPayload::Eip4844(eip4844) => Ok(JsonExecutionPayloadV2 {
|
||||||
"Unsupported conversion to JsonExecutionPayloadV1 for {}",
|
parent_hash: eip4844.parent_hash,
|
||||||
ForkName::Eip4844
|
fee_recipient: eip4844.fee_recipient,
|
||||||
))),
|
state_root: eip4844.state_root,
|
||||||
|
receipts_root: eip4844.receipts_root,
|
||||||
|
logs_bloom: eip4844.logs_bloom,
|
||||||
|
prev_randao: eip4844.prev_randao,
|
||||||
|
block_number: eip4844.block_number,
|
||||||
|
gas_limit: eip4844.gas_limit,
|
||||||
|
gas_used: eip4844.gas_used,
|
||||||
|
timestamp: eip4844.timestamp,
|
||||||
|
extra_data: eip4844.extra_data,
|
||||||
|
base_fee_per_gas: eip4844.base_fee_per_gas,
|
||||||
|
excess_data_gas: Some(eip4844.excess_data_gas),
|
||||||
|
block_hash: eip4844.block_hash,
|
||||||
|
transactions: eip4844.transactions,
|
||||||
|
#[cfg(feature = "withdrawals")]
|
||||||
|
withdrawals: Some(
|
||||||
|
Vec::from(eip4844.withdrawals)
|
||||||
|
.into_iter()
|
||||||
|
.map(Into::into)
|
||||||
|
.collect::<Vec<_>>()
|
||||||
|
.into(),
|
||||||
|
),
|
||||||
|
#[cfg(not(feature = "withdrawals"))]
|
||||||
|
withdrawals: None,
|
||||||
|
}),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1589,7 +1589,7 @@ impl<T: EthSpec> ExecutionLayer<T> {
|
|||||||
timestamp: eip4844_block.timestamp,
|
timestamp: eip4844_block.timestamp,
|
||||||
extra_data: eip4844_block.extra_data,
|
extra_data: eip4844_block.extra_data,
|
||||||
base_fee_per_gas: eip4844_block.base_fee_per_gas,
|
base_fee_per_gas: eip4844_block.base_fee_per_gas,
|
||||||
excess_blobs: eip4844_block.excess_blobs,
|
excess_data_gas: eip4844_block.excess_data_gas,
|
||||||
block_hash: eip4844_block.block_hash,
|
block_hash: eip4844_block.block_hash,
|
||||||
transactions,
|
transactions,
|
||||||
#[cfg(feature = "withdrawals")]
|
#[cfg(feature = "withdrawals")]
|
||||||
|
@ -7,6 +7,7 @@ pub mod json_str;
|
|||||||
pub mod list_of_bytes_lists;
|
pub mod list_of_bytes_lists;
|
||||||
pub mod quoted_u64_vec;
|
pub mod quoted_u64_vec;
|
||||||
pub mod u256_hex_be;
|
pub mod u256_hex_be;
|
||||||
|
pub mod u256_hex_be_opt;
|
||||||
pub mod u32_hex;
|
pub mod u32_hex;
|
||||||
pub mod u64_hex_be;
|
pub mod u64_hex_be;
|
||||||
pub mod u8_hex;
|
pub mod u8_hex;
|
||||||
|
169
consensus/serde_utils/src/u256_hex_be_opt.rs
Normal file
169
consensus/serde_utils/src/u256_hex_be_opt.rs
Normal file
@ -0,0 +1,169 @@
|
|||||||
|
use ethereum_types::U256;
|
||||||
|
|
||||||
|
use serde::de::Visitor;
|
||||||
|
use serde::{de, Deserializer, Serialize, Serializer};
|
||||||
|
use std::fmt;
|
||||||
|
use std::str::FromStr;
|
||||||
|
|
||||||
|
pub fn serialize<S>(num: &Option<U256>, serializer: S) -> Result<S::Ok, S::Error>
|
||||||
|
where
|
||||||
|
S: Serializer,
|
||||||
|
{
|
||||||
|
num.serialize(serializer)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub struct U256Visitor;
|
||||||
|
|
||||||
|
impl<'de> Visitor<'de> for U256Visitor {
|
||||||
|
type Value = String;
|
||||||
|
|
||||||
|
fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
formatter.write_str("a well formatted hex string")
|
||||||
|
}
|
||||||
|
|
||||||
|
fn visit_str<E>(self, value: &str) -> Result<Self::Value, E>
|
||||||
|
where
|
||||||
|
E: de::Error,
|
||||||
|
{
|
||||||
|
if !value.starts_with("0x") {
|
||||||
|
return Err(de::Error::custom("must start with 0x"));
|
||||||
|
}
|
||||||
|
let stripped = &value[2..];
|
||||||
|
if stripped.is_empty() {
|
||||||
|
Err(de::Error::custom(format!(
|
||||||
|
"quantity cannot be {:?}",
|
||||||
|
stripped
|
||||||
|
)))
|
||||||
|
} else if stripped == "0" {
|
||||||
|
Ok(value.to_string())
|
||||||
|
} else if stripped.starts_with('0') {
|
||||||
|
Err(de::Error::custom("cannot have leading zero"))
|
||||||
|
} else {
|
||||||
|
Ok(value.to_string())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn deserialize<'de, D>(deserializer: D) -> Result<Option<U256>, D::Error>
|
||||||
|
where
|
||||||
|
D: Deserializer<'de>,
|
||||||
|
{
|
||||||
|
let decoded = deserializer.deserialize_string(U256Visitor)?;
|
||||||
|
|
||||||
|
Some(
|
||||||
|
U256::from_str(&decoded)
|
||||||
|
.map_err(|e| de::Error::custom(format!("Invalid U256 string: {}", e))),
|
||||||
|
)
|
||||||
|
.transpose()
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod test {
|
||||||
|
use ethereum_types::U256;
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
use serde_json;
|
||||||
|
|
||||||
|
#[derive(Debug, PartialEq, Serialize, Deserialize)]
|
||||||
|
#[serde(transparent)]
|
||||||
|
struct Wrapper {
|
||||||
|
#[serde(with = "super")]
|
||||||
|
val: Option<U256>,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn encoding() {
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(0.into())
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0x0\""
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(1.into())
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0x1\""
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(256.into())
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0x100\""
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(65.into())
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0x41\""
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(1024.into())
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0x400\""
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(U256::max_value() - 1)
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe\""
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
&serde_json::to_string(&Wrapper {
|
||||||
|
val: Some(U256::max_value())
|
||||||
|
})
|
||||||
|
.unwrap(),
|
||||||
|
"\"0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff\""
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn decoding() {
|
||||||
|
assert_eq!(
|
||||||
|
serde_json::from_str::<Wrapper>("\"0x0\"").unwrap(),
|
||||||
|
Wrapper {
|
||||||
|
val: Some(0.into())
|
||||||
|
},
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
serde_json::from_str::<Wrapper>("\"0x41\"").unwrap(),
|
||||||
|
Wrapper {
|
||||||
|
val: Some(65.into())
|
||||||
|
},
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
serde_json::from_str::<Wrapper>("\"0x400\"").unwrap(),
|
||||||
|
Wrapper {
|
||||||
|
val: Some(1024.into())
|
||||||
|
},
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
serde_json::from_str::<Wrapper>(
|
||||||
|
"\"0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe\""
|
||||||
|
)
|
||||||
|
.unwrap(),
|
||||||
|
Wrapper {
|
||||||
|
val: Some(U256::max_value() - 1)
|
||||||
|
},
|
||||||
|
);
|
||||||
|
assert_eq!(
|
||||||
|
serde_json::from_str::<Wrapper>(
|
||||||
|
"\"0xffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff\""
|
||||||
|
)
|
||||||
|
.unwrap(),
|
||||||
|
Wrapper {
|
||||||
|
val: Some(U256::max_value())
|
||||||
|
},
|
||||||
|
);
|
||||||
|
serde_json::from_str::<Wrapper>("\"0x\"").unwrap_err();
|
||||||
|
serde_json::from_str::<Wrapper>("\"0x0400\"").unwrap_err();
|
||||||
|
serde_json::from_str::<Wrapper>("\"400\"").unwrap_err();
|
||||||
|
serde_json::from_str::<Wrapper>("\"ff\"").unwrap_err();
|
||||||
|
}
|
||||||
|
}
|
@ -74,9 +74,9 @@ pub struct ExecutionPayload<T: EthSpec> {
|
|||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
pub base_fee_per_gas: Uint256,
|
pub base_fee_per_gas: Uint256,
|
||||||
#[superstruct(only(Eip4844))]
|
#[superstruct(only(Eip4844))]
|
||||||
#[serde(with = "eth2_serde_utils::quoted_u64")]
|
#[serde(with = "eth2_serde_utils::quoted_u256")]
|
||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
pub excess_blobs: u64,
|
pub excess_data_gas: Uint256,
|
||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
pub block_hash: ExecutionBlockHash,
|
pub block_hash: ExecutionBlockHash,
|
||||||
#[serde(with = "ssz_types::serde_utils::list_of_hex_var_list")]
|
#[serde(with = "ssz_types::serde_utils::list_of_hex_var_list")]
|
||||||
|
@ -68,9 +68,9 @@ pub struct ExecutionPayloadHeader<T: EthSpec> {
|
|||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
pub base_fee_per_gas: Uint256,
|
pub base_fee_per_gas: Uint256,
|
||||||
#[superstruct(only(Eip4844))]
|
#[superstruct(only(Eip4844))]
|
||||||
#[serde(with = "eth2_serde_utils::quoted_u64")]
|
#[serde(with = "eth2_serde_utils::quoted_u256")]
|
||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
pub excess_blobs: u64,
|
pub excess_data_gas: Uint256,
|
||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
pub block_hash: ExecutionBlockHash,
|
pub block_hash: ExecutionBlockHash,
|
||||||
#[superstruct(getter(copy))]
|
#[superstruct(getter(copy))]
|
||||||
@ -150,7 +150,7 @@ impl<T: EthSpec> ExecutionPayloadHeaderCapella<T> {
|
|||||||
extra_data: self.extra_data.clone(),
|
extra_data: self.extra_data.clone(),
|
||||||
base_fee_per_gas: self.base_fee_per_gas,
|
base_fee_per_gas: self.base_fee_per_gas,
|
||||||
// TODO: verify if this is correct
|
// TODO: verify if this is correct
|
||||||
excess_blobs: 0,
|
excess_data_gas: Uint256::zero(),
|
||||||
block_hash: self.block_hash,
|
block_hash: self.block_hash,
|
||||||
transactions_root: self.transactions_root,
|
transactions_root: self.transactions_root,
|
||||||
#[cfg(feature = "withdrawals")]
|
#[cfg(feature = "withdrawals")]
|
||||||
@ -216,7 +216,7 @@ impl<T: EthSpec> From<ExecutionPayloadEip4844<T>> for ExecutionPayloadHeaderEip4
|
|||||||
timestamp: payload.timestamp,
|
timestamp: payload.timestamp,
|
||||||
extra_data: payload.extra_data,
|
extra_data: payload.extra_data,
|
||||||
base_fee_per_gas: payload.base_fee_per_gas,
|
base_fee_per_gas: payload.base_fee_per_gas,
|
||||||
excess_blobs: payload.excess_blobs,
|
excess_data_gas: payload.excess_data_gas,
|
||||||
block_hash: payload.block_hash,
|
block_hash: payload.block_hash,
|
||||||
transactions_root: payload.transactions.tree_hash_root(),
|
transactions_root: payload.transactions.tree_hash_root(),
|
||||||
#[cfg(feature = "withdrawals")]
|
#[cfg(feature = "withdrawals")]
|
||||||
|
Loading…
Reference in New Issue
Block a user