# Lightclient Attackers Isolation
Adversarial nodes may have the incentive to lie to a lightclient about the state of a Tendermint blockchain. An attempt to do so is called attack. Light client verification (opens new window) checks incoming data by checking a so-called "commit", which is a forwarded set of signed messages that is (supposedly) produced during executing Tendermint consensus. Thus, an attack boils down to creating and signing Tendermint consensus messages in deviation from the Tendermint consensus algorithm rules.
As Tendermint consensus and light client verification is safe under the assumption of more than 2/3 of correct voting power per block [TMBC-FM-2THIRDS] (opens new window), this implies that if there was an attack then [TMBC-FM-2THIRDS] (opens new window) was violated, that is, there is a block such that
- validators deviated from the protocol, and
- these validators represent more than 1/3 of the voting power in that block.
In the case of an attack (opens new window), the lightclient attack detection mechanism (opens new window) computes data, so called evidence [LC-DATA-EVIDENCE.1] (opens new window), that can be used
- to proof that there has been attack [TMBC-LC-EVIDENCE-DATA.1] (opens new window) and
- as basis to find the actual nodes that deviated from the Tendermint protocol.
This specification considers how a full node in a Tendermint blockchain can isolate a set of attackers that launched the attack. The set should satisfy
- the set does not contain a correct validator
- the set contains validators that represent more than 1/3 of the voting power of a block that is still within the unbonding period
# Outline
After providing the problem statement, we specify the isolator function and close with the discussion about its correctness which is based on computer-aided analysis of Tendermint Consensus.
# Part I - Basics and Definition of the Problem
For definitions of data structures used here, in particular LightBlocks [LCV-DATA-LIGHTBLOCK.1] (opens new window), we refer to the specification of Light Client Verification (opens new window).
The specification of the detection mechanism (opens new window) describes
- what is a light client attack,
- conditions under which the detector will detect a light client attack,
- and the format of the output data, called evidence, in the case an attack is detected. The format is defined in [LC-DATA-EVIDENCE.1] (opens new window) and looks as follows
The isolator is a function that gets as input evidence ev
and a prefix of the blockchain bc at least up to height ev.ConflictingBlock.Header.Height + 1. The output is a set of peerIDs of validators.
We assume that the full node is synchronized with the blockchain and has reached the height ev.ConflictingBlock.Header.Height + 1.
# [LCAI-INV-Output.1]
When an output is generated it satisfies the following properties:
- If
- bc[CommonHeight].bfttimeis within the unbonding period w.r.t. the time at the full node,
- ev.ConflictingBlock.Header != bc[ev.ConflictingBlock.Header.Height]
- Validators in ev.ConflictingBlock.Commitrepresent more than 1/3 of the voting power inbc[ev.CommonHeight].NextValidators
 
- Then: The output is a set of validators in bc[CommonHeight].NextValidatorsthat- represent more than 1/3 of the voting power in bc[ev.commonHeight].NextValidators
- signed Tendermint consensus messages for height ev.ConflictingBlock.Header.Heightby violating the Tendermint consensus protocol.
 
- represent more than 1/3 of the voting power in 
- Else: the empty set.
# Part II - Protocol
Here we discuss how to solve the problem of isolating misbehaving processes. We describe the function isolateMisbehavingProcesses as well as all the helping functions below. In Part III, we discuss why the solution is complete based on result from analysis with automated tools.
# Isolation
# Outline
We first check whether the conflicting block can indeed be verified from the common height. We then first check whether it was a lunatic attack (violating validity). If this is not the case, we check for equivocation. If this also is not the case, we start the on-chain accountability protocol (opens new window).
# [LCAI-FUNC-MAIN.1]
- Implementation comment
- If the full node has only reached height ev.conflictingBlock.Header.Heightthenbc[ev.conflictingBlock.Header.Height + 1].Header.LastCommitrefers to the locally stored commit for this height. (This commit must be present by the precondition onlength(bc).)
- We check in the precondition that the unbonding period is not expired. However, since time moves on, before handing the validators over Cosmos SDK, the time needs to be checked again to satisfy the contract which requires that only bonded validators are reported. This passing of validators to the SDK is out of scope of this specification.
 
- If the full node has only reached height 
- Expected precondition
- length(bc) >= ev.conflictingBlock.Header.Height
- ValidAndVerifiedUnbonding(bc[ev.CommonHeight], ev.ConflictingBlock) == SUCCESS
- ev.ConflictingBlock.Header != bc[ev.ConflictingBlock.Header.Height]
- ev.conflictingBlocksatisfies basic validation (in particular all signed messages in the Commit are from the same round)
 
- Expected postcondition
- [FN-INV-Output.1] holds
 
- Error condition
- returns an error if precondition is violated.
 
# Details of the Functions
# [LCAI-FUNC-VVU.1]
- Conditions are identical to [LCV-FUNC-VALID.2] (opens new window) except the precondition "trusted.Header.Time > now - trustingPeriod" is substituted with
- trusted.Header.Time > now - UnbondingPeriod
 
# [LCAI-FUNC-NONVALID.1]
- Implementation remarks
- checks whether the evidence header evviolates the validity property of Tendermint Consensus, by checking against a reference header
 
- checks whether the evidence header 
- Expected precondition
- ref.Height == ev.Height
 
- Expected postcondition
- returns evaluation of the following disjunction
 [LCAI-NONVALID-OUTPUT.1] ==
 ref.ValidatorsHash != ev.ValidatorsHashor
 ref.NextValidatorsHash != ev.NextValidatorsHashor
 ref.ConsensusHash != ev.ConsensusHashor
 ref.AppHash != ev.AppHashor
 ref.LastResultsHash != ev.LastResultsHash
 
- returns evaluation of the following disjunction
- Implementation remarks
- This triggers the query/response protocol (opens new window).
 
- Expected postcondition
- returns attackers according to [LCAI-INV-Output.1].
 
- Expected precondition
- commitis well-formed. In particular all votes are from the same round- r.
 
- Expected postcondition
- returns round rthat is encoded in all the votes of the commit
 
- returns round 
- Error condition
- reports error if precondition is violated
 
- Expected postcondition
- returns all validator addresses in commit
 
- returns all validator addresses in 
- Expected postcondition
- returns all validator addresses in vals
 
- returns all validator addresses in 
# Part III - Completeness
As discussed in the beginning of this document, an attack boils down to creating and signing Tendermint consensus messages in deviation from the Tendermint consensus algorithm rules.
The main function isolateMisbehavingProcesses distinguishes three kinds of wrongly signed messages, namely,
- lunatic: signing invalid blocks
- equivocation: double-signing valid blocks in the same consensus round
- amnesia: signing conflicting blocks in different consensus rounds, without having seen a quorum of messages that would have allowed to do so.
The question is whether this captures all attacks.
First observe that the first check in isolateMisbehavingProcesses is violatesTMValidity. It takes care of lunatic attacks. If this check passes, that is, if violatesTMValidity returns FALSE this means that [LCAI-NONVALID-OUTPUT.1] evaluates to false, which implies that ref.ValidatorsHash = ev.ValidatorsHash. Hence, after violatesTMValidity, all the involved validators are the ones from the blockchain. It is thus sufficient to analyze one instance of Tendermint consensus with a fixed group membership (set of validators). Also, as we have two different blocks for the same height, it is sufficient to consider two different valid consensus values, that is, binary consensus.
For this fixed group membership, we have analyzed the attacks using the TLA+ specification of Tendermint Consensus in TLA+ (opens new window). We checked that indeed the only possible scenarios that can lead to violation of agreement are equivocation and amnesia. An independent study by Galois of the protocol based on Ivy proofs (opens new window) led to the same conclusion.
# References
[supervisor (opens new window)] The specification of the light client supervisor.
[verification (opens new window)] The specification of the light client verification protocol.
[detection (opens new window)] The specification of the light client attack detection mechanism.
[tendermint-accountability (opens new window)]: TLA+ specification to check the types of attacks