pub struct Wallet<D>{ /* 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<Secp256k1>>
impl Wallet<SigningKey<Secp256k1>>
Sourcepub fn new_keystore<P, R, S>(
dir: P,
rng: &mut R,
password: S,
name: Option<&str>,
) -> Result<(Wallet<SigningKey<Secp256k1>>, String), WalletError>
pub fn new_keystore<P, R, S>( dir: P, rng: &mut R, password: S, name: Option<&str>, ) -> Result<(Wallet<SigningKey<Secp256k1>>, 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<Wallet<SigningKey<Secp256k1>>, WalletError>
pub fn decrypt_keystore<P, S>( keypath: P, password: S, ) -> Result<Wallet<SigningKey<Secp256k1>>, 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<(Wallet<SigningKey<Secp256k1>>, String), WalletError>
pub fn encrypt_keystore<P, R, B, S>( keypath: P, rng: &mut R, pk: B, password: S, name: Option<&str>, ) -> Result<(Wallet<SigningKey<Secp256k1>>, 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: &mut R) -> Wallet<SigningKey<Secp256k1>>
pub fn new<R>(rng: &mut R) -> Wallet<SigningKey<Secp256k1>>
Creates a new random keypair seeded with the provided RNG
Sourcepub fn from_bytes(
bytes: &[u8],
) -> Result<Wallet<SigningKey<Secp256k1>>, WalletError>
pub fn from_bytes( bytes: &[u8], ) -> Result<Wallet<SigningKey<Secp256k1>>, 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: u16,
) -> Wallet<Signer<Secp256k1>>
pub fn connect( connector: Connector, credentials: Credentials, id: u16, ) -> Wallet<Signer<Secp256k1>>
Connects to a yubi key’s ECDSA account at the provided id
Source§impl<D> Wallet<D>
impl<D> Wallet<D>
Sourcepub fn new_with_signer(signer: D, address: H160, chain_id: u64) -> Wallet<D>
pub fn new_with_signer(signer: D, address: H160, chain_id: u64) -> Wallet<D>
Construct a new wallet with an external Signer
Source§impl<D> Wallet<D>
impl<D> 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 From<SigningKey<Secp256k1>> for Wallet<SigningKey<Secp256k1>>
impl From<SigningKey<Secp256k1>> for Wallet<SigningKey<Secp256k1>>
Source§fn from(signer: SigningKey<Secp256k1>) -> Wallet<SigningKey<Secp256k1>>
fn from(signer: SigningKey<Secp256k1>) -> Wallet<SigningKey<Secp256k1>>
Source§impl PartialEq for Wallet<SigningKey<Secp256k1>>
impl PartialEq for Wallet<SigningKey<Secp256k1>>
Source§impl<D> Signer for Wallet<D>
impl<D> Signer for Wallet<D>
Source§fn with_chain_id<T>(self, chain_id: T) -> Wallet<D>
fn with_chain_id<T>(self, chain_id: T) -> Wallet<D>
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, <Wallet<D> as Signer>::Error>> + Send + 'async_trait>>
fn sign_message<'life0, 'async_trait, S>( &'life0 self, message: S, ) -> Pin<Box<dyn Future<Output = Result<Signature, <Wallet<D> as Signer>::Error>> + Send + 'async_trait>>
Source§fn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 TypedTransaction,
) -> Pin<Box<dyn Future<Output = Result<Signature, <Wallet<D> as Signer>::Error>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
Wallet<D>: 'async_trait,
fn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 TypedTransaction,
) -> Pin<Box<dyn Future<Output = Result<Signature, <Wallet<D> as Signer>::Error>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
Wallet<D>: '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> 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> Pointable for T
impl<T> Pointable for T
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.