pub struct ChainIdFiller(/* private fields */);
Expand description
A TxFiller
that populates the chain ID of a transaction.
If a chain ID is provided, it will be used for filling. If a chain ID is not provided, the filler will attempt to fetch the chain ID from the provider the first time a transaction is prepared, and will cache it for future transactions.
Transactions that already have a chain_id set by the user will not be modified.
§Example
let provider = ProviderBuilder::new()
.with_chain_id(1)
.wallet(wallet)
.on_http(url);
provider.send_transaction(TransactionRequest::default()).await;
Implementations§
source§impl ChainIdFiller
impl ChainIdFiller
sourcepub fn new(chain_id: Option<ChainId>) -> Self
pub fn new(chain_id: Option<ChainId>) -> Self
Create a new ChainIdFiller
with an optional chain ID.
If a chain ID is provided, it will be used for filling. If a chain ID is not provided, the filler will attempt to fetch the chain ID from the provider the first time a transaction is prepared.
Trait Implementations§
source§impl Clone for ChainIdFiller
impl Clone for ChainIdFiller
source§fn clone(&self) -> ChainIdFiller
fn clone(&self) -> ChainIdFiller
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 Debug for ChainIdFiller
impl Debug for ChainIdFiller
source§impl Default for ChainIdFiller
impl Default for ChainIdFiller
source§fn default() -> ChainIdFiller
fn default() -> ChainIdFiller
Returns the “default value” for a type. Read more
source§impl PartialEq for ChainIdFiller
impl PartialEq for ChainIdFiller
source§impl<N: Network> TxFiller<N> for ChainIdFiller
impl<N: Network> TxFiller<N> for ChainIdFiller
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::TransactionRequest) -> FillerControlFlow
fn status(&self, tx: &N::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,
_fillable: Self::Fillable,
tx: SendableTx<N>,
) -> TransportResult<SendableTx<N>>
async fn fill( &self, _fillable: 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.
impl Eq for ChainIdFiller
impl StructuralPartialEq for ChainIdFiller
Auto Trait Implementations§
impl Freeze for ChainIdFiller
impl RefUnwindSafe for ChainIdFiller
impl Send for ChainIdFiller
impl Sync for ChainIdFiller
impl Unpin for ChainIdFiller
impl UnwindSafe for ChainIdFiller
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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