Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/timo-reymann/mkdocs-decision-records
Manage decision records with mkdocs in a customizable and minimal fashion.
https://github.com/timo-reymann/mkdocs-decision-records
adr mkdocs pypi
Last synced: 5 days ago
JSON representation
Manage decision records with mkdocs in a customizable and minimal fashion.
- Host: GitHub
- URL: https://github.com/timo-reymann/mkdocs-decision-records
- Owner: timo-reymann
- License: mit
- Created: 2024-12-09T18:32:42.000Z (28 days ago)
- Default Branch: main
- Last Pushed: 2024-12-26T19:56:24.000Z (11 days ago)
- Last Synced: 2024-12-26T20:29:44.604Z (11 days ago)
- Topics: adr, mkdocs, pypi
- Language: Python
- Homepage: https://pypi.org/project/mkdocs-decision-records/
- Size: 974 KB
- Stars: 7
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-repositories - timo-reymann/mkdocs-decision-records - Manage decision records with mkdocs in a customizable and minimal fashion. (Python)
README
mkdocs-decision-records
===
[![PyPI version](https://badge.fury.io/py/mkdocs-decision-records.svg)](https://pypi.org/project/mkdocs-decision-records)
[![PyPI - Downloads](https://img.shields.io/pypi/dm/mkdocs-decision-records)](https://pypi.org/project/mkdocs-decision-records)
[![LICENSE](https://img.shields.io/github/license/timo-reymann/mkdocs-decision-records)](https://github.com/timo-reymann/mkdocs-decision-records/blob/main/LICENSE)
[![CircleCI](https://circleci.com/gh/timo-reymann/mkdocs-decision-records.svg?style=shield)](https://app.circleci.com/pipelines/github/timo-reymann/mkdocs-decision-records)
[![codecov](https://codecov.io/gh/timo-reymann/mkdocs-decision-records/graph/badge.svg?token=EVgb1KIcjC)](https://codecov.io/gh/timo-reymann/mkdocs-decision-records)
[![Quality Gate Status](https://sonarcloud.io/api/project_badges/measure?project=timo-reymann_mkdocs-decision-records&metric=alert_status)](https://sonarcloud.io/summary/new_code?id=timo-reymann_mkdocs-decision-records)
[![Code Smells](https://sonarcloud.io/api/project_badges/measure?project=timo-reymann_mkdocs-decision-records&metric=code_smells)](https://sonarcloud.io/summary/new_code?id=timo-reymann_mkdocs-decision-records)
[![Maintainability Rating](https://sonarcloud.io/api/project_badges/measure?project=timo-reymann_mkdocs-decision-records&metric=sqale_rating)](https://sonarcloud.io/summary/new_code?id=timo-reymann_mkdocs-decision-records)
[![Security Rating](https://sonarcloud.io/api/project_badges/measure?project=timo-reymann_mkdocs-decision-records&metric=security_rating)](https://sonarcloud.io/summary/new_code?id=timo-reymann_mkdocs-decision-records)
[![Renovate](https://img.shields.io/badge/renovate-enabled-green?logo=)](https://renovatebot.com)
Manage decision records with mkdocs in a customizable and minimal fashion.## Features
- Customizable status colors and lifecycle
- Enforces information to be present for ADRs
- Allows description being kept as markdown## Demo
[You can find a Demo on GitHub Pages](https://timo-reymann.github.io/mkdocs-decision-records/)
## Installation
1. Install `mkdocs-decision-records` from the PyPi registry using your favorite package manager
2. Configure your `mkdocs.yml`
```yaml
plugins:
- decision-records:
# Folder where your decision records are located, defaults to adr
decisions_folder: adr
# Optional prefix to prepend to ticket numbers
ticket_url_prefix: https://ticket.example.com/
# Configure amount of required deciders
required_deciders_count: 1
# Configure available stages and the badge colors
lifecycle_stages:
{status}: {color}
```
3. Create your ADRs ensuring to add the frontmatter meta data:
```markdown
---
id: 000
status: proposed | rejected | accepted | deprecated | … | superseded by
date: YYYY-MM-DD
deciders:
- decider 1
- decider 2
# Optional ticket
ticket: FOO-1
---## Context and Problem Statement
[Describe the context and problem statement, e.g., in free form using two to three sentences. You may want to articulate the problem in form of a question.]
## Decision Drivers
* [driver 1, e.g., a force, facing concern, …]
* [driver 2, e.g., a force, facing concern, …]
* …## Considered Options
* [option 1]
* [option 2]
* [option 3]## Decision Outcome
Chosen option: "[option 1]",
because [justification. e.g., only option, which meets k.o. criterion decision driver | which resolves force force | … | comes out best (see below)].## Pros and Cons of the Options
### [option 1]
[example | description | pointer to more information | …]
* Good, because [argument a]
* Good, because [argument b]
* Bad, because [argument c]
* …### [option 2]
[example | description | pointer to more information | …]
* Good, because [argument a]
* Good, because [argument b]
* Bad, because [argument c]
* …### [option 3]
[example | description | pointer to more information | …]
* Good, because [argument a]
* Good, because [argument b]
* Bad, because [argument c]
* …## Links
* [Link type] [Link to ADR]
* …
```## Motivation
I love ADRs and documenting decisions in general. This plugin makes it a bit easier, enforcing basic meta information
while keeping the format open enough so you can do your thing.## Contributing
I love your input! I want to make contributing to this project as easy and transparent as possible, whether it's:
- Reporting a bug
- Discussing the current state of the configuration
- Submitting a fix
- Proposing new features
- Becoming a maintainerTo get started please read the [Contribution Guidelines](./CONTRIBUTING.md).
## Development
### Requirements
- Python 3.12+
- Poetry### Build
````sh
poetry install
````### Alternatives
- [mkdocs-material](https://pypi.org/project/mkdocs-material-adr/)
- Needs to use the theme
- ADR graph
- [mkdocs-macros-adr-summary](https://github.com/febus982/mkdocs-macros-adr-summary)
- works entirely with macros
- no metadata table at the top