Skip to content

Commit

Permalink
install transaction injector to builder service
Browse files Browse the repository at this point in the history
  • Loading branch information
ralexstokes committed Feb 28, 2023
1 parent 57e94a1 commit cbe75d1
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 2 deletions.
5 changes: 5 additions & 0 deletions example.config.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,3 +20,8 @@ secret_key = "0x14b6e79cbc6267c6e527b4bf7a71747d42a58b10279366cf0c7bb4e2aa455901
host = "0.0.0.0"
port = 8551
engine_api_endpoint = "http://127.0.0.1:8552"

[builder.transaction_injector]
mnemonic = "work man father plunge mystery proud hollow address reunion sauce theory bonus"
chain_id = 1337
provider_url = "http://127.0.0.1:8545"
30 changes: 28 additions & 2 deletions mev-build-rs/src/service.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ use mev_rs::{
Client as HttpClient, Config as EngineApiProxyConfig, Proxy, Server as EngineApiProxy,
},
},
transaction_injector::{Config as TransactionInjectorConfig, Injector as TransactionInjector},
Error, Network,
};
use serde::Deserialize;
Expand All @@ -31,6 +32,8 @@ pub struct Config {
pub network: Network,
pub engine_api_proxy: EngineApiProxyConfig,
pub secret_key: SecretKey,
#[serde(default)]
pub transaction_injector: Option<TransactionInjectorConfig>,
}

impl fmt::Debug for Config {
Expand All @@ -42,6 +45,7 @@ impl fmt::Debug for Config {
.field("network", &self.network)
.field("engine_api_proxy", &self.engine_api_proxy)
.field("secret_key", &"...")
.field("transaction_injector", &self.transaction_injector)
.finish()
}
}
Expand All @@ -55,6 +59,7 @@ impl Default for Config {
network: Default::default(),
engine_api_proxy: Default::default(),
secret_key: SecretKey::default(),
transaction_injector: None,
}
}
}
Expand All @@ -69,8 +74,15 @@ impl Service {
}

pub async fn spawn(self, context: Option<Context>) -> Result<ServiceHandle, Error> {
let Config { host, port, beacon_api_endpoint, network, engine_api_proxy, secret_key } =
self.config;
let Config {
host,
port,
beacon_api_endpoint,
network,
engine_api_proxy,
secret_key,
transaction_injector,
} = self.config;

let beacon_api_endpoint: Url = beacon_api_endpoint.parse().unwrap();
let client = Client::new(beacon_api_endpoint);
Expand Down Expand Up @@ -101,13 +113,27 @@ impl Service {
let current_epoch = clock.current_epoch();
builder.initialize(current_epoch).await;

let mut transaction_injector =
transaction_injector.and_then(|config| match TransactionInjector::new(config) {
Ok(injector) => Some(injector),
Err(err) => {
tracing::warn!("could not create transaction injector: {err}");
None
}
});
let clock = tokio::spawn(async move {
let slots = clock.stream_slots();

tokio::pin!(slots);

while let Some(slot) = slots.next().await {
builder.on_slot(slot).await;
if let Some(transaction_injector) = &mut transaction_injector {
match transaction_injector.submit_transaction().await {
Ok(txn_hash) => tracing::info!("injected transaction with hash {txn_hash}"),
Err(err) => tracing::warn!("error injecting transaction: {err}"),
}
}
}
});

Expand Down

0 comments on commit cbe75d1

Please sign in to comment.