Skip to content

Ease configuration of values for Helm charts in your IDE

License

Notifications You must be signed in to change notification settings

fstaudt/helm-values

Repository files navigation

Helm values

Build Maven Central

IntelliJ
Version Downloads

Gradle
Gradle Plugin Portal

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).

Supported by

JetBrains

Licenses for Open Source Development

SBS

SBS

JSON schemas

Generated JSON schemas

The plugins generate several JSON schemas to support the validation of Helm values in different contexts.

aggregated-values-schema.json

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

values.schema.json

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.

global-values.schema.json (deprecated)

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.

Patch for generated JSON schemas

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):

Patch files in YAML format have been introduced with #55 (0.9.0).*
If JSON patch file is present, YAML patch file is ignored.

JSON schema validation

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.

JSON schema validation results

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.

JSON schema repositories

Gradle and IntelliJ plugins can be configured to download JSON schemas from external JSON schema repositories.

Why use external repositories for JSON schemas ?

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.

Configure JSON schema repositories

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.

JSON schema repository structure

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

Custom JSON schema file names

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 repository security

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.