forked from cosmos/cosmos-sdk
-
Notifications
You must be signed in to change notification settings - Fork 35
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Modify IBC client governance unfreezing to reflect ADR changes (cosmo…
…s#8405) * update proto files * make proto-gen * update clienttypes * update localhost and solo machine * refactor tm client proposal handling * copy metadata * self review fixes * update 02-client keeper tests * fix 02-client type tests * fix localhost and solomachine tests * begin updating tm tests * partially fix tm tests * increase codecov * add more tests * add changelog * update specs * add docs * fix test * modify adr * allow modified chain-ids * add CLI command * fix typos * fix lint * Apply suggestions from code review Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com> * update docs, rm example * Update docs/ibc/proposals.md Co-authored-by: Christopher Goes <cwgoes@pluranimity.org> * update height checks to reflect chain-id changes cc @AdityaSripal * Apply suggestions from code review Co-authored-by: Christopher Goes <cwgoes@pluranimity.org> * Apply suggestions from code review Co-authored-by: Aditya <adityasripal@gmail.com> * address most of @AdityaSripal suggestions * update docs per review suggestions * Update x/ibc/core/02-client/types/proposal.go * add proposal handler * register proposal type * register proposal on codec * fix routing Co-authored-by: Federico Kunze <31522760+fedekunze@users.noreply.github.com> Co-authored-by: Christopher Goes <cwgoes@pluranimity.org> Co-authored-by: Aditya <adityasripal@gmail.com>
- Loading branch information
1 parent
d3e51cf
commit 47dd07d
Showing
30 changed files
with
807 additions
and
550 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
<!-- | ||
order: 5 | ||
--> | ||
|
||
# Governance Proposals | ||
|
||
In uncommon situations, a highly valued client may become frozen due to uncontrollable | ||
circumstances. A highly valued client might have hundreds of channels being actively used. | ||
Some of those channels might have a significant amount of locked tokens used for ICS 20. | ||
|
||
If the one third of the validator set of the chain the client represents decides to collude, | ||
they can sign off on two valid but conflicting headers each signed by the other one third | ||
of the honest validator set. The light client can now be updated with two valid, but conflicting | ||
headers at the same height. The light client cannot know which header is trustworthy and therefore | ||
evidence of such misbehaviour is likely to be submitted resulting in a frozen light client. | ||
|
||
Frozen light clients cannot be updated under any circumstance except via a governance proposal. | ||
Since a quorum of validators can sign arbitrary state roots which may not be valid executions | ||
of the state machine, a governance proposal has been added to ease the complexity of unfreezing | ||
or updating clients which have become "stuck". Without this mechanism, validator sets would need | ||
to construct a state root to unfreeze the client. Unfreezing clients, re-enables all of the channels | ||
built upon that client. This may result in recovery of otherwise lost funds. | ||
|
||
Tendermint light clients may become expired if the trusting period has passed since their | ||
last update. This may occur if relayers stop submitting headers to update the clients. | ||
|
||
An unplanned upgrade by the counterparty chain may also result in expired clients. If the counterparty | ||
chain undergoes an unplanned upgrade, there may be no commitment to that upgrade signed by the validator | ||
set before the chain-id changes. In this situation, the validator set of the last valid update for the | ||
light client is never expected to produce another valid header since the chain-id has changed, which will | ||
ultimately lead the on-chain light client to become expired. | ||
|
||
In the case that a highly valued light client is frozen, expired, or rendered non-updateable, a | ||
governance proposal may be submitted to update this client, known as the subject client. The | ||
proposal includes the client identifier for the subject, the client identifier for a substitute | ||
client, and an initial height to reference the substitute client from. Light client implementations | ||
may implement custom updating logic, but in most cases, the subject will be updated with information | ||
from the substitute client, if the proposal passes. The substitute client is used as a "stand in" | ||
while the subject is on trial. It is best practice to create a substitute client *after* the subject | ||
has become frozen to avoid the substitute from also becoming frozen. An active substitute client | ||
allows headers to be submitted during the voting period to prevent accidental expiry once the proposal | ||
passes. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
package client | ||
|
||
import ( | ||
govclient "github.com/cosmos/cosmos-sdk/x/gov/client" | ||
"github.com/cosmos/cosmos-sdk/x/ibc/core/02-client/client/cli" | ||
) | ||
|
||
var ProposalHandler = govclient.NewProposalHandler(cli.NewCmdSubmitUpdateClientProposal, nil) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.