Skip to content

Latest commit

 

History

History

consensus

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Overview

The consensus protocol is part of the blockchain mining mechanism, confirming the validity of proposed transactions (as referenced by its own state database) among a set of potentially untrusted agents on a network. If the amount of faulty (hostile) agents have a lower bound, here 1/3 of the total amount of participants, the protocol has mechanisms in place to assure safety and liveness. This is the lower bound and the definition of the concepts can be found in Section 4.5 Correctness here.

Implementation Details

  • engine is the core abstraction of the consensus protocol, containing the lower-level abstractions. It has the implemented PBFT protocol specification.
  • leader_process assigns and manages the primary (leader) of a unique consensus round
  • state codifies the state of a consensus message as a value between 0 and 6 (inclusive) in a custom message type
  • replay dry runs a proposed proposition with the cache before it proceeds with an actual transition operation
  • transition checks whether a set of transactions are valid according to current state and that the state transition is possible
  • view is the implemented view-change protocol to provide liveness to allow the system to continue if (when) the leader fails
  • common contains some consensus types and helper functions used frequently