pub enum Wallet<P> {
Safe(Safe<P>),
Eoa(Eoa<P>),
}Expand description
A wallet that can be either a Safe smart account or an EOA
Note: Debug is not derived because Safe<P> and Eoa<P> don’t implement Debug.
Variants§
Implementations§
Source§impl<P> Wallet<P>
impl<P> Wallet<P>
Sourcepub async fn connect(provider: P, signer: PrivateKeySigner) -> Result<Self>
pub async fn connect(provider: P, signer: PrivateKeySigner) -> Result<Self>
Connects to a wallet, auto-detecting whether a Safe exists
Uses default configuration (salt_nonce = 0, single owner, threshold = 1).
If a Safe is deployed at the computed CREATE2 address, returns Wallet::Safe.
Otherwise, returns Wallet::Eoa.
§Arguments
provider- The provider for RPC callssigner- The private key signer
§Returns
Wallet::Safe if Safe exists at computed address, Wallet::Eoa otherwise
Sourcepub async fn connect_with_config(
provider: P,
signer: PrivateKeySigner,
config: WalletConfig,
) -> Result<Self>
pub async fn connect_with_config( provider: P, signer: PrivateKeySigner, config: WalletConfig, ) -> Result<Self>
Connects to a wallet with custom configuration
If a Safe is deployed at the computed CREATE2 address for the given config,
returns Wallet::Safe. Otherwise, returns Wallet::Eoa.
§Arguments
provider- The provider for RPC callssigner- The private key signerconfig- Configuration for Safe address computation
Sourcepub async fn connect_and_deploy(
provider: P,
signer: PrivateKeySigner,
) -> Result<Self>
pub async fn connect_and_deploy( provider: P, signer: PrivateKeySigner, ) -> Result<Self>
Connects and deploys a Safe if one doesn’t exist
Uses default configuration. If Safe already exists, connects to it.
If not, deploys a new Safe and returns Wallet::Safe.
§Arguments
provider- The provider for RPC calls (must support sending transactions)signer- The private key signer
Sourcepub async fn connect_and_deploy_with_config(
provider: P,
signer: PrivateKeySigner,
config: WalletConfig,
) -> Result<Self>
pub async fn connect_and_deploy_with_config( provider: P, signer: PrivateKeySigner, config: WalletConfig, ) -> Result<Self>
Connects and deploys a Safe with custom configuration
If Safe already exists at the computed address, connects to it. If not, deploys a new Safe with the specified configuration.
§Arguments
provider- The provider for RPC calls (must support sending transactions)signer- The private key signerconfig- Configuration for Safe address computation and deployment
Sourcepub fn address(&self) -> Address
pub fn address(&self) -> Address
Returns the wallet’s address
For Wallet::Safe, returns the Safe contract address.
For Wallet::Eoa, returns the EOA signer address.
Sourcepub fn signer_address(&self) -> Address
pub fn signer_address(&self) -> Address
Returns the underlying EOA signer address
For both variants, this returns the address of the private key signer.
Sourcepub fn batch(&self) -> BatchBuilder<'_, P>
pub fn batch(&self) -> BatchBuilder<'_, P>
Creates a unified batch builder for executing transactions
This provides the same API for both Safe and EOA wallets, abstracting away the differences between atomic multicall (Safe) and sequential transactions (EOA).
§Example
wallet.batch()
.add_typed(token, IERC20::transferCall { to: recipient, amount })
.simulate().await?
.execute().await?;Sourcepub async fn execute_single(
&self,
to: Address,
value: U256,
data: Bytes,
operation: Operation,
) -> Result<ExecutionResult>
pub async fn execute_single( &self, to: Address, value: U256, data: Bytes, operation: Operation, ) -> Result<ExecutionResult>
Executes a single transaction
This is a convenience method for executing a single call without
the batch builder. For multiple calls, use batch() instead.
§Errors
Returns Error::UnsupportedEoaOperation if operation is DelegateCall
and the wallet is an EOA.
Sourcepub async fn computed_safe_address(
provider: &P,
signer: &PrivateKeySigner,
config: &WalletConfig,
) -> Result<Address>
pub async fn computed_safe_address( provider: &P, signer: &PrivateKeySigner, config: &WalletConfig, ) -> Result<Address>
Computes the Safe address that would be used for the given signer and config
This is useful for checking what Safe address would be computed without actually connecting or deploying.
Source§impl<P> Wallet<P>
Specialized implementation for the common HTTP provider case
impl<P> Wallet<P>
Specialized implementation for the common HTTP provider case
Sourcepub async fn connect_and_deploy_with_rpc(
provider: P,
signer: PrivateKeySigner,
rpc_url: Url,
) -> Result<Self>
pub async fn connect_and_deploy_with_rpc( provider: P, signer: PrivateKeySigner, rpc_url: Url, ) -> Result<Self>
Connects and deploys a Safe using the specified RPC URL
This variant is useful when the provider doesn’t expose its RPC URL directly.
§Arguments
provider- The provider for RPC callssigner- The private key signerrpc_url- The RPC URL for sending deployment transaction
Sourcepub async fn connect_and_deploy_with_rpc_and_config(
provider: P,
signer: PrivateKeySigner,
rpc_url: Url,
config: WalletConfig,
) -> Result<Self>
pub async fn connect_and_deploy_with_rpc_and_config( provider: P, signer: PrivateKeySigner, rpc_url: Url, config: WalletConfig, ) -> Result<Self>
Connects and deploys a Safe with custom configuration and RPC URL
Auto Trait Implementations§
impl<P> Freeze for Wallet<P>where
P: Freeze,
impl<P> RefUnwindSafe for Wallet<P>where
P: RefUnwindSafe,
impl<P> Send for Wallet<P>where
P: Send,
impl<P> Sync for Wallet<P>where
P: Sync,
impl<P> Unpin for Wallet<P>where
P: Unpin,
impl<P> UnwindSafe for Wallet<P>where
P: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.