diff --git a/light-client/src/client.rs b/light-client/src/client.rs index 60e9f68..5ebe356 100644 --- a/light-client/src/client.rs +++ b/light-client/src/client.rs @@ -606,7 +606,7 @@ mod test { fn test_error_create_client() { let client_state = hex!("0a272f6962632e6c69676874636c69656e74732e7061726c69612e76312e436c69656e745374617465124d08381214151f3951fa218cac426edfe078fa9e5c6dcea5001a2000000000000000000000000000000000000000000000000000000000000000002205109b9ea90f2a040880a305320410c0843d").to_vec(); let consensus_state = hex!("0a2a2f6962632e6c69676874636c69656e74732e7061726c69612e76312e436f6e73656e7375735374617465126c0a2056e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b42110de82d5a8061a209c59cf0b5717cb6e2bd8620b7f3481605c8abcd45636bdf45c86db06338f0c5e22207a1dede35f5c835fecdc768324928cd0d9d9161e8529e1ba1e60451f3a9d088a").to_vec(); - let client = ParliaLightClient::default(); + let client = ParliaLightClient; let mock_consensus_state = BTreeMap::new(); let ctx = MockClientReader { client_state: None, diff --git a/light-client/src/header/eth_header.rs b/light-client/src/header/eth_header.rs index 0355878..ba3d7e1 100644 --- a/light-client/src/header/eth_header.rs +++ b/light-client/src/header/eth_header.rs @@ -58,6 +58,7 @@ pub struct ETHHeader { pub blob_gas_used: Option, pub excess_blob_gas: Option, pub parent_beacon_root: Option>, + pub requests_hash: Option>, // calculated by RawETHHeader pub hash: Hash, @@ -133,6 +134,11 @@ impl ETHHeader { stream.append_empty_data(); } stream.append(parent_beacon_root); + + // https://github.com/bnb-chain/bsc/blob/e2f2111a85fecabb4782099338aca21bf58bde09/core/types/block.go#L776 + if let Some(value) = &self.requests_hash { + stream.append(value); + } } } stream.finalize_unbounded_list(); @@ -378,6 +384,7 @@ impl TryFrom for ETHHeader { let blob_gas_used: Option = rlp.try_next_as_val().map(Some).unwrap_or(None); let excess_blob_gas: Option = rlp.try_next_as_val().map(Some).unwrap_or(None); let parent_beacon_root: Option> = rlp.try_next_as_val().map(Some).unwrap_or(None); + let requests_hash: Option> = rlp.try_next_as_val().map(Some).unwrap_or(None); // Check that the extra-data contains the vanity, validators and signature let extra_size = extra_data.len(); @@ -415,72 +422,7 @@ impl TryFrom for ETHHeader { return Err(Error::UnexpectedNonce(number)); } - // create block hash - let mut stream = RlpStream::new(); - stream.begin_unbounded_list(); - stream.append(&parent_hash); - stream.append(&uncle_hash); - stream.append(&coinbase); - stream.append(&root.to_vec()); - stream.append(&tx_hash); - stream.append(&receipt_hash); - stream.append(&bloom); - stream.append(&difficulty); - stream.append(&number); - stream.append(&gas_limit); - stream.append(&gas_used); - stream.append(×tamp); - stream.append(&extra_data); - stream.append(&mix_digest); - stream.append(&nonce); - - if base_fee_per_gas.is_some() - || withdrawals_hash.is_some() - || blob_gas_used.is_some() - || excess_blob_gas.is_some() - || parent_beacon_root.is_some() - { - if let Some(v) = base_fee_per_gas { - stream.append(&v); - } else { - stream.append_empty_data(); - } - } - if withdrawals_hash.is_some() - || blob_gas_used.is_some() - || excess_blob_gas.is_some() - || parent_beacon_root.is_some() - { - if let Some(v) = &withdrawals_hash { - stream.append(v); - } else { - stream.append_empty_data(); - } - } - if blob_gas_used.is_some() || excess_blob_gas.is_some() || parent_beacon_root.is_some() { - if let Some(v) = blob_gas_used { - stream.append(&v); - } else { - stream.append_empty_data(); - } - } - if excess_blob_gas.is_some() || parent_beacon_root.is_some() { - if let Some(v) = excess_blob_gas { - stream.append(&v); - } else { - stream.append_empty_data(); - } - } - if parent_beacon_root.is_some() { - if let Some(v) = &parent_beacon_root { - stream.append(v); - } else { - stream.append_empty_data(); - } - } - stream.finalize_unbounded_list(); - let buffer_vec: Vec = stream.out().to_vec(); - let hash: Hash = keccak_256(&buffer_vec); + let hash: Hash = keccak_256(value.header.as_slice()); let epoch = if number % BLOCKS_PER_EPOCH == 0 { let (validators, turn_length) = get_validator_bytes_and_turn_length(&extra_data)?; @@ -510,6 +452,7 @@ impl TryFrom for ETHHeader { withdrawals_hash, blob_gas_used, parent_beacon_root, + requests_hash, hash, epoch, }) diff --git a/light-client/src/header/vote_attestation.rs b/light-client/src/header/vote_attestation.rs index fb05570..e6aa6fc 100644 --- a/light-client/src/header/vote_attestation.rs +++ b/light-client/src/header/vote_attestation.rs @@ -242,6 +242,7 @@ mod test { blob_gas_used: None, excess_blob_gas: None, parent_beacon_root: None, + requests_hash: None, hash: [0u8; 32], epoch: None, };