pub trait TxSigner<Signature> {
// Required methods
fn address(&self) -> Address;
fn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 mut (dyn SignableTransaction<Signature> + 'static),
) -> Pin<Box<dyn Future<Output = Result<Signature, Error>> + Send + 'async_trait>>
where 'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait;
}
Available on crate feature
network
only.Expand description
Asynchronous transaction signer, capable of signing any SignableTransaction
for the given
Signature
type.
A signer should hold an optional ChainId
value, which is used for EIP-155 replay
protection.
If chain_id
is Some, EIP-155 should be applied to the input transaction in
sign_transaction
, and to the resulting signature in all the methods.
If chain_id
is None, EIP-155 should not be applied.
Synchronous signers should implement both this trait and TxSignerSync
.
Required Methods§
Sourcefn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 mut (dyn SignableTransaction<Signature> + 'static),
) -> Pin<Box<dyn Future<Output = Result<Signature, Error>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait,
fn sign_transaction<'life0, 'life1, 'async_trait>(
&'life0 self,
tx: &'life1 mut (dyn SignableTransaction<Signature> + 'static),
) -> Pin<Box<dyn Future<Output = Result<Signature, Error>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait,
Asynchronously sign an unsigned transaction.