Skip to content

Commit

Permalink
feat: adds bundle helper submission call
Browse files Browse the repository at this point in the history
  • Loading branch information
dylanlott committed Dec 12, 2024
1 parent dfa90a0 commit da4b819
Showing 1 changed file with 22 additions and 7 deletions.
29 changes: 22 additions & 7 deletions src/tasks/submit.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@ use alloy::{
consensus::{constants::GWEI_TO_WEI, SimpleCoder},
eips::BlockNumberOrTag,
network::{TransactionBuilder, TransactionBuilder4844},
providers::Provider as _,
providers::SendableTx,
providers::{Provider as _, WalletProvider},
rpc::types::eth::TransactionRequest,
signers::Signer,
sol_types::SolCall,
Expand All @@ -23,6 +23,7 @@ use std::time::Instant;
use tokio::{sync::mpsc, task::JoinHandle};
use tracing::{debug, error, instrument, trace};
use zenith_types::{
bundle_helper::{submitCall, BlockHeader, FillPermit2},
SignRequest, SignResponse,
Zenith::{self, IncorrectHostBlock},
};
Expand Down Expand Up @@ -142,19 +143,33 @@ impl SubmitTask {
let r: FixedBytes<32> = resp.sig.r().into();
let s: FixedBytes<32> = resp.sig.s().into();

let header = Zenith::BlockHeader {
// TODO: Build fills
let fills: Vec<FillPermit2> = vec![];

let header = BlockHeader {
hostBlockNumber: resp.req.host_block_number,
rollupChainId: U256::from(self.config.ru_chain_id),
gasLimit: resp.req.gas_limit,
rewardAddress: resp.req.ru_reward_address,
blockDataHash: in_progress.contents_hash(),
};

let tx = self
.build_blob_tx(header, v, r, s, in_progress)?
.with_from(self.provider.default_signer_address())
.with_to(self.config.zenith_address)
.with_gas_limit(1_000_000);
let submit_call = submitCall { fills, header, v, r, s }.abi_encode();

let tx = TransactionRequest::default()
.with_input(submit_call)
.with_max_priority_fee_per_gas((GWEI_TO_WEI * 16) as u128);

if let Err(TransportError::ErrorResp(e)) =
self.provider.call(&tx).block(BlockNumberOrTag::Pending.into()).await
{
error!(
code = e.code,
message = %e.message,
data = ?e.data,
"error in transaction submission"
);
}

if let Err(TransportError::ErrorResp(e)) =
self.provider.call(&tx).block(BlockNumberOrTag::Pending.into()).await
Expand Down

0 comments on commit da4b819

Please sign in to comment.