pub struct AuthorityAggregator<A: Clone> {
    pub committee: Arc<Committee>,
    pub validator_display_names: Arc<HashMap<AuthorityName, String>>,
    pub authority_clients: Arc<BTreeMap<AuthorityName, Arc<SafeClient<A>>>>,
    pub metrics: Arc<AuthAggMetrics>,
    pub safe_client_metrics_base: SafeClientMetricsBase,
    pub timeouts: TimeoutConfig,
    pub committee_store: Arc<CommitteeStore>,
}

Fields§

§committee: Arc<Committee>

Our Sui committee.

§validator_display_names: Arc<HashMap<AuthorityName, String>>

For more human readable metrics reporting. It’s OK for this map to be empty or missing validators, it then defaults to use concise validator public keys.

§authority_clients: Arc<BTreeMap<AuthorityName, Arc<SafeClient<A>>>>

How to talk to this committee.

§metrics: Arc<AuthAggMetrics>

Metrics

§safe_client_metrics_base: SafeClientMetricsBase

Metric base for the purpose of creating new safe clients during reconfiguration.

§timeouts: TimeoutConfig§committee_store: Arc<CommitteeStore>

Store here for clone during re-config.

Implementations§

source§

impl<A: Clone> AuthorityAggregator<A>

source

pub fn new( committee: Committee, committee_store: Arc<CommitteeStore>, authority_clients: BTreeMap<AuthorityName, A>, registry: &Registry, validator_display_names: Arc<HashMap<AuthorityName, String>> ) -> Self

source

pub fn new_with_timeouts( committee: Committee, committee_store: Arc<CommitteeStore>, authority_clients: BTreeMap<AuthorityName, A>, registry: &Registry, validator_display_names: Arc<HashMap<AuthorityName, String>>, timeouts: TimeoutConfig ) -> Self

source

pub fn new_with_metrics( committee: Committee, committee_store: Arc<CommitteeStore>, authority_clients: BTreeMap<AuthorityName, A>, safe_client_metrics_base: SafeClientMetricsBase, auth_agg_metrics: Arc<AuthAggMetrics>, validator_display_names: Arc<HashMap<AuthorityName, String>> ) -> Self

source

pub fn recreate_with_net_addresses( &self, committee: CommitteeWithNetworkMetadata, network_config: &Config, disallow_missing_intermediate_committees: bool ) -> SuiResult<AuthorityAggregator<NetworkAuthorityClient>>

This function recreates AuthorityAggregator with the given committee. It also updates committee store which impacts other of its references. When disallow_missing_intermediate_committees is true, it requires the new committee needs to be current epoch + 1. The function could be used along with reconfig_from_genesis to fill in all previous epoch’s committee info.

source

pub fn get_client(&self, name: &AuthorityName) -> Option<&Arc<SafeClient<A>>>

source

pub fn clone_client_test_only(&self, name: &AuthorityName) -> Arc<SafeClient<A>>
where A: Clone,

source

pub fn clone_committee_store(&self) -> Arc<CommitteeStore>

source

pub fn clone_inner_committee_test_only(&self) -> Committee

source

pub fn clone_inner_clients_test_only( &self ) -> BTreeMap<AuthorityName, SafeClient<A>>

source§

impl AuthorityAggregator<NetworkAuthorityClient>

source

pub fn new_from_local_system_state( store: &Arc<dyn ExecutionCacheRead>, committee_store: &Arc<CommitteeStore>, safe_client_metrics_base: SafeClientMetricsBase, auth_agg_metrics: AuthAggMetrics ) -> Result<Self>

Create a new network authority aggregator by reading the committee and network address information from the system state object on-chain. This function needs metrics parameters because registry will panic if we attempt to register already-registered metrics again.

source

pub fn new_from_committee( committee: CommitteeWithNetworkMetadata, committee_store: &Arc<CommitteeStore>, safe_client_metrics_base: SafeClientMetricsBase, auth_agg_metrics: Arc<AuthAggMetrics>, validator_display_names: Arc<HashMap<AuthorityName, String>> ) -> Result<Self>

source§

impl<A> AuthorityAggregator<A>
where A: AuthorityAPI + Send + Sync + 'static + Clone,

source

pub async fn get_latest_object_version_for_testing( &self, object_id: ObjectID ) -> SuiResult<Object>

Query the object with highest version number from the authorities. We stop after receiving responses from 2f+1 validators. This function is untrusted because we simply assume each response is valid and there are no byzantine validators. Because of this, this function should only be used for testing or benchmarking.

source

pub async fn get_latest_system_state_object_for_testing( &self ) -> Result<SuiSystemState>

Get the latest system state object from the authorities. This function assumes all validators are honest. It should only be used for testing or benchmarking.

source

pub async fn process_transaction( &self, transaction: Transaction, client_addr: Option<SocketAddr> ) -> Result<ProcessTransactionResult, AggregatorProcessTransactionError>

Submits the transaction to a quorum of validators to make a certificate.

source

pub async fn process_certificate( &self, request: HandleCertificateRequestV3, client_addr: Option<SocketAddr> ) -> Result<QuorumDriverResponse, AggregatorProcessCertificateError>

source

pub async fn execute_transaction_block( &self, transaction: &Transaction, client_addr: Option<SocketAddr> ) -> Result<VerifiedCertifiedTransactionEffects, Error>

source

pub async fn handle_transaction_info_request_from_some_validators( &self, tx_digest: &TransactionDigest, validators: &BTreeSet<AuthorityName>, timeout_total: Option<Duration> ) -> SuiResult<PlainTransactionInfoResponse>

This function tries to get SignedTransaction OR CertifiedTransaction from an given list of validators who are supposed to know about it.

Trait Implementations§

source§

impl<A: Clone + Clone> Clone for AuthorityAggregator<A>

source§

fn clone(&self) -> AuthorityAggregator<A>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

§

impl<A> !RefUnwindSafe for AuthorityAggregator<A>

§

impl<A> Send for AuthorityAggregator<A>
where A: Sync + Send,

§

impl<A> Sync for AuthorityAggregator<A>
where A: Sync + Send,

§

impl<A> Unpin for AuthorityAggregator<A>

§

impl<A> !UnwindSafe for AuthorityAggregator<A>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Any for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

§

fn type_name(&self) -> &'static str

§

impl<T> AnySync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32 ) -> TaggedParser<'a, Implicit, Self, E>

source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<T> DynClone for T
where T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> FutureExt for T

§

fn with_context(self, otel_cx: Context) -> WithContext<Self>

Attaches the provided Context to this type, returning a WithContext wrapper. Read more
§

fn with_current_context(self) -> WithContext<Self>

Attaches the current Context to this type, returning a WithContext wrapper. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a Request
source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more