Portage CD CLI Configuration
The Portage CD CLI provides a set of commands to manage the configuration of your portage. These commands allow you to initialize, list variables, render, and convert configuration files in various formats.
This documentation provides a comprehensive overview of the configuration management capabilities available in the Portage CD CLI. For further assistance or more detailed examples, refer to the CLI's help command or the official documentation.
Configuring Using Environment Variables, CLI Arguments, or Configuration Files
The Portage CD supports flexible configuration methods to suit various operational environments. You can configure the engine using environment variables, command-line (CLI) arguments, or configuration files in JSON, YAML, or TOML formats. This flexibility allows you to choose the most convenient way to set up your portage based on your deployment and development needs.
Configuration Precedence
The Portage CD uses Viper under the hood to manage its configurations, which follows a specific order of precedence when merging configuration options:
- Command-line Arguments: These override values specified through other methods.
- Environment Variables: They take precedence over configuration files.
- Configuration Files: Supports JSON, YAML, and TOML formats. The engine reads these files if specified and merges them into the existing configuration.
- Default Values: Predefined in the code.
Using Environment Variables
Environment variables are a convenient way to configure the application in environments where file access might be restricted or for overriding specific configurations without changing the configuration files.
To use environment variables:
- Prefix your environment variables with a specific prefix (e.g.,
WF_
) to avoid conflicts with other applications. - Use the environment variable names that correspond to the configuration options you wish to set.
Using CLI Arguments
CLI arguments provide a way to specify configuration values when running a command. They are useful for temporary overrides or when scripting actions. For each configuration option, there is usually a corresponding flag that can be passed to the command.
For example:
./portage run image-build --build-dir . --dockerfile custom.Dockerfile
Using Configuration Files
Configuration files offer a structured and human-readable way to manage your application settings. The Portage CD supports JSON, YAML, and TOML formats, allowing you to choose the one that best fits your preferences or existing infrastructure.
- JSON: A lightweight data-interchange format.
- YAML: A human-readable data serialization standard.
- TOML:A minimal configuration file format that's easy to read due to its clear semantics.
To specify which configuration file to use, you can typically pass the file path as a CLI argument or set an environment variable pointing to the file.
Merging Configuration
Portage CD merges configuration from different sources in the order of precedence mentioned above. If the same configuration is specified in multiple places, the source with the highest precedence overrides the others. This mechanism allows for flexible configuration strategies, such as defining default values in a file and overriding them with environment variables or CLI arguments as needed.
Commands - Managing the configuration file
config init
Initializes the configuration file with default settings.
config vars
Lists supported built-in variables that can be used in templates.
config render
Renders a configuration template using the --file
flag or STDIN and writes the output to STDOUT.
config convert
Converts a configuration file from one format to another.
Examples
Render Configuration Template
Rendering a configuration template from config.json.tmpl
to JSON format:
$ cat config.json.tmpl | ./portage config render
Output:
{
"image": {...},
"artifacts": {...}
}
Convert Configuration Format
Attempting to convert the configuration without specifying required flags results in an error:
$ cat config.json.tmpl | ./portage config render | ./portage config convert
Error Output:
Error: at least one of the flags in the group [file input] is required
Successful conversion from JSON to TOML format:
$ cat config.json.tmpl | ./portage config render | ./portage config convert -i json -o toml
Output:
[image]
buildDir = '.'
...