pub struct NonceFiller<M: NonceManager = SimpleNonceManager> { /* private fields */ }
Expand description
A TxFiller
that fills nonces on transactions. The behavior of filling nonces is determined
by the NonceManager
.
§Note
- If the transaction request does not have a sender set, this layer will not fill nonces.
- Using two providers with their own nonce layer can potentially fill invalid nonces if transactions are sent from the same address, as the next nonce to be used is cached internally in the layer.
§Example
let provider = ProviderBuilder::new()
.with_simple_nonce_management()
.wallet(wallet)
.on_http(url);
provider.send_transaction(TransactionRequest::default()).await;
Implementations§
source§impl<M: NonceManager> NonceFiller<M>
impl<M: NonceManager> NonceFiller<M>
sourcepub const fn new(nonce_manager: M) -> Self
pub const fn new(nonce_manager: M) -> Self
Creates a new NonceFiller
with the specified NonceManager
.
Trait Implementations§
source§impl<M: Clone + NonceManager> Clone for NonceFiller<M>
impl<M: Clone + NonceManager> Clone for NonceFiller<M>
source§fn clone(&self) -> NonceFiller<M>
fn clone(&self) -> NonceFiller<M>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<M: Debug + NonceManager> Debug for NonceFiller<M>
impl<M: Debug + NonceManager> Debug for NonceFiller<M>
source§impl<M: Default + NonceManager> Default for NonceFiller<M>
impl<M: Default + NonceManager> Default for NonceFiller<M>
source§fn default() -> NonceFiller<M>
fn default() -> NonceFiller<M>
Returns the “default value” for a type. Read more
source§impl<M: NonceManager, N: Network> TxFiller<N> for NonceFiller<M>
impl<M: NonceManager, N: Network> TxFiller<N> for NonceFiller<M>
source§type Fillable = u64
type Fillable = u64
The properties that this filler retrieves from the RPC. to fill in the
TransactionRequest.
source§fn status(&self, tx: &<N as Network>::TransactionRequest) -> FillerControlFlow
fn status(&self, tx: &<N as Network>::TransactionRequest) -> FillerControlFlow
Return a control-flow enum indicating whether the filler is ready to
fill in the transaction request, or if it is missing required
properties.
source§fn fill_sync(&self, _tx: &mut SendableTx<N>)
fn fill_sync(&self, _tx: &mut SendableTx<N>)
Performs any synchronous filling. This should be called before
TxFiller::prepare
and TxFiller::fill
to fill in any properties
that can be filled synchronously.source§async fn prepare<P, T>(
&self,
provider: &P,
tx: &N::TransactionRequest,
) -> TransportResult<Self::Fillable>
async fn prepare<P, T>( &self, provider: &P, tx: &N::TransactionRequest, ) -> TransportResult<Self::Fillable>
Prepares fillable properties, potentially by making an RPC request.
source§async fn fill(
&self,
nonce: Self::Fillable,
tx: SendableTx<N>,
) -> TransportResult<SendableTx<N>>
async fn fill( &self, nonce: Self::Fillable, tx: SendableTx<N>, ) -> TransportResult<SendableTx<N>>
Fills in the transaction request with the fillable properties.
source§fn join_with<T>(self, other: T) -> JoinFill<Self, T>where
T: TxFiller<N>,
fn join_with<T>(self, other: T) -> JoinFill<Self, T>where
T: TxFiller<N>,
Joins this filler with another filler to compose multiple fillers.
source§fn continue_filling(&self, tx: &SendableTx<N>) -> bool
fn continue_filling(&self, tx: &SendableTx<N>) -> bool
Returns
true
if the filler is should continue filling.source§fn ready(&self, tx: &N::TransactionRequest) -> bool
fn ready(&self, tx: &N::TransactionRequest) -> bool
Returns
true
if the filler is ready to fill in the transaction request.source§fn finished(&self, tx: &N::TransactionRequest) -> bool
fn finished(&self, tx: &N::TransactionRequest) -> bool
Returns
true
if the filler is finished filling in the transaction request.source§fn prepare_and_fill<P, T>(
&self,
provider: &P,
tx: SendableTx<N>,
) -> impl Send + Future<Output = TransportResult<SendableTx<N>>>
fn prepare_and_fill<P, T>( &self, provider: &P, tx: SendableTx<N>, ) -> impl Send + Future<Output = TransportResult<SendableTx<N>>>
Prepares and fills the transaction request with the fillable properties.
Auto Trait Implementations§
impl<M> Freeze for NonceFiller<M>where
M: Freeze,
impl<M> RefUnwindSafe for NonceFiller<M>where
M: RefUnwindSafe,
impl<M> Send for NonceFiller<M>
impl<M> Sync for NonceFiller<M>
impl<M> Unpin for NonceFiller<M>where
M: Unpin,
impl<M> UnwindSafe for NonceFiller<M>where
M: 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
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)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>
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 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>
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