From a8bcafcb5d59ada5d343cabcbc087dcb70a8734c Mon Sep 17 00:00:00 2001 From: Daira Emma Hopwood Date: Thu, 28 Dec 2023 02:17:52 +0000 Subject: [PATCH] Crosslink: clarifications. Signed-off-by: Daira Emma Hopwood --- src/design/crosslink/construction.md | 14 +++++++++++--- src/design/crosslink/security-analysis.md | 18 ++++++++++-------- 2 files changed, 21 insertions(+), 11 deletions(-) diff --git a/src/design/crosslink/construction.md b/src/design/crosslink/construction.md index 7a1ca86..7618a6c 100644 --- a/src/design/crosslink/construction.md +++ b/src/design/crosslink/construction.md @@ -74,6 +74,8 @@ A Crosslink node must participate in both $\Pi A player’s view in $\Pi_{\mathrm{*bft}}$ includes a set of $\mathrm{*}$bft‑block chains each rooted at a fixed genesis $\mathrm{*}$bft‑block $\mathcal{O}_{\mathrm{*bft}}$. There is a $\mathrm{*}$bft‑block‑validity rule (specified below), which depends only on the content of the block and its ancestors. A non‑genesis block can only be $\mathrm{*}$bft‑block‑valid if its parent is $\mathrm{*}$bft‑block‑valid. A $\mathrm{*}$bft‑valid‑chain is a chain of $\mathrm{*}$bft‑block‑valid blocks. +Execution proceeds in a sequence of epochs. In each epoch, a $\mathrm{*}$bft‑proposal may be made. + A $\mathrm{*}$bft‑proposal refers to a parent $\mathrm{*}$bft‑block, and specifies the proposal’s epoch. The content of a proposal is signed by the proposer using a strongly unforgeable signature scheme. We consider the proposal to include this signature. There is a $\mathrm{*}$bft‑proposal‑validity rule, depending only on the content of the proposal and its parent block, and the validity of the proposer’s signature. ```admonish info @@ -82,15 +84,15 @@ We will shorten “$\mathrm{*}$bft‑block‑v For each epoch, there is a fixed number of voting units distributed between the players, which they use to vote for a $\mathrm{*}$bft‑proposal. We say that a voting unit has been cast for a $\mathrm{*}$bft‑proposal $P$ at a given time in a $\mathrm{*}$bft‑execution, if and only if $P$ is $\mathrm{*}$bft‑proposal‑valid and a ballot for $P$ authenticated by the holder of the voting unit exists at that time. -If, and only if, the votes cast for a $\mathrm{*}$bft‑proposal $P$ satisfy a notarization rule at a given time in a $\mathrm{*}$bft‑execution, then it is possible to obtain a valid $\mathrm{*}$bft‑notarization‑proof $\mathsf{proof}_P$. The notarization rule must require at least a two‑thirds absolute supermajority of voting units in $P$'s epoch to have been cast for $P$. It may also require other conditions. +Using knowledge of ballots cast for a $\mathrm{*}$bft‑proposal $P$ that collectively satisfy a notarization rule at a given time in a $\mathrm{*}$bft‑execution, and only with such knowledge, it is possible to obtain a valid $\mathrm{*}$bft‑notarization‑proof $\mathsf{proof}_P$. The notarization rule must require at least a two‑thirds absolute supermajority of voting units in $P$’s epoch to have been cast for $P$. It may also require other conditions. A voting unit is cast non‑honestly for an epoch’s proposal iff: * it is cast other than by the holder of the unit (due to key compromise or any flaw in the voting protocol, for example); or -* it is double‑cast (i.e. for distinct proposals); or +* it is double‑cast (i.e. there are two ballots casting it for distinct proposals); or * the holder of the unit following the conditions for honest voting in $\Pi_{\mathrm{*bft}}$, according to its view, should not have cast that vote. ```admonish success "Definition: One‑third bound on non‑honest voting" -An execution of $\Pi_{\mathrm{bft}}$ has the **one‑third bound on non‑honest voting** property if at any epoch in the execution, *strictly* fewer than one third of the total voting units for that epoch are cast non‑honestly. +An execution of $\Pi_{\mathrm{bft}}$ has the **one‑third bound on non‑honest voting** property iff for every epoch, *strictly* fewer than one third of the total voting units for that epoch are ever cast non‑honestly. ``` ```admonish info @@ -99,6 +101,12 @@ It may be the case that a ballot cast for $P$ is not in honest view when it is u There may be multiple distinct ballots or distinct ballot messages attempting to cast a given voting unit for the same proposal; this is undesirable for bandwidth usage, but it is not necessary to consider it to be non‑honest behaviour for the purpose of security analysis, as long as such ballots are not double‑counted toward the two‑thirds threshold. ``` +```admonish warning "Security caveat" +The **one‑third bound on non‑honest voting** property considers all ballots cast in the entire execution. In particular, it is possible that a validator’s key is compromised and then used to cast its voting units for a proposal of an epoch long finished. If the number of voting units cast non-honestly for any epoch *ever* reaches one third of the total voting units for that epoch during an execution, then the **one‑third bound on non‑honest voting** property is violated for that execution. + +Therefore, validator keys of honest nodes must remain secret indefinitely. Whenever a key is rotated, the old key must be securely deleted. For further discussion and potential improvements, see [tfl-book issue #140](https://github.com/Electric-Coin-Company/tfl-book/issues/140). +``` + A $\mathrm{*}$bft‑block consists of $(P, \mathsf{proof}_P)$ re‑signed by the same proposer using a strongly unforgeable signature scheme. It is $\mathrm{*}$bft‑block‑valid iff: * $P$ is $\mathrm{*}$bft‑proposal‑valid; and * $\mathsf{proof}_P$ is a valid proof that some subset of ballots cast for $P$ are sufficient to satisfy the notarization rule; and diff --git a/src/design/crosslink/security-analysis.md b/src/design/crosslink/security-analysis.md index 05faa7c..9124a26 100644 --- a/src/design/crosslink/security-analysis.md +++ b/src/design/crosslink/security-analysis.md @@ -137,16 +137,18 @@ The above property is not as strong as we would like for practical uses of $\mat As documented in the [Model for BFT protocols](./construction.md#model-for-bft-protocols-Πorigbftbft) section of [The Crosslink Construction](./construction.md)): -> For each epoch, there is a fixed number of voting units distributed between the players, which they use to vote for a $\mathrm{*}$bft‑proposal. If, and only if, the votes cast for a $\mathrm{*}$bft‑proposal $P$ satisfy a notarization rule, then it is possible to obtain a valid $\mathrm{*}$bft‑notarization-proof $\mathsf{proof}_P$. The notarization rule must require at least a two-thirds absolute supermajority of voting units to have been cast for $P$. (It may also require other conditions.) +> For each epoch, there is a fixed number of voting units distributed between the players, which they use to vote for a $\mathrm{*}$bft‑proposal. We say that a voting unit has been cast for a $\mathrm{*}$bft‑proposal $P$ at a given time in a $\mathrm{*}$bft‑execution, if and only if $P$ is $\mathrm{*}$bft‑proposal‑valid and a ballot for $P$ authenticated by the holder of the voting unit exists at that time. > -> A voting unit for an epoch is cast non‑honestly if: -> * it is cast other than by the holder of the unit (due to key compromise or any flaw in the voting protocol, for example); or -> * it is double‑cast (i.e. for distinct proposals); or -> * the holder of the unit following the conditions for honest voting in $\Pi_{\mathrm{*bft}}$, according to its view, should not have cast that vote. +> Using knowledge of ballots cast for a $\mathrm{*}$bft‑proposal $P$ that collectively satisfy a notarization rule at a given time in a $\mathrm{*}$bft‑execution, and only with such knowledge, it is possible to obtain a valid $\mathrm{*}$bft‑notarization‑proof $\mathsf{proof}_P$. The notarization rule must require at least a two‑thirds absolute supermajority of voting units in $P$’s epoch to have been cast for $P$. It may also require other conditions. > -> ```admonish success -> An execution of $\Pi_{\mathrm{bft}}$ has the **one‑third bound on non‑honest voting** property if at any epoch in the execution, strictly fewer than one third of the total voting units for that epoch are cast non‑honestly. -> ``` +> A voting unit is cast non‑honestly for an epoch’s proposal iff: +> * it is cast other than by the holder of the unit (due to key compromise or any flaw in the voting protocol, for example); or +> * it is double‑cast (i.e. there are two ballots casting it for distinct proposals); or +> * the holder of the unit following the conditions for honest voting in $\Pi_{\mathrm{*bft}}$, according to its view, should not have cast that vote. + +```admonish success "Definition: One‑third bound on non‑honest voting" +An execution of $\Pi_{\mathrm{bft}}$ has the **one‑third bound on non‑honest voting** property iff for every epoch, *strictly* fewer than one third of the total voting units for that epoch are ever cast non‑honestly. +``` ```admonish success "Theorem: On bft‑valid blocks for a given epoch in honest view" By a well known argument often used to prove safety of BFT protocols, in an execution of Crosslink where $\Pi_{\mathrm{bft}}$ has the **one‑third bound on non‑honest voting** property (and assuming soundness of notarization proofs), any bft‑valid block for a given epoch in honest view must commit to the same proposal.