Skip to main content
Version: Next

Architecture Decision Records (ADR)

This is a location to record all high-level architecture decisions in the Interchain Security project.

You can read more about the ADR concept in this blog post.

An ADR should provide:

  • Context on the relevant goals and the current state
  • Proposed changes to achieve the goals
  • Summary of pros and cons
  • References
  • Changelog

Note the distinction between an ADR and a spec. The ADR provides the context, intuition, reasoning, and justification for a change in architecture, or for the architecture of something new. The spec is much more compressed and streamlined summary of everything as it is or should be.

If recorded decisions turned out to be lacking, convene a discussion, record the new decisions here, and then modify the code to match.

Note the context/background should be written in the present tense.

To suggest an ADR, please make use of the ADR template provided.

Table of Contents

ADR #DescriptionStatus
001Consumer chain key assignmentAccepted, Implemented
002Jail ThrottlingAccepted, Implemented
003Equivocation governance proposalAccepted, Implemented
004Denom DOS fixesAccepted, Implemented
005Cryptographic verification of equivocation evidenceAccepted, In-progress
007Pause validator unbonding during equivocation proposalProposed
008Throttle with retriesAccepted, In-progress
009Soft Opt-outAccepted, Implemented
010Standalone to Consumer ChangeoverAccepted, Implemented
011Improving testing and increasing confidenceProposed
012Separate ReleasingProposed
013Slashing on the provider for consumer equivocationProposed