-
Notifications
You must be signed in to change notification settings - Fork 14
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
docs: adr-001 cli implementation (#347)
* docs: adding draft of CLI decision record * docs: adding details around config file * docs: refactor wording for clarity * docs: update config example * expand content for default behaviors around oscal-model
- Loading branch information
Showing
1 changed file
with
61 additions
and
0 deletions.
There are no files selected for viewing
61 changes: 61 additions & 0 deletions
61
docs/architecture/decisions/implement-cli-framework_001.md
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,61 @@ | ||
--- | ||
x-trestle-template-version: 0.0.1 | ||
title: Implement CLI Framework | ||
status: accepted | ||
--- | ||
|
||
# ADR 001 - Implement CLI Framework | ||
|
||
## Context | ||
|
||
|
||
The primary motivation for this ADR is to enhance the user experience by implementing a more robust CLI framework within the trestlebot codebase. This will address the requirements of [Issue #295](https://github.com/RedHatProductSecurity/trestle-bot/issues/295) and [Issue #342](https://github.com/RedHatProductSecurity/trestle-bot/issues/342) and enable future development of more complex CLI scenarios. Currently entrypoints leverage the argparse library as the core CLI framework. However advanced patterns such as command chaining, subcommands, and dependencies between arguments can be difficult to implement. Moving to the [Click](https://click.palletsprojects.com/en/5.x/) CLI framework will address these challenges and support more complex requirements in the future. In addition, Click will provide a universal command syntax that can be used in the Python CLI app and container execution. | ||
|
||
This ADR also outlines the adoption of environment variables and a configuration file within the CLI. These will provides alternatives methods of passing arguments to the CLI beyond just command flags. This provides users with flexibility in how they pass arguments to the CLI and creates a more static option for arguments that tend to remain unchanged between command executions. | ||
|
||
|
||
## Decision | ||
|
||
The trestlebot module will be refactored to remove the use of `argparse` in favor of Click as the CLI framework. The code contained in `entrypoints` will be converted into Click commands under the `trestlebot` CLI application. A new `cli.py` module will be created as the main entrypoint. | ||
|
||
In addition, support will be added for using a configuration file and environment variables as CLI inputs. The CLI will prioritize arguments passed as command flags. If no argument is passed, the CLI will check for an environment variable. Finally, if no enviroment variable is found, it will look to the configuration file. Click natively supports loading command arguments from environment variables, including a constant prefix. All environment variables will have a `TRESTLEBOT_` prefix. | ||
|
||
The configuration file will be broken into two primary categories, `global` and `model specific`. Global configuration will apply across all models and include values such as git provider, markdown directories, etc. Model specific configuration will apply to the given OSCAL model only. While it is expected that most repos will be used for authoring a single OSCAL model, the possiblity of authoring more than one model would be supported. | ||
|
||
The configuration file would be initialized at a default location during the `trestlebot init` command. Manual creation and editing is also possible. The path to the configuration file can be passed using the `--config | -c` flag. This would not be required if using the default file location. | ||
|
||
Default behaviors: | ||
- the default configuration file location will be `.trestlebot/config.yaml` | ||
- if a command only supports a single OSCAL model then `--oscal-model` will default to that value. (ex: `rules-transform` only supports compdef) | ||
- if the config file only contains a single OSCAL model then that will be used as the default value for `--oscal-model` | ||
|
||
#### Example config: | ||
|
||
```yaml | ||
--- | ||
version: 1 | ||
working-dir: "." | ||
upstream-sources: [<url>] | ||
ssp-index-path: ssp-index.json | ||
git-provider-type: github | ||
git-provider-url: github.com | ||
git-committer-name: "Foo Bar" | ||
git-committer-email: [email protected] | ||
models: | ||
# we could allow for multiple or keep this as one | ||
- oscal-model: ssp | ||
markdown-path: markdown/system-security-plans | ||
skip-items: [...] | ||
skip-assemble: true | ||
- oscal-model: compdef | ||
markdown-path: markdown/component-definitions | ||
skip-items: [...] | ||
skip-assemble: true | ||
``` | ||
## Consequences | ||
- The existing command syntax will be updated to evolve from a set of independent entrypoint commants to a unified `trestlebot` CLI with multiple "subcommands". For example, `trestlebot-autosync <args>` becomes `trestlebot autosync <args>`. | ||
- The container entrypoints will be collapsed into a single entrypoint leveraging the Click CLI application. | ||
- CLI command arguments will be passed via flags, environment variables, or configuration file. |