From 9c609545112fd769005da14ebfbccac01518507c Mon Sep 17 00:00:00 2001 From: elfedy Date: Fri, 22 Nov 2024 17:43:29 -0300 Subject: [PATCH 1/3] fix: use zksync_deploy method to set correct tx params --- crates/forge/bin/cmd/create.rs | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/crates/forge/bin/cmd/create.rs b/crates/forge/bin/cmd/create.rs index 2cdb55890..e78b3144d 100644 --- a/crates/forge/bin/cmd/create.rs +++ b/crates/forge/bin/cmd/create.rs @@ -114,7 +114,6 @@ pub struct CreateArgs { pub struct ZkSyncData { #[allow(dead_code)] bytecode: Vec, - bytecode_hash: H256, factory_deps: Vec>, paymaster_params: Option, } @@ -256,7 +255,7 @@ impl CreateArgs { visited_bytecodes.insert(bytecode.clone()); visited_bytecodes.into_iter().collect() }; - let zk_data = ZkSyncData { bytecode, bytecode_hash, factory_deps, paymaster_params }; + let zk_data = ZkSyncData { bytecode, factory_deps, paymaster_params }; return if self.unlocked { // Deploy with unlocked account @@ -661,6 +660,8 @@ impl CreateArgs { self.verify_preflight_check(constructor_args.clone(), chain).await?; } + println!("{:?}", deployer.tx); + // Deploy the actual contract let (deployed_contract, receipt) = deployer.send_with_receipt().await?; @@ -1077,21 +1078,16 @@ where None => Default::default(), Some(constructor) => constructor.abi_encode_input(¶ms).unwrap_or_default(), }; - let data: Bytes = foundry_zksync_core::encode_create_params( - &forge::revm::primitives::CreateScheme::Create, - zk_data.bytecode_hash, - constructor_args, - ) - .into(); - // create the tx object. Since we're deploying a contract, `to` is - // `CONTRACT_DEPLOYER_ADDRESS` - let tx: alloy_zksync::network::transaction_request::TransactionRequest = + let mut tx: alloy_zksync::network::transaction_request::TransactionRequest = TransactionRequest::default() .to(foundry_zksync_core::CONTRACT_DEPLOYER_ADDRESS.to_address()) - .input(data.into()) .into(); + tx = tx + .zksync_deploy(zk_data.bytecode.clone(), constructor_args, zk_data.factory_deps.clone()) + .map_err(|_| ContractDeploymentError::TransactionBuildError)?; + Ok(ZkDeployer { client: self.client.clone(), abi: self.abi, @@ -1116,6 +1112,8 @@ pub enum ContractDeploymentError { ContractNotDeployed, #[error(transparent)] RpcError(#[from] TransportError), + #[error("failed building transaction")] + TransactionBuildError, } impl From for ContractDeploymentError { From 46c3b53052ddf80ad718252d7239213c710c26a4 Mon Sep 17 00:00:00 2001 From: elfedy Date: Fri, 22 Nov 2024 18:32:29 -0300 Subject: [PATCH 2/3] inject tx type on script transactions --- crates/forge/bin/cmd/create.rs | 3 --- crates/script/src/broadcast.rs | 6 ++++-- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/crates/forge/bin/cmd/create.rs b/crates/forge/bin/cmd/create.rs index e78b3144d..e460d0658 100644 --- a/crates/forge/bin/cmd/create.rs +++ b/crates/forge/bin/cmd/create.rs @@ -180,7 +180,6 @@ impl CreateArgs { eyre::bail!("Dynamic linking not supported in `create` command - deploy the following library contracts first, then provide the address to link at compile time\n{}", link_refs) } }; - let bytecode_hash = H256::from_str(&hash.expect("Contract hash not found"))?; // Add arguments to constructor let config = self.eth.try_load_config_emit_warnings()?; @@ -660,8 +659,6 @@ impl CreateArgs { self.verify_preflight_check(constructor_args.clone(), chain).await?; } - println!("{:?}", deployer.tx); - // Deploy the actual contract let (deployed_contract, receipt) = deployer.send_with_receipt().await?; diff --git a/crates/script/src/broadcast.rs b/crates/script/src/broadcast.rs index 7253cddbb..38e279910 100644 --- a/crates/script/src/broadcast.rs +++ b/crates/script/src/broadcast.rs @@ -16,7 +16,7 @@ use alloy_rpc_types::TransactionRequest; use alloy_serde::WithOtherFields; use alloy_transport::Transport; use alloy_zksync::network::{ - transaction_request::TransactionRequest as ZkTransactionRequest, Zksync, + transaction_request::TransactionRequest as ZkTransactionRequest, tx_type::TxType, Zksync, }; use eyre::{bail, Context, Result}; use forge_verify::provider::VerificationProviderType; @@ -119,7 +119,9 @@ pub async fn send_transaction( debug!("sending transaction: {:?}", tx); if let Some(zk) = zk { - let mut zk_tx: ZkTransactionRequest = tx.inner.clone().into(); + let mut inner = tx.inner.clone(); + inner.transaction_type = Some(TxType::Eip712 as u8); + let mut zk_tx: ZkTransactionRequest = inner.into(); if !zk.factory_deps.is_empty() { zk_tx.set_factory_deps(zk.factory_deps.iter().map(Bytes::from_iter).collect()); } From 13a11f380851318f63402fb2fc1ed094c2ccd908 Mon Sep 17 00:00:00 2001 From: elfedy Date: Fri, 22 Nov 2024 18:40:27 -0300 Subject: [PATCH 3/3] clippy --- crates/forge/bin/cmd/create.rs | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/crates/forge/bin/cmd/create.rs b/crates/forge/bin/cmd/create.rs index e460d0658..3721f2726 100644 --- a/crates/forge/bin/cmd/create.rs +++ b/crates/forge/bin/cmd/create.rs @@ -43,10 +43,8 @@ use std::{ collections::{HashSet, VecDeque}, marker::PhantomData, path::PathBuf, - str::FromStr, sync::Arc, }; -use zksync_types::H256; merge_impl_figment_convert!(CreateArgs, opts, eth); @@ -156,7 +154,7 @@ impl CreateArgs { let artifact = remove_zk_contract(&mut zk_output, &target_path, &self.contract.name)?; - let ZkContractArtifact { bytecode, hash, factory_dependencies, abi, .. } = artifact; + let ZkContractArtifact { bytecode, factory_dependencies, abi, .. } = artifact; let abi = abi.expect("Abi not found"); let bin = bytecode.expect("Bytecode not found");