Auto generation¶
Auto generation happens mostly with Git hooks. You can find the lefthook
configuration here. These pre-commit hooks call different Python scripts to auto generate code for the documentation.
Generation scripts and their respective files¶
Documentation¶
Variables¶
cli_env_vars.env
-- All CLI environment variables in adotenv
file.cli_env_vars.md
-- All CLI environment variables in a table.config_env_vars.env
-- Almost all pipeline config environment variables in adotenv
file. The script checks for each field inKpopsConfig
whether it has anenv
attribute defined. The script is currently unable to visit the classes of fields liketopic_name_config
, hence any environment variables defined there would remain unknown to it.config_env_vars.env
-- Almost all pipeline config environment variables in a table.variable_substitution.yaml
-- A copy of./tests/pipeline/resources/component-type-substitution/pipeline.yaml
used as an example of substitution.
CLI commands¶
Generated by typer-cli
from the code in main.py
. It is called with Python's subprocess
module.
Pipeline and defaults example definitions¶
Generates example pipeline.yaml
and defaults.yaml
for each individual component, stores them and also concatenates them into 1 big pipeline definition and 1 big pipeline defaults definition.
User input
headers/*\.yaml
-- The top of each example. Includes a description comment,type
andname
. The headers forpipeline.yaml
reside in thepipeline-components
dir and thedefaults.yaml
headers reside in thepipeline-defaults
dir. The names of the files must be equal to the respective componenttype
.sections/*\.yaml
-- Each YAML file contains a single section (component attribute) definition. The intention is to keep the minimal set of definitions there from which any component definition can be built. The names of the files must be equal to the respective componenttype
and the attribute name. The sections are used for bothdefaults.yaml
andpipeline.yaml
generation and reside in thepipeline-components
dir.
Generated
pipeline-components/dependencies/*
Cached information about KPOps componentspipeline_component_dependencies.yaml
-- Specifies per component which files in thesections
dir should be used for thepipeline.yaml
generation.defaults_pipeline_component_dependencies.yaml
-- Specifies per component which files in thesections
dir should be used for thedefaults.yaml
generation.kpops_structure.yaml
-- Specifies the inheritance hierarchy of the components and what sections exist in each component.pipeline-components/*\.yaml
-- All single-component pipeline definitions and one big (complete)pipeline.yaml
that contains all of them.pipeline-defaults/*\.yaml
-- All single-component defaults definitions and one big (complete)defaults.yaml
that contains all of them.