| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  | #![allow(deprecated)]
 | 
					
						
							|  |  |  | #![cfg(feature = "full")]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-20 09:48:10 -07:00
										 |  |  | use std::str::FromStr;
 | 
					
						
							|  |  |  | use thiserror::Error;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-06 21:05:55 -06:00
										 |  |  | #[derive(Serialize, Deserialize, Default, Clone, Copy, Debug, PartialEq)]
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  | #[serde(rename_all = "camelCase")]
 | 
					
						
							|  |  |  | pub struct CommitmentConfig {
 | 
					
						
							|  |  |  |     pub commitment: CommitmentLevel,
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | impl CommitmentConfig {
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentConfig::processed() instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  |     pub fn recent() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Recent,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentConfig::finalized() instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2019-12-18 11:38:54 -07:00
										 |  |  |     pub fn max() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Max,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentConfig::finalized() instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2020-04-29 22:55:33 -06:00
										 |  |  |     pub fn root() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Root,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentConfig::confirmed() instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2020-05-18 12:49:01 -06:00
										 |  |  |     pub fn single() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Single,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentConfig::confirmed() instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2020-05-22 13:55:17 -06:00
										 |  |  |     pub fn single_gossip() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::SingleGossip,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     pub fn finalized() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Finalized,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn confirmed() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Confirmed,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn processed() -> Self {
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             commitment: CommitmentLevel::Processed,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-03 17:53:30 -07:00
										 |  |  |     pub fn ok(self) -> Option<Self> {
 | 
					
						
							|  |  |  |         if self == Self::default() {
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  |             None
 | 
					
						
							|  |  |  |         } else {
 | 
					
						
							| 
									
										
										
										
											2020-03-03 17:53:30 -07:00
										 |  |  |             Some(self)
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     pub fn is_finalized(&self) -> bool {
 | 
					
						
							|  |  |  |         matches!(
 | 
					
						
							|  |  |  |             &self.commitment,
 | 
					
						
							|  |  |  |             CommitmentLevel::Finalized | CommitmentLevel::Max | CommitmentLevel::Root
 | 
					
						
							|  |  |  |         )
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn is_confirmed(&self) -> bool {
 | 
					
						
							|  |  |  |         matches!(
 | 
					
						
							|  |  |  |             &self.commitment,
 | 
					
						
							|  |  |  |             CommitmentLevel::Confirmed | CommitmentLevel::SingleGossip | CommitmentLevel::Single
 | 
					
						
							|  |  |  |         )
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     pub fn is_processed(&self) -> bool {
 | 
					
						
							|  |  |  |         matches!(
 | 
					
						
							|  |  |  |             &self.commitment,
 | 
					
						
							|  |  |  |             CommitmentLevel::Processed | CommitmentLevel::Recent
 | 
					
						
							|  |  |  |         )
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-26 16:47:35 -06:00
										 |  |  |     pub fn is_at_least_confirmed(&self) -> bool {
 | 
					
						
							|  |  |  |         self.is_confirmed() || self.is_finalized()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     pub fn use_deprecated_commitment(commitment: CommitmentConfig) -> Self {
 | 
					
						
							|  |  |  |         match commitment.commitment {
 | 
					
						
							|  |  |  |             CommitmentLevel::Finalized => CommitmentConfig::max(),
 | 
					
						
							|  |  |  |             CommitmentLevel::Confirmed => CommitmentConfig::single_gossip(),
 | 
					
						
							|  |  |  |             CommitmentLevel::Processed => CommitmentConfig::recent(),
 | 
					
						
							|  |  |  |             _ => commitment,
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-20 09:48:10 -07:00
										 |  |  | impl FromStr for CommitmentConfig {
 | 
					
						
							|  |  |  |     type Err = ParseCommitmentLevelError;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     fn from_str(s: &str) -> Result<Self, Self::Err> {
 | 
					
						
							|  |  |  |         CommitmentLevel::from_str(s).map(|commitment| Self { commitment })
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 13:55:17 -06:00
										 |  |  | #[derive(Serialize, Deserialize, Clone, Copy, Debug, PartialEq, Eq, Hash)]
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  | #[serde(rename_all = "camelCase")]
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:45:17 -06:00
										 |  |  | /// An attribute of a slot. It describes how finalized a block is at some point in time. For example, a slot
 | 
					
						
							|  |  |  | /// is said to be at the max level immediately after the cluster recognizes the block at that slot as
 | 
					
						
							|  |  |  | /// finalized. When querying the ledger state, use lower levels of commitment to report progress and higher
 | 
					
						
							|  |  |  | /// levels to ensure state changes will not be rolled back.
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  | pub enum CommitmentLevel {
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     /// (DEPRECATED) The highest slot having reached max vote lockout, as recognized by a supermajority of the cluster.
 | 
					
						
							|  |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentLevel::Finalized instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  |     Max,
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:45:17 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     /// (DEPRECATED) The highest slot of the heaviest fork. Ledger state at this slot is not derived from a finalized
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:45:17 -06:00
										 |  |  |     /// block, but if multiple forks are present, is from the fork the validator believes is most likely
 | 
					
						
							|  |  |  |     /// to finalize.
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentLevel::Processed instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  |     Recent,
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:45:17 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     /// (DEPRECATED) The highest slot having reached max vote lockout.
 | 
					
						
							|  |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentLevel::Finalized instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2020-04-29 22:55:33 -06:00
										 |  |  |     Root,
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:45:17 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-11 11:19:06 -07:00
										 |  |  |     /// (DEPRECATED) The highest slot having reached 1 confirmation by supermajority of the cluster.
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentLevel::Confirmed instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2020-05-18 12:49:01 -06:00
										 |  |  |     Single,
 | 
					
						
							| 
									
										
										
										
											2020-08-07 08:45:17 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     /// (DEPRECATED) The highest slot that has been voted on by supermajority of the cluster
 | 
					
						
							| 
									
										
										
										
											2020-09-11 11:19:06 -07:00
										 |  |  |     /// This differs from `single` in that:
 | 
					
						
							|  |  |  |     /// 1) It incorporates votes from gossip and replay.
 | 
					
						
							|  |  |  |     /// 2) It does not count votes on descendants of a block, only direct votes on that block.
 | 
					
						
							|  |  |  |     /// 3) This confirmation level also upholds "optimistic confirmation" guarantees in
 | 
					
						
							|  |  |  |     /// release 1.3 and onwards.
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |     #[deprecated(
 | 
					
						
							|  |  |  |         since = "1.5.5",
 | 
					
						
							|  |  |  |         note = "Please use CommitmentLevel::Confirmed instead"
 | 
					
						
							|  |  |  |     )]
 | 
					
						
							| 
									
										
										
										
											2020-05-22 13:55:17 -06:00
										 |  |  |     SingleGossip,
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// The highest slot of the heaviest fork processed by the node. Ledger state at this slot is
 | 
					
						
							|  |  |  |     /// not derived from a confirmed or finalized block, but if multiple forks are present, is from
 | 
					
						
							|  |  |  |     /// the fork the validator believes is most likely to finalize.
 | 
					
						
							|  |  |  |     Processed,
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// The highest slot that has been voted on by supermajority of the cluster, ie. is confirmed.
 | 
					
						
							|  |  |  |     /// Confirmation incorporates votes from gossip and replay. It does not count votes on
 | 
					
						
							|  |  |  |     /// descendants of a block, only direct votes on that block, and upholds "optimistic
 | 
					
						
							|  |  |  |     /// confirmation" guarantees in release 1.3 and onwards.
 | 
					
						
							|  |  |  |     Confirmed,
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// The highest slot having reached max vote lockout, as recognized by a supermajority of the
 | 
					
						
							|  |  |  |     /// cluster.
 | 
					
						
							|  |  |  |     Finalized,
 | 
					
						
							| 
									
										
										
										
											2019-11-06 14:15:00 -07:00
										 |  |  | }
 | 
					
						
							| 
									
										
										
										
											2020-07-06 21:05:55 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | impl Default for CommitmentLevel {
 | 
					
						
							|  |  |  |     fn default() -> Self {
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |         Self::Finalized
 | 
					
						
							| 
									
										
										
										
											2020-07-06 21:05:55 -06:00
										 |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							| 
									
										
										
										
											2021-01-20 09:48:10 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | impl FromStr for CommitmentLevel {
 | 
					
						
							|  |  |  |     type Err = ParseCommitmentLevelError;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     fn from_str(s: &str) -> Result<Self, Self::Err> {
 | 
					
						
							|  |  |  |         match s {
 | 
					
						
							|  |  |  |             "max" => Ok(CommitmentLevel::Max),
 | 
					
						
							|  |  |  |             "recent" => Ok(CommitmentLevel::Recent),
 | 
					
						
							|  |  |  |             "root" => Ok(CommitmentLevel::Root),
 | 
					
						
							|  |  |  |             "single" => Ok(CommitmentLevel::Single),
 | 
					
						
							|  |  |  |             "singleGossip" => Ok(CommitmentLevel::SingleGossip),
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |             "processed" => Ok(CommitmentLevel::Processed),
 | 
					
						
							|  |  |  |             "confirmed" => Ok(CommitmentLevel::Confirmed),
 | 
					
						
							|  |  |  |             "finalized" => Ok(CommitmentLevel::Finalized),
 | 
					
						
							| 
									
										
										
										
											2021-01-20 09:48:10 -07:00
										 |  |  |             _ => Err(ParseCommitmentLevelError::Invalid),
 | 
					
						
							|  |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | impl std::fmt::Display for CommitmentLevel {
 | 
					
						
							|  |  |  |     fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
 | 
					
						
							|  |  |  |         let s = match self {
 | 
					
						
							|  |  |  |             CommitmentLevel::Max => "max",
 | 
					
						
							|  |  |  |             CommitmentLevel::Recent => "recent",
 | 
					
						
							|  |  |  |             CommitmentLevel::Root => "root",
 | 
					
						
							|  |  |  |             CommitmentLevel::Single => "single",
 | 
					
						
							|  |  |  |             CommitmentLevel::SingleGossip => "singleGossip",
 | 
					
						
							| 
									
										
										
										
											2021-01-26 12:23:07 -07:00
										 |  |  |             CommitmentLevel::Processed => "processed",
 | 
					
						
							|  |  |  |             CommitmentLevel::Confirmed => "confirmed",
 | 
					
						
							|  |  |  |             CommitmentLevel::Finalized => "finalized",
 | 
					
						
							| 
									
										
										
										
											2021-01-20 09:48:10 -07:00
										 |  |  |         };
 | 
					
						
							|  |  |  |         write!(f, "{}", s)
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #[derive(Error, Debug)]
 | 
					
						
							|  |  |  | pub enum ParseCommitmentLevelError {
 | 
					
						
							|  |  |  |     #[error("invalid variant")]
 | 
					
						
							|  |  |  |     Invalid,
 | 
					
						
							|  |  |  | }
 |