1use crate::base_types::AuthorityName;
5use crate::committee::Committee;
6use serde::{Deserialize, Serialize};
7
8#[derive(Clone, Copy, Debug, PartialEq, Eq, Serialize, Deserialize)]
10#[serde(rename_all = "kebab-case")]
11pub enum FullNodeSyncMode {
12 StateSyncOnly = 0,
14 ConsensusObserver = 1,
16}
17
18#[derive(Clone, Copy, Debug, PartialEq, Eq)]
25pub enum NodeRole {
26 Validator,
28 FullNode(FullNodeSyncMode),
30}
31
32impl NodeRole {
33 pub fn from_committee(
36 committee: &Committee,
37 name: &AuthorityName,
38 fullnode_sync_mode: Option<FullNodeSyncMode>,
39 ) -> Self {
40 if committee.authority_exists(name) {
41 NodeRole::Validator
42 } else if let Some(mode) = fullnode_sync_mode {
43 NodeRole::FullNode(mode)
44 } else {
45 NodeRole::FullNode(FullNodeSyncMode::StateSyncOnly)
46 }
47 }
48
49 pub fn is_fullnode(&self) -> bool {
50 matches!(self, Self::FullNode(_))
51 }
52
53 pub fn is_validator(&self) -> bool {
54 matches!(self, Self::Validator)
55 }
56
57 pub fn runs_consensus(&self) -> bool {
60 matches!(
61 self,
62 Self::Validator | Self::FullNode(FullNodeSyncMode::ConsensusObserver)
63 )
64 }
65
66 pub fn should_enable_index_processing(&self) -> bool {
73 matches!(self, Self::FullNode(_))
74 }
75
76 pub fn process_consensus_commits(&self) -> bool {
80 matches!(self, Self::Validator)
81 }
82
83 pub fn should_run_rpc_servers(&self) -> bool {
85 matches!(self, Self::FullNode(_))
86 }
87}
88
89impl std::fmt::Display for NodeRole {
90 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
91 match self {
92 Self::Validator => write!(f, "Validator"),
93 Self::FullNode(FullNodeSyncMode::StateSyncOnly) => write!(f, "FullNode"),
94 Self::FullNode(FullNodeSyncMode::ConsensusObserver) => {
95 write!(f, "FullNode(ConsensusObserver)")
96 }
97 }
98 }
99}
100
101#[cfg(test)]
102mod tests {
103 use super::*;
104
105 #[test]
106 fn test_validator_role() {
107 let role = NodeRole::Validator;
108 assert!(role.runs_consensus());
109 assert!(!role.should_enable_index_processing());
110 assert!(!role.should_run_rpc_servers());
111 assert!(role.process_consensus_commits());
112 }
113
114 #[test]
115 fn test_consensus_observer_role() {
116 let role = NodeRole::FullNode(FullNodeSyncMode::ConsensusObserver);
117 assert!(role.runs_consensus());
118 assert!(role.should_enable_index_processing());
119 assert!(role.should_run_rpc_servers());
120 assert!(!role.process_consensus_commits());
121 }
122
123 #[test]
124 fn test_fullnode_state_sync_role() {
125 let role = NodeRole::FullNode(FullNodeSyncMode::StateSyncOnly);
126 assert!(!role.runs_consensus());
127 assert!(role.should_enable_index_processing());
128 assert!(role.should_run_rpc_servers());
129 assert!(!role.process_consensus_commits());
130 }
131}