Documentation ¶
Index ¶
- func Factory(ctx context.Context, config *consensus.Config, privateKey *ecdsa.PrivateKey, ...) (consensus.Consensus, error)
- func New(config *ibft.Config, privateKey *ecdsa.PrivateKey, db storage.Storage, ...) consensus.Istanbul
- type API
- func (api *API) Candidates() map[types.Address]bool
- func (api *API) Discard(address types.Address)
- func (api *API) GetSnapshot(number *jsonrpc.BlockNumber) (*Snapshot, error)
- func (api *API) GetSnapshotAtHash(hash types.Hash) (*Snapshot, error)
- func (api *API) GetValidators(number *jsonrpc.BlockNumber) ([]types.Address, error)
- func (api *API) GetValidatorsAtHash(hash types.Hash) ([]types.Address, error)
- func (api *API) Propose(address types.Address, auth bool)
- type Snapshot
- type Tally
- type Vote
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type API ¶
type API struct {
// contains filtered or unexported fields
}
API is a user facing RPC API to dump Istanbul state
func (*API) Candidates ¶
Candidates returns the current candidates the node tries to uphold and vote on.
func (*API) Discard ¶
Discard drops a currently running candidate, stopping the validator from casting further votes (either for or against).
func (*API) GetSnapshot ¶
func (api *API) GetSnapshot(number *jsonrpc.BlockNumber) (*Snapshot, error)
GetSnapshot retrieves the state snapshot at a given block.
func (*API) GetSnapshotAtHash ¶
GetSnapshotAtHash retrieves the state snapshot at a given block.
func (*API) GetValidators ¶
GetValidators retrieves the list of authorized validators at the specified block.
func (*API) GetValidatorsAtHash ¶
GetValidatorsAtHash retrieves the state snapshot at a given block.
type Snapshot ¶
type Snapshot struct { Epoch uint64 // The number of blocks after which to checkpoint and reset the pending votes Number uint64 // Block number where the snapshot was created Hash types.Hash // Block hash where the snapshot was created Votes []*Vote // List of votes cast in chronological order Tally map[types.Address]Tally // Current vote tally to avoid recalculating ValSet ibft.ValidatorSet // Set of authorized validators at this moment }
Snapshot is the state of the authorization voting at a given point in time.
func (*Snapshot) MarshalJSON ¶
Marshal to a json byte array
func (*Snapshot) UnmarshalJSON ¶
Unmarshal from a json byte array
type Tally ¶
type Tally struct { Authorize bool `json:"authorize"` // Whether the vote it about authorizing or kicking someone Votes int `json:"votes"` // Number of votes until now wanting to pass the proposal }
Tally is a simple vote tally to keep the current score of votes. Votes that go against the proposal aren't counted since it's equivalent to not voting.
type Vote ¶
type Vote struct { Validator types.Address `json:"validator"` // Authorized validator that cast this vote Block uint64 `json:"block"` // Block number the vote was cast in (expire old votes) Address types.Address `json:"address"` // Account being voted on to change its authorization Authorize bool `json:"authorize"` // Whether to authorize or deauthorize the voted account }
Vote represents a single vote that an authorized validator made to modify the list of authorizations.