Working with ADRs
ADRs (Architectural Decision Records) document significant design choices. They explain why things are built a certain way.
Creating ADRs
govctl new adr "Use Redis for caching"
This creates a TOML file in gov/adr/ with the decision context.
ADR Structure
ADRs contain:
- Context — The situation requiring a decision
- Decision — What was decided
- Consequences — Expected outcomes (positive and negative)
- Status —
proposed,accepted,deprecated, orsuperseded
Editing ADRs
ADRs are TOML files — edit them directly or use govctl:
govctl edit ADR-0003
Status Lifecycle
proposed → accepted → deprecated
↘ superseded
Accept a Decision
When consensus is reached:
govctl accept ADR-0003
Deprecate
When a decision is no longer relevant:
govctl deprecate ADR-0003
Supersede
When a new decision replaces an old one:
govctl supersede ADR-0001 --by ADR-0005
This marks ADR-0001 as superseded and records ADR-0005 as its replacement.
Listing ADRs
govctl list adr
govctl list adr --status accepted
Why TOML?
ADRs use TOML (not JSON or YAML) because:
- Comments allowed — Humans can annotate inline
- Multi-line strings — Clean
"""blocks for prose - No YAML ambiguity —
NOstaysNO, notfalse - Round-trip stable — Deterministic serialization