Merge remote-tracking branch 'origin/main' into bugfix/argument-encoding

This commit is contained in:
Omar Abdulla
2025-07-14 20:36:42 +03:00
11 changed files with 402 additions and 139 deletions
+9 -21
View File
@@ -2,10 +2,10 @@ use std::{collections::HashMap, str::FromStr};
use alloy::{
json_abi::JsonAbi,
network::TransactionBuilder,
primitives::{Address, Bytes, U256},
rpc::types::{TransactionInput, TransactionRequest},
rpc::types::TransactionRequest,
};
use alloy_primitives::TxKind;
use semver::VersionReq;
use serde::Deserialize;
use serde_json::Value;
@@ -157,30 +157,18 @@ impl Input {
/// Parse this input into a legacy transaction.
pub fn legacy_transaction(
&self,
chain_id: u64,
nonce: u64,
deployed_contracts: &HashMap<String, Address>,
deployed_abis: &HashMap<String, JsonAbi>,
) -> anyhow::Result<TransactionRequest> {
let to = match self.method {
Method::Deployer => Some(TxKind::Create),
_ => Some(TxKind::Call(
self.instance_to_address(&self.instance, deployed_contracts)?,
)),
};
let input_data = self.encoded_input(deployed_abis, deployed_contracts)?;
Ok(TransactionRequest {
from: Some(self.caller),
to,
nonce: Some(nonce),
chain_id: Some(chain_id),
gas_price: Some(5_000_000),
gas: Some(5_000_000),
input: TransactionInput::new(input_data),
..Default::default()
})
let transaction_request = TransactionRequest::default().nonce(nonce);
match self.method {
Method::Deployer => Ok(transaction_request.with_deploy_code(input_data)),
_ => Ok(transaction_request
.to(self.instance_to_address(&self.instance, deployed_contracts)?)
.input(input_data.into())),
}
}
}