Browse Source

light client dir and readmes

pull/7804/head
Ethan Buchman 5 years ago
parent
commit
f26eb4ee89
No known key found for this signature in database GPG Key ID: DBB0B3EC64A4BDAA
5 changed files with 73 additions and 0 deletions
  1. +49
    -0
      spec/consensus/light/README.md
  2. +0
    -0
      spec/consensus/light/accountability.md
  3. +0
    -0
      spec/consensus/light/verification-non-recursive.md
  4. +0
    -0
      spec/consensus/light/verification.md
  5. +24
    -0
      spec/consensus/readme.md

+ 49
- 0
spec/consensus/light/README.md View File

@ -0,0 +1,49 @@
# Tendermint Light Client Protocol
## Contents
- [Motivation](#motivation)
- [Structure](#structure)
- [Core Verification](./verification.md)
- [Fork Detection](./detection.md)
- [Fork Accountability](./accountability.md)
## Motivation
The Tendermint Light Client is motivated by the need for a light weight protocol
to sync with a Tendermint blockchain, with the least processing necessary to
securely verify a recent state. The protocol consists
primarily of checking hashes and verifying Tendermint commit signatures to
update trusted validator sets and committed block headers from the chain.
Motivating use cases include:
- Light Node: a daemon that syncs a blockchain to the latest committed header by making RPC requests to full nodes.
- State Sync: a reactor that syncs a blockchain to a recent committed state by making P2P requests to full nodes.
- IBC Client: an ABCI application library that syncs a blockchain to a recent committed header by receiving proof-carrying
transactions from "IBC relayers", who make RPC requests to full nodes on behalf of the IBC clients.
## Structure
The Tendermint Light Client consists of three primary components:
- [Core Verification](./verification.md): verifying hashes, signatures, and validator set changes
- [Fork Detection](./detection.md): talking to multiple peers to detect byzantine behaviour
- [Fork Accountability](./accountability.md): analyzing byzantine behaviour to hold validators accountable.
While every light client must perform core verification and fork detection
to achieve their prescribed security level, fork accountability is expected to
be done by full nodes and validators, and is thus more accurately a component of
the full node consensus protocol, though it is included here since it is
primarily concerned with providing security to light clients.
Light clients are fundamentally synchronous protocols,
where security is grounded ultimately in the interval during which a validator can be punished
for byzantine behaviour. We assume here that such intervals have fixed and known minima
referred to commonly as a blockchain's Unbonding Period.
A secure light client must guarantee that all three components -
core verification, fork detection, and fork accountability -
each with their own synchrony assumptions and fault model, can execute
sequentially and to completion within the given Unbonding Period.

spec/consensus/fork-accountability.md → spec/consensus/light/accountability.md View File


spec/consensus/non-recursive-light-client.md → spec/consensus/light/verification-non-recursive.md View File


spec/consensus/light-client.md → spec/consensus/light/verification.md View File


+ 24
- 0
spec/consensus/readme.md View File

@ -3,3 +3,27 @@ cards: true
---
# Consensus
Specification of the Tendermint consensus protocol.
## Contents
- [Consensus Paper](./consensus-paper) - Latex paper on
[arxiv](https://arxiv.org/abs/1807.04938) describing the
core Tendermint consensus state machine with proofs of safety and termination.
- [BFT Time](./bft-time.md) - How the timestamp in a Tendermint
block header is computed in a Byzantine Fault Tolerant manner
- [Creating Proposal](./creating-proposal.md) - How a proposer
creates a block proposal for consensus
- [Light Client Protocol](./light) - A protocol for light weight consensus
verification and syncing to the latest state
- [Signing](./signing.md) - Rules for cryptographic signatures
produced by validators.
- [Write Ahead Log](./wal.md) - Write ahead log used by the
consensus state machine to recover from crashes.
The protocol used to gossip consensus messages between peers, which is critical
for liveness, is described in the [reactors section](/spec/reactors/consensus).
There is also a [stale markdown description](consensus.md) of the consensus state machine
(TODO update this).

Loading…
Cancel
Save