forked from MystenLabs/sui
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[node] Add plumbing that allows authorities to connect to other autho…
…rities (MystenLabs#1610) * Add plumbing to allows authorities to connect to other authorities Co-authored-by: George Danezis <george@danez.is>
- Loading branch information
Showing
5 changed files
with
110 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
// Copyright (c) 2022, Mysten Labs, Inc. | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
/* | ||
Authorities have a passive component (in AuthorityState), but can also have active | ||
components to perform a number of functions such as: | ||
(1) Share transactions received with other authorities, to complete their execution | ||
in case clients fail before sharing a trasnaction with sufficient authorities. | ||
(2) Share certificates with other authorities in case clients fail before a | ||
certificate has its executon finalized. | ||
(3) Gossip executed certificates digests with other authorities through following | ||
each other and using push / pull to execute certificates. | ||
(4) Perform the active operations necessary to progress the periodic checkpointing | ||
protocol. | ||
This component manages the root of all these active processes. It spawns services | ||
and tasks that activelly initiate network operations to progess all these | ||
processes. | ||
Some ground rules: | ||
- The logic here does nothing "privileged", namely any process that could not | ||
have been performed over the public authority interface by an untrusted | ||
client. | ||
- All logic here should be safe to the ActiveAuthority state being transient | ||
and multiple instances running in parallel per authority, or at untrusted | ||
clients. Or Authority state being stopped, without its state being saved | ||
(loss of store), and then restarted some time later. | ||
*/ | ||
|
||
use std::{collections::BTreeMap, sync::Arc}; | ||
|
||
use sui_types::{base_types::AuthorityName, error::SuiResult}; | ||
|
||
use crate::{ | ||
authority::AuthorityState, authority_aggregator::AuthorityAggregator, | ||
authority_client::AuthorityAPI, | ||
}; | ||
|
||
pub struct ActiveAuthority<A> { | ||
// The local authority state | ||
pub authority: Arc<AuthorityState>, | ||
// The network interfaces to other authorities | ||
pub net: AuthorityAggregator<A>, | ||
} | ||
|
||
impl<A> ActiveAuthority<A> { | ||
pub fn new( | ||
authority: Arc<AuthorityState>, | ||
authority_clients: BTreeMap<AuthorityName, A>, | ||
) -> SuiResult<Self> { | ||
let committee = authority.committee.clone(); | ||
|
||
Ok(ActiveAuthority { | ||
authority, | ||
net: AuthorityAggregator::new(committee, authority_clients), | ||
}) | ||
} | ||
} | ||
|
||
impl<A> ActiveAuthority<A> | ||
where | ||
A: AuthorityAPI + Send + Sync + 'static + Clone, | ||
{ | ||
// TODO: Active tasks go here + logic to spawn them all | ||
pub async fn spawn_all_active_processes(self) -> Option<()> { | ||
None | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters