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 pk: PrivateKeySigner = "0x...".parse()?;
let provider =
ProviderBuilder::<_, _, Ethereum>::default().with_chain_id(1).wallet(pk).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
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
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
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
Source§fn status(&self, tx: &N::TransactionRequest) -> FillerControlFlow
fn status(&self, tx: &N::TransactionRequest) -> FillerControlFlow
Source§fn fill_sync(&self, tx: &mut SendableTx<N>)
fn fill_sync(&self, tx: &mut SendableTx<N>)
TxFiller::prepare
and TxFiller::fill
to fill in any properties
that can be filled synchronously.Source§async fn prepare<P>(
&self,
provider: &P,
_tx: &N::TransactionRequest,
) -> TransportResult<Self::Fillable>where
P: Provider<N>,
async fn prepare<P>(
&self,
provider: &P,
_tx: &N::TransactionRequest,
) -> TransportResult<Self::Fillable>where
P: Provider<N>,
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>>
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>,
Source§fn continue_filling(&self, tx: &SendableTx<N>) -> bool
fn continue_filling(&self, tx: &SendableTx<N>) -> bool
true
if the filler is should continue filling.Source§fn ready(&self, tx: &N::TransactionRequest) -> bool
fn ready(&self, tx: &N::TransactionRequest) -> bool
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
true
if the filler is finished filling in the transaction request.Source§fn prepare_and_fill<P>(
&self,
provider: &P,
tx: SendableTx<N>,
) -> impl Send + Future<Output = TransportResult<SendableTx<N>>>where
P: Provider<N>,
fn prepare_and_fill<P>(
&self,
provider: &P,
tx: SendableTx<N>,
) -> impl Send + Future<Output = TransportResult<SendableTx<N>>>where
P: Provider<N>,
Source§fn prepare_call(
&self,
tx: &mut N::TransactionRequest,
) -> impl Send + Future<Output = TransportResult<()>>
fn prepare_call( &self, tx: &mut N::TransactionRequest, ) -> impl Send + Future<Output = TransportResult<()>>
Source§fn prepare_call_sync(
&self,
tx: &mut N::TransactionRequest,
) -> TransportResult<()>
fn prepare_call_sync( &self, tx: &mut N::TransactionRequest, ) -> TransportResult<()>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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
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<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> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeSendSync for T
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 8 bytes