Struct ethers_providers::QuorumProvider
source · [−]pub struct QuorumProvider<T> { /* private fields */ }Expand description
A provider that bundles multiple providers and only returns a value to the caller once the quorum has been reached.
Example
Create a QuorumProvider that only returns a value if the Quorum::Majority of
the weighted providers return the same value.
use ethers_core::types::U64;
use ethers_providers::{JsonRpcClient, QuorumProvider, Quorum, WeightedProvider, Http};
use std::str::FromStr;
let provider1 = WeightedProvider::new(Http::from_str("http://localhost:8545")?);
let provider2 = WeightedProvider::with_weight(Http::from_str("http://localhost:8545")?, 2);
let provider3 = WeightedProvider::new(Http::from_str("http://localhost:8545")?);
let provider = QuorumProvider::builder()
.add_providers([provider1, provider2, provider3])
.quorum(Quorum::Majority)
.build();
// the weight at which a quorum is reached,
assert_eq!(provider.quorum_weight(), 4 / 2); // majority >=50%
let block_number: U64 = provider.request("eth_blockNumber", ()).await?;
Implementations
sourceimpl QuorumProvider<Box<dyn JsonRpcClientWrapper>>
impl QuorumProvider<Box<dyn JsonRpcClientWrapper>>
sourceimpl QuorumProvider<Box<dyn PubsubClientWrapper>>
impl QuorumProvider<Box<dyn PubsubClientWrapper>>
sourcepub fn dyn_pub_sub() -> QuorumProviderBuilder<Box<dyn PubsubClientWrapper>>
pub fn dyn_pub_sub() -> QuorumProviderBuilder<Box<dyn PubsubClientWrapper>>
Create a QuorumProvider for different PubsubClient types
sourceimpl<T> QuorumProvider<T>
impl<T> QuorumProvider<T>
sourcepub fn builder() -> QuorumProviderBuilder<T>
pub fn builder() -> QuorumProviderBuilder<T>
Convenience method for creating a QuorumProviderBuilder with same JsonRpcClient types
pub fn new(
quorum: Quorum,
providers: impl IntoIterator<Item = WeightedProvider<T>>
) -> Self
pub fn providers(&self) -> &[WeightedProvider<T>]
sourcepub fn quorum_weight(&self) -> u64
pub fn quorum_weight(&self) -> u64
The weight at which the provider reached a quorum
pub fn add_provider(&mut self, provider: WeightedProvider<T>)
Trait Implementations
sourceimpl<T: Clone> Clone for QuorumProvider<T>
impl<T: Clone> Clone for QuorumProvider<T>
sourcefn clone(&self) -> QuorumProvider<T>
fn clone(&self) -> QuorumProvider<T>
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source. Read more
sourceimpl<T: Debug> Debug for QuorumProvider<T>
impl<T: Debug> Debug for QuorumProvider<T>
sourceimpl<C> JsonRpcClient for QuorumProvider<C> where
C: JsonRpcClientWrapper,
impl<C> JsonRpcClient for QuorumProvider<C> where
C: JsonRpcClientWrapper,
type Error = ProviderError
type Error = ProviderError
A JSON-RPC Error
sourcefn request<'life0, 'life1, 'async_trait, T, R>(
&'life0 self,
method: &'life1 str,
params: T
) -> Pin<Box<dyn Future<Output = Result<R, Self::Error>> + Send + 'async_trait>> where
T: 'async_trait + Serialize + Send + Sync,
R: 'async_trait + DeserializeOwned,
'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait,
fn request<'life0, 'life1, 'async_trait, T, R>(
&'life0 self,
method: &'life1 str,
params: T
) -> Pin<Box<dyn Future<Output = Result<R, Self::Error>> + Send + 'async_trait>> where
T: 'async_trait + Serialize + Send + Sync,
R: 'async_trait + DeserializeOwned,
'life0: 'async_trait,
'life1: 'async_trait,
Self: 'async_trait,
Sends a request with the provided JSON-RPC and parameters serialized as JSON
sourceimpl<C> PubsubClient for QuorumProvider<C> where
C: PubsubClientWrapper,
impl<C> PubsubClient for QuorumProvider<C> where
C: PubsubClientWrapper,
type NotificationStream = QuorumStream
type NotificationStream = QuorumStream
The type of stream this transport returns
Auto Trait Implementations
impl<T> RefUnwindSafe for QuorumProvider<T> where
T: RefUnwindSafe,
impl<T> Send for QuorumProvider<T> where
T: Send,
impl<T> Sync for QuorumProvider<T> where
T: Sync,
impl<T> Unpin for QuorumProvider<T> where
T: Unpin,
impl<T> UnwindSafe for QuorumProvider<T> where
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Instruments this type with the provided Span, returning an
Instrumented wrapper. Read more
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
fn vzip(self) -> V
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber to this type, returning a
WithDispatch wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber to this type, returning a
WithDispatch wrapper. Read more