Skip to main content

Wallet

Enum Wallet 

Source
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§

§

Safe(Safe<P>)

Safe smart account variant

§

Eoa(Eoa<P>)

Externally Owned Account variant

Implementations§

Source§

impl<P> Wallet<P>
where P: Provider<AnyNetwork> + Clone + 'static,

Source

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 calls
  • signer - The private key signer
§Returns

Wallet::Safe if Safe exists at computed address, Wallet::Eoa otherwise

Source

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 calls
  • signer - The private key signer
  • config - Configuration for Safe address computation
Source

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
Source

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 signer
  • config - Configuration for Safe address computation and deployment
Source

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.

Source

pub fn is_safe(&self) -> bool

Returns true if this is a Safe wallet

Source

pub fn is_eoa(&self) -> bool

Returns true if this is an EOA wallet

Source

pub fn signer_address(&self) -> Address

Returns the underlying EOA signer address

For both variants, this returns the address of the private key signer.

Source

pub fn provider(&self) -> &P

Returns a reference to the provider

Source

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?;
Source

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.

Source

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>
where P: Provider<AnyNetwork> + Clone + 'static,

Specialized implementation for the common HTTP provider case

Source

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 calls
  • signer - The private key signer
  • rpc_url - The RPC URL for sending deployment transaction
Source

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> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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 more
Source§

impl<T> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows 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
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows 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
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .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
where Self: BorrowMut<B>, B: ?Sized,

Calls .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
where Self: AsRef<R>, R: ?Sized,

Calls .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
where Self: AsMut<R>, R: ?Sized,

Calls .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
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more