Templating
API Reference
Template module which handles all things related to templates.
- template.load_template(file, params, description)
Load a template file through Jinja into a dictionary.
- This function performs the following steps:
Passes the YAML file to be loaded and parsed through `Jinja`
`Jinja` substitutes the variables with their values as they are found in params
Loads any other files that are referenced using the Jinja {% include %} directive, if it is present.
Updates the context key path within image definitions with respect to its relative parent file path.
Loads the rendered YAML file into a dictionary.
- Parameters:
file (Union[Path, str]) – Path to the templated YAML file to be loaded.
params (Dict[str, Any] | None, optional) – Named parameters to be passed to Jinja. Defaults to {}.
description ([str]) – The description from the file extracted and added to the payload.
- Returns:
Dictionary containing the rendered YAML file
- Return type:
Dict[str, Any]
CLI Reference
Helper functions for Peak cli.
- cli.helpers.check_file_extension(file_path)
Checks if the file has a .txt or .md extension.
- Parameters:
file_path (str) – Path to the file to check.
- Raises:
ValueError – If the file extension is not .txt or .md.
- Return type:
None
- cli.helpers.format_logs(logs)
Formats logs into a readable format.
- Parameters:
logs (List[Dict[str, Any]]) – List of logs
- Returns:
Formatted logs
- Return type:
str
- cli.helpers.get_client(command)
Create a client for the invoked command.
- Parameters:
command (str) – Invoked CLI command
- Returns:
client class for the invoked command
- Return type:
BaseClient
- cli.helpers.get_updated_artifacts(body, artifact_path, artifact_ignore_files)
Returns updated artifacts by replacing artifact path and ignore files by the ones provided via cli args.
- Parameters:
body (Dict[str, Any]) – Dictionary containing request body generated from user provided yaml file
artifact_path (str | None) – Path to the artifact.
artifact_ignore_files (List[str] | None) – Ignore files to use when creating artifact.
- Returns:
Dictionary containing updated artifacts
- Return type:
Dict[str, Any]
- cli.helpers.parse_build_arguments(build_arguments)
Parses build arguments provided via cli args to the format {name: arg1, value: value1}.
- Parameters:
build_arguments (List[str]) – List of build arguments provided via cli args
- Returns:
List of build arguments in the required format
- Return type:
List[Dict[str, str]]
- Raises:
BadParameterException – If a value is invalid
- cli.helpers.parse_params(params)
Parse parameters into key-value pairs.
- Parameters:
params (Optional[List[str]]) – List of key-value pairs
- Returns:
Dictionary of key-value pairs
- Return type:
Dict[str, str]
- Raises:
BadParameterException – If a value is invalid
>>> params = ["foo=1", "bar=2"] >>> vals = parse_params(params) >>> vals {'foo': '1', 'bar': '2'}
Raises an error if a value is invalid >>> parse_params([“bar==foo”]) #doctest: +IGNORE_EXCEPTION_DETAIL Traceback (most recent call last): … BadParameterException: Unable to parse: bar==foo
- cli.helpers.remove_unknown_args(args, func)
Filters keys from dictionary which are not accepted by the function.
- Parameters:
args (Dict[str, Any]) – dictionary to filter
func (Callable) – function to filter for
- Returns:
filtered dictionary
- Return type:
Dict[str, Any]
- cli.helpers.template_handler(file, params_file=None, params=None, description_file=None)
Loads and returns the rendered template.
- Parameters:
file (str) – Path to the template file.
params_file (Optional[str]) – Path to the params map file.
description_file (str | None) – (Optional[str]): Path to the description markdown/text file
params (Optional[List[str]]) – List of params to override.
- Returns:
Rendered template with values substituted.
- Return type:
Dict[str, Any]