Struct TendermintObject

Source
pub struct TendermintObject {
Show 15 fields pub id: SharedObjectId, pub validators: HashMap<String, ValidatorInfo>, pub blocks: Vec<Block>, pub current_height: u64, pub current_round: u32, pub state: ConsensusState, pub proposals: HashMap<(u64, u32), TendermintMessageType>, pub prevotes: HashMap<(u64, u32), HashMap<String, Vote>>, pub precommits: HashMap<(u64, u32), HashMap<String, Vote>>, pub locked_block: Option<String>, pub locked_round: Option<u32>, pub my_validator_address: String, pub signer: ECDSASigner, pub verifier: ECDSAVerifier, pub messages: Vec<TendermintMessageType>,
}
Expand description

Tendermint BFT consensus object

Fields§

§id: SharedObjectId§validators: HashMap<String, ValidatorInfo>§blocks: Vec<Block>§current_height: u64§current_round: u32§state: ConsensusState§proposals: HashMap<(u64, u32), TendermintMessageType>§prevotes: HashMap<(u64, u32), HashMap<String, Vote>>§precommits: HashMap<(u64, u32), HashMap<String, Vote>>§locked_block: Option<String>§locked_round: Option<u32>§my_validator_address: String§signer: ECDSASigner§verifier: ECDSAVerifier§messages: Vec<TendermintMessageType>

Implementations§

Source§

impl TendermintObject

Source

pub fn new() -> Result<Self>

Source

pub fn add_validator( &mut self, address: String, public_key: String, voting_power: u64, )

Add a validator to the set

Source

pub fn total_voting_power(&self) -> u64

Get total voting power of active validators

Source

pub fn has_majority(&self, voting_power: u64) -> bool

Check if we have +2/3 majority

Source

pub fn process_proposal( &mut self, proposal: TendermintMessageType, ) -> Result<bool>

Process a proposal message

Source

pub fn process_prevote( &mut self, prevote: TendermintMessageType, ) -> Result<bool>

Process a prevote message

Source

pub fn process_precommit( &mut self, precommit: TendermintMessageType, ) -> Result<bool>

Process a precommit message

Source

pub fn can_commit(&self) -> Option<String>

Check if we can commit a block

Source

pub fn commit_block(&mut self, block_hash: String) -> Result<()>

Commit a block

Source

pub fn create_proposal( &self, transactions: Vec<Value>, ) -> Result<TendermintMessageType>

Create a proposal for the current height/round

Source

pub fn get_consensus_info(&self) -> Value

Get current consensus state info

Source

pub fn get_voting_stats(&self) -> Value

Get voting statistics for current round

Trait Implementations§

Source§

impl ApplicationObject for TendermintObject

Source§

fn id(&self) -> &SharedObjectId

Get the object’s unique identifier
Source§

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

Get the object’s type name
Source§

fn is_valid<'life0, 'life1, 'async_trait>( &'life0 self, message: &'life1 SharedMessage, ) -> Pin<Box<dyn Future<Output = Result<bool>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Validate if a message is valid for this object
Source§

fn add_message<'life0, 'async_trait>( &'life0 mut self, message: SharedMessage, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Add a validated message to the object
Source§

fn is_merkleized(&self) -> bool

Check if this object supports merkleized synchronization
Source§

fn get_latest_digest<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<String>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Get the latest state digest
Source§

fn has_digest<'life0, 'life1, 'async_trait>( &'life0 self, digest: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<bool>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Check if object has a specific digest
Source§

fn is_valid_digest<'life0, 'life1, 'async_trait>( &'life0 self, _digest: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<bool>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Validate if a digest is valid
Source§

fn add_digest<'life0, 'async_trait>( &'life0 mut self, _digest: String, ) -> Pin<Box<dyn Future<Output = Result<bool>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Add a digest to the object
Source§

fn gossip_messages<'life0, 'life1, 'async_trait>( &'life0 self, _digest: Option<&'life1 str>, ) -> Pin<Box<dyn Future<Output = Result<Vec<SharedMessage>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Get messages for gossip protocol
Source§

fn get_messages_since_digest<'life0, 'life1, 'async_trait>( &'life0 self, _digest: &'life1 str, ) -> Pin<Box<dyn Future<Output = Result<Vec<SharedMessage>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Get messages since a specific digest
Source§

fn get_state<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<Value>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Get the current state as JSON
Source§

fn reset<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Reset the object to initial state
Source§

fn clone_box(&self) -> Box<dyn ApplicationObject>

Clone the object
Source§

fn as_any(&self) -> &dyn Any

Get reference as Any for downcasting
Source§

fn as_any_mut(&mut self) -> &mut dyn Any

Get mutable reference as Any for downcasting
Source§

impl Debug for TendermintObject

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

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
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
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

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

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

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.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

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

Source§

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>,

Source§

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.
Source§

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

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

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
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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