pub struct Wallet<D: PrehashSigner<(Signature, RecoveryId)>> { /* private fields */ }
Expand description
An Ethereum private-public key pair which can be used for signing messages.
§Examples
§Signing and Verifying a message
The wallet can be used to produce ECDSA Signature
objects, which can be
then verified. Note that this uses hash_message
under the hood which will
prefix the message being hashed with the Ethereum Signed Message
domain separator.
use ethers_core::rand::thread_rng;
use ethers_signers::{LocalWallet, Signer};
let wallet = LocalWallet::new(&mut thread_rng());
// Optionally, the wallet's chain id can be set, in order to use EIP-155
// replay protection with different chains
let wallet = wallet.with_chain_id(1337u64);
// The wallet can be used to sign messages
let message = b"hello";
let signature = wallet.sign_message(message).await?;
assert_eq!(signature.recover(&message[..]).unwrap(), wallet.address());
// LocalWallet is clonable:
let wallet_clone = wallet.clone();
let signature2 = wallet_clone.sign_message(message).await?;
assert_eq!(signature, signature2);
Implementations§
Source§impl Wallet<SigningKey>
impl Wallet<SigningKey>
Sourcepub fn new_keystore<P, R, S>(
dir: P,
rng: &mut R,
password: S,
name: Option<&str>,
) -> Result<(Self, String), WalletError>
Available on non-WebAssembly only.
pub fn new_keystore<P, R, S>( dir: P, rng: &mut R, password: S, name: Option<&str>, ) -> Result<(Self, String), WalletError>
Creates a new random encrypted JSON with the provided password and stores it in the
provided directory. Returns a tuple (Wallet, String) of the wallet instance for the
keystore with its random UUID. Accepts an optional name for the keystore file. If None
,
the keystore is stored as the stringified UUID.
Sourcepub fn decrypt_keystore<P, S>(
keypath: P,
password: S,
) -> Result<Self, WalletError>
Available on non-WebAssembly only.
pub fn decrypt_keystore<P, S>( keypath: P, password: S, ) -> Result<Self, WalletError>
Decrypts an encrypted JSON from the provided path to construct a Wallet instance
Sourcepub fn encrypt_keystore<P, R, B, S>(
keypath: P,
rng: &mut R,
pk: B,
password: S,
name: Option<&str>,
) -> Result<(Self, String), WalletError>
Available on non-WebAssembly only.
pub fn encrypt_keystore<P, R, B, S>( keypath: P, rng: &mut R, pk: B, password: S, name: Option<&str>, ) -> Result<(Self, String), WalletError>
Creates a new encrypted JSON with the provided private key and password and stores it in the
provided directory. Returns a tuple (Wallet, String) of the wallet instance for the
keystore with its random UUID. Accepts an optional name for the keystore file. If None
,
the keystore is stored as the stringified UUID.
Sourcepub fn new<R: Rng + CryptoRng>(rng: &mut R) -> Self
pub fn new<R: Rng + CryptoRng>(rng: &mut R) -> Self
Creates a new random keypair seeded with the provided RNG
Sourcepub fn from_bytes(bytes: &[u8]) -> Result<Self, WalletError>
pub fn from_bytes(bytes: &[u8]) -> Result<Self, WalletError>
Creates a new Wallet instance from a raw scalar value (big endian).
Source§impl Wallet<Signer<Secp256k1>>
impl Wallet<Signer<Secp256k1>>
Sourcepub fn connect(connector: Connector, credentials: Credentials, id: Id) -> Self
Available on crate feature yubihsm
and non-WebAssembly only.
pub fn connect(connector: Connector, credentials: Credentials, id: Id) -> Self
yubihsm
and non-WebAssembly only.Connects to a yubi key’s ECDSA account at the provided id
Source§impl<D: PrehashSigner<(Signature, RecoveryId)>> Wallet<D>
impl<D: PrehashSigner<(Signature, RecoveryId)>> Wallet<D>
Sourcepub fn new_with_signer(signer: D, address: Address, chain_id: u64) -> Self
pub fn new_with_signer(signer: D, address: Address, chain_id: u64) -> Self
Construct a new wallet with an external Signer
Source§impl<D: PrehashSigner<(Signature, RecoveryId)>> Wallet<D>
impl<D: PrehashSigner<(Signature, RecoveryId)>> Wallet<D>
Sourcepub fn sign_transaction_sync(
&self,
tx: &TypedTransaction,
) -> Result<Signature, WalletError>
pub fn sign_transaction_sync( &self, tx: &TypedTransaction, ) -> Result<Signature, WalletError>
Synchronously signs the provided transaction, normalizing the signature v
value with
EIP-155 using the transaction’s chain_id
, or the signer’s chain_id
if the transaction
does not specify one.
Trait Implementations§
Source§impl<D: Clone + PrehashSigner<(Signature, RecoveryId)>> Clone for Wallet<D>
impl<D: Clone + PrehashSigner<(Signature, RecoveryId)>> Clone for Wallet<D>
Source§impl<D: PrehashSigner<(Signature, RecoveryId)>> Debug for Wallet<D>
impl<D: PrehashSigner<(Signature, RecoveryId)>> Debug for Wallet<D>
Source§impl From<SecretKey<Secp256k1>> for Wallet<SigningKey>
impl From<SecretKey<Secp256k1>> for Wallet<SigningKey>
Source§fn from(key: K256SecretKey) -> Self
fn from(key: K256SecretKey) -> Self
Source§impl From<Signer<Secp256k1>> for Wallet<Signer<Secp256k1>>
Available on crate feature yubihsm
and non-WebAssembly only.
impl From<Signer<Secp256k1>> for Wallet<Signer<Secp256k1>>
yubihsm
and non-WebAssembly only.Source§fn from(signer: YubiSigner<Secp256k1>) -> Self
fn from(signer: YubiSigner<Secp256k1>) -> Self
Source§impl From<SigningKey<Secp256k1>> for Wallet<SigningKey>
impl From<SigningKey<Secp256k1>> for Wallet<SigningKey>
Source§fn from(signer: SigningKey) -> Self
fn from(signer: SigningKey) -> Self
Source§impl FromStr for Wallet<SigningKey>
impl FromStr for Wallet<SigningKey>
Source§impl PartialEq for Wallet<SigningKey>
impl PartialEq for Wallet<SigningKey>
Source§impl<D: Sync + Send + PrehashSigner<(Signature, RecoveryId)>> Signer for Wallet<D>
impl<D: Sync + Send + PrehashSigner<(Signature, RecoveryId)>> Signer for Wallet<D>
Source§fn with_chain_id<T: Into<u64>>(self, chain_id: T) -> Self
fn with_chain_id<T: Into<u64>>(self, chain_id: T) -> Self
Sets the wallet’s chain_id, used in conjunction with EIP-155 signing
type Error = WalletError
Source§fn sign_message<'life0, 'async_trait, S>(
&'life0 self,
message: S,
) -> Pin<Box<dyn Future<Output = Result<Signature, Self::Error>> + Send + 'async_trait>>
fn sign_message<'life0, 'async_trait, S>( &'life0 self, message: S, ) -> Pin<Box<dyn Future<Output = Result<Signature, Self::Error>> + Send + 'async_trait>>
Source§fn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 TypedTransaction,
) -> Pin<Box<dyn Future<Output = Result<Signature, Self::Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 TypedTransaction,
) -> Pin<Box<dyn Future<Output = Result<Signature, Self::Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Auto Trait Implementations§
impl<D> Freeze for Wallet<D>where
D: Freeze,
impl<D> RefUnwindSafe for Wallet<D>where
D: RefUnwindSafe,
impl<D> Send for Wallet<D>where
D: Send,
impl<D> Sync for Wallet<D>where
D: Sync,
impl<D> Unpin for Wallet<D>where
D: Unpin,
impl<D> UnwindSafe for Wallet<D>where
D: 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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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> 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> 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.