Struct ethers_signers::Wallet
source · 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> 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> 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.