Skip to content

External dependencies

Kapitan has the functionality to fetch external dependencies from remote locations.

Supported dependencies types are:

Usage

Kapitan by default will not attempt to download any dependency, and rely on what is already available.

Basic fetching

You can use the fetch option to explicitly fetch the dependencies:

kapitan compile --fetch

.kapitan

to make it default, then simply use kapitan compile

...
compile:
  fetch: true

This will download the dependencies and store them at their respective output_path.

Overwrite local changes

When fetching a dependency, Kapitan will refuse to overwrite existing files to preserve your local modifications.

Use the force-fetch option to force overwrite your local files in the output_path.

kapitan compile --force-fetch

.kapitan

to make it default, then simply use kapitan compile

...
compile:
  force-fetch: true

Caching

Kapitan also supports caching Use the --cache flag to cache the fetched items in the .dependency_cache directory in the root project directory.

```shell
kapitan compile --cache --fetch
```

Defining dependencies

Syntax

parameters:
  kapitan:
    dependencies:
    - type: git
      output_path: path/to/dir
      source: git_url # mkdocs (1)!
      subdir: relative/path/from/repo/root (optional) # mkdocs (2)!
      ref: tag, commit, branch etc. (optional) # mkdocs (3)!
      submodules: true/false (optional) # mkdocs (4)!
  1. Git types can fetch external git repositories through either HTTP/HTTPS or SSH URLs.
  2. Optional supports for cloning just a sub-directory
  3. Optional support for accessing them in specific commits and branches (refs).
  4. Optional support to disable fetching the submodules of a repo.

Note

This type depends on the git binary installed on your system and available to Kapitan.

Example

Say we want to fetch the source code from our kapitan repository, specifically, kapicorp/kapitan/kapitan/version.py. Let's create a very simple target file inventory/targets/kapitan-example.yml.

parameters:
  kapitan:
    vars:
      target: kapitan-example
    dependencies:
    - type: git
      output_path: source/kapitan
      source: git@github.com:kapicorp/kapitan.git
      subdir: kapitan
      ref: master
      submodules: true
    compile:
    - input_paths:
      - source/kapitan/version.py
      input_type: jinja2 # just to copy the file over to target
      output_path: .

Syntax

parameters:
  kapitan:
    dependencies:
    - type: http | https # mkdocs (2)!
      output_path: path/to/file # mkdocs (1)!
      source: http[s]://<url> # mkdocs (2)!
      unpack: True | False # mkdocs (3)!
  1. output_path must fully specify the file name. For example:
  2. http[s] types can fetch external dependencies available at http:// or https:// URL.
  3. archive mode: download and unpack

Example

Say we want to download kapitan README.md file. Since it's on Github, we can access it as https://raw.githubusercontent.com/kapicorp/kapitan/master/README.md. Using the following inventory, we can copy this to our target folder:

parameters:
  kapitan:
    vars:
      target: kapitan-example
    dependencies:
    - type: https
      output_path: README.md
      source: https://raw.githubusercontent.com/kapicorp/kapitan/master/README.md
    compile:
    - input_paths:
      - README.md
      input_type: jinja2
      output_path: .

Syntax

parameters:
  kapitan:
    dependencies:
    - type: helm
      output_path: path/to/chart
      source: http[s]|oci://<helm_chart_repository_url>
      version: <specific chart version>
      chart_name: <name of chart>
      helm_path: <helm binary>

Fetches helm charts and any specific subcharts in the requirements.yaml file.

helm_path can be used to specify where the helm binary name or path. It defaults to the value of the KAPITAN_HELM_PATH environment var or simply to helm if neither is set. You should specify only if you don't want the default behavior.

source can be either the URL to a chart repository, or the URL to a chart on an OCI registry (supported since Helm 3.8.0).

Example

If we want to download the prometheus helm chart we simply add the dependency to the monitoring target. We want a specific version 11.3.0 so we put that in.

parameters:
  kapitan:
    vars:
      target: monitoring
    dependencies:
      - type: helm
        output_path: charts/prometheus
        source: https://kubernetes-charts.storage.googleapis.com
        version: 11.3.0
        chart_name: prometheus
    compile:
      - input_type: helm
        output_path: .
        input_paths:
          - charts/prometheus
        helm_values:
        alertmanager:
            enabled: false
        helm_params:
          namespace: monitoring
          name: prometheus