diff --git a/crates/rpc/rpc-builder/src/lib.rs b/crates/rpc/rpc-builder/src/lib.rs index 76e889eec63..12e8c0c1a82 100644 --- a/crates/rpc/rpc-builder/src/lib.rs +++ b/crates/rpc/rpc-builder/src/lib.rs @@ -20,7 +20,7 @@ #![cfg_attr(docsrs, feature(doc_cfg, doc_auto_cfg))] use crate::{auth::AuthRpcModule, error::WsHttpSamePortError, metrics::RpcRequestMetrics}; -use alloy_network::Ethereum; +use alloy_network::{Ethereum, IntoWallet}; use alloy_provider::{fillers::RecommendedFillers, Provider, ProviderBuilder}; use core::marker::PhantomData; use error::{ConflictingModules, RpcError, ServerKind}; @@ -2089,6 +2089,21 @@ impl RpcServerHandle { self.new_http_provider_for() } + /// Returns a new [`alloy_network::Ethereum`] http provider with its recommended fillers and + /// installed wallet. + pub fn eth_http_provider_with_wallet( + &self, + wallet: W, + ) -> Option + Clone + Unpin + 'static> + where + W: IntoWallet, + { + let rpc_url = self.http_url()?; + let provider = + ProviderBuilder::new().wallet(wallet).connect_http(rpc_url.parse().expect("valid url")); + Some(provider) + } + /// Returns an http provider from the rpc server handle for the /// specified [`alloy_network::Network`]. /// @@ -2111,6 +2126,24 @@ impl RpcServerHandle { self.new_ws_provider_for().await } + /// Returns a new [`alloy_network::Ethereum`] ws provider with its recommended fillers and + /// installed wallet. + pub async fn eth_ws_provider_with_wallet( + &self, + wallet: W, + ) -> Option + Clone + Unpin + 'static> + where + W: IntoWallet, + { + let rpc_url = self.ws_url()?; + let provider = ProviderBuilder::new() + .wallet(wallet) + .connect(&rpc_url) + .await + .expect("failed to create ws client"); + Some(provider) + } + /// Returns an ws provider from the rpc server handle for the /// specified [`alloy_network::Network`]. ///