Ease configuration of values for Helm charts in your IDE
The project provides several plugins to generate JSON schemas for values of Helm charts.
These schemas can then be used to document, validate and auto-complete Helm values in your IDE:
The plugins can extract the JSON schemas named values.schema.json
from all chart dependencies.
They can also be configured to download JSON schemas from external JSON schema repositories.
The aggregated JSON schema can then be used to provide auto-completion and documentation on values.yaml in your IDE.
Finally, the Gradle plugin can also be used to generate and publish JSON schemas to external JSON schema repositories.
All business logic of the plugins is maintained in a java shared library published on maven Central repository.
This java library can be used to provide JSON schema generation for other IDE or build tools (e.g. Maven plugin).
The plugins generate several JSON schemas to support the validation of Helm values in different contexts.
Schema aggregated-values.schema.json
is generated
by Gradle task aggregateJsonSchema
or aggregation actions in IntelliJ plugin
.
It is intended to provide documentation, validation and auto-completion in your IDE on values.yaml of the current chart.
It aggregates:
- JSON schemas extracted from packages of chart dependencies
- JSON schemas of dependencies downloaded from external JSON schema repositories
JSON schemas are only extracted from package of a chart dependency if there is no external JSON schema repository
defined for this dependency.
A fallback schema is generated if package of chart dependency is missing or invalid.
The description of the fallback schema provides more information on the extract issue.
JSON schemas are only downloaded from external JSON schema repositories if an external JSON schema repository defined
for this dependency.
A fallback schema is generated if JSON schema can't be downloaded from the external repository (schema not found,
network failure ...).
The description of the fallback schema provides more information on the download issue.
It is also intended to provide documentation, validation and auto-completion on extra values applied on a
packaged chart.
e.g.:
helm install my-chart-1.2.3.tgz -f extra-values.yaml
Schema values.schema.json
is generated
by Gradle task generateJsonSchemas.
It is intended to be published in a JSON schema repository, so that it can be referenced in schemas of other charts.
This schema contains several references ($ref
) to other schemas and shouldn't be packaged in Helm charts.
Schema global-values.schema.json
was generated
by Gradle task generateJsonSchemas until version 0.3.0.
It was intended to be published in a JSON schema repository, so that it can be referenced in schemas of other charts.
Since #11 (0.4.0), schema global-values.schema.json
is no more generated and published to external repositories.
It is however still used in generation of schema aggregated-values.schema.json
for retro-compatibility with schemas
generated with previous versions.
The support of global values schema files in aggregation is however deprecated and will be removed in 1.0.0
.
In some cases, generated JSON schemas may not contain enough information.
This can be the case when the chart defines its own templates and its own values.
To allow such customizations, plugins use json-patch library to patch the generated JSON schemas.
Patch is enabled by creation of a file in the base folder of the chart (same folder as Chart.yaml
):
values.schema.patch.json
orvalues.schema.patch.yaml
: patch forvalues.schema.json
generated by Gradle task generateJsonSchemas
Since #12 (0.4.0), this patch file also impactsaggregated-values.schema.json
that is based onvalues.schema.json
.aggregated-values.schema.patch.json
oraggregated-values.schema.patch.yaml
: additional patch foraggregated-values.schema.json
generated by Gradle task aggregateJsonSchema or by IntelliJ action to refresh JSON schemas
Patch files in YAML format have been introduced with #55 (0.9.0).*
If JSON patch file is present, YAML patch file is ignored.
Generated JSON schemas can be used in multiple ways to validate content of values.yaml
of a Helm chart:
- in IntelliJ IDEA using JSON schema validation features provided by IntelliJ IDEA,
- in Visual Studio code using JSON schema validation features provided by VS code plugins,
- with Gradle using new Gradle task
validateHelmValues
introduced in 0.7.0.
It is important to be aware that IntelliJ IDEA, VS code & Gradle plugins use different JSON schema validators.
The same generated JSON schemas may therefore produce different validation results depending on the tool used to
validate it.
As an example, generated JSON schemas
use keyword unevaluatedProperties
introduced in Draft 2019-09.
IntelliJ IDEA only supports JSON schema specification up to Draft-07 and therefore ignores this keyword.
Validation errors linked to this keyword are therefore not correctly identified by IntelliJ IDEA.
On the other hand, Gradle plugin
uses JSON schema validator from networknt and fully supports
Draft 2020-12.
Validation errors linked to keyword unevaluatedProperties
are therefore be correctly identified by Gradle plugin.
Usage of unevaluatedProperties
keyword in generated JSON schemas is required to allow correct JSON schema composition,
as explained
in JSON schema specification.
Validation differences should disappear when Draft 2019-09 is supported by JSON schema validators of all IDE.
Gradle and IntelliJ plugins can be configured to download JSON schemas from external JSON schema repositories.
External schema repositories can be useful to provide documentation for Helm charts that do not contain a JSON schema.
They can also be useful if you only want JSON schema validation to be only informative in your IDE.
helm install
fails when provided values are not validated by the packaged JSON schema.
Finally, JSON schemas stored in external JSON schema repositories can contain references ($ref
) to other schemas.
This gives more flexibility and industrialization capabilities
compared to JSON schemas packaged in Helm charts that must be self-contained.
Gradle and IntelliJ plugins ensure that referenced JSON schemas are also downloaded
and that references in the downloaded schemas are updated to use the locally downloaded schemas.
Repository mappings can be configured in plugins to define JSON schema repository for each Helm repository.
Plugins use the repository key in dependencies of Chart.yaml
to define the JSON schema repository
that must be used to download JSON schemas for each dependency.
Given the following Chart.yaml:
apiVersion: v2
name: my-bundle
version: 0.1.0
dependencies:
- name: another-bundle
version: 0.2.0
repository: "@bundles"
- name: simple-app
version: 0.3.0
repository: "@apps"
- name: thirdparty-chart
version: 0.4.0
repository: "@thirdparty"
The plugins can be configured with following configuration to download JSON schemas for the first 2 dependencies:
Helm repository ID | JSON schema repository |
---|---|
@bundles |
https://my-schemas/repository/bundles |
@apps |
https://my-schemas/repository/apps |
More information on configuration of JSON schema repositories is provided in Gradle plugin and IntelliJ plugin documentation.
Each schema repository should be structured as follows:
repository
|- chart-with-single-schema
|- chart-version
|- values.schema.json # JSON schema for values.yaml (including global section)
|- chart-with-separate-global-schema
|- chart-version
|- values.schema.json # JSON schema for values.yaml (including a reference to schema for global section)
|- global-values.schema.json # JSON schema for global section in values.yaml
File names for JSON schemas can be overridden for each repository.
Default values are provided:
- JSON schema for values.yaml:
values.schema.json
- JSON schema for global section in values.yaml (deprecated):
global-values.schema.json
More information to configure custom file names is provided in Gradle plugin and IntelliJ plugin documentation.
JSON schema repositories can be secured with basic authentication.
Each schema repository can be configured with user and password.
More information to configure security for repositories is provided in Gradle plugin and IntelliJ plugin documentation.