This repository is part of Project Syn. For documentation on Project Syn and this component, see https://syn.tools.
Please note that this project is in its early stages and under active development.
See CHANGELOG.md for changelogs of each release version of Commodore.
See DockerHub for pre-built Docker images of Commodore.
Commodore provides opinionated tenant-aware management of Kapitan inventories and templates. Commodore uses Kapitan for the heavy lifting of rendering templates and resolving a hierachical configuration structure.
Commodore introduces the concept of a component, which is a bundle of Kapitan templates and associated Kapitan classes which describe how to render the templates. Commodore fetches any components that are required for a given configuration before running Kapitan, and sets up symlinks so Kapitan can find the component classes.
Commodore also supports additional processing on the output of Kapitan, such
as patching in the desired namespace for a Helm chart which has been rendered
using helm template.
- Python 3.6+, with
python3-devandpython3-venvupdated - Poetry
- Docker
-
Install requirements
Install poetry according to the upstream documentation.
Create the Commodore environment:
poetry installBuild the Kapitan helm binding:
-
Linux:
poetry run build_kapitan_helm_binding -
OS X:
Note: At the moment you'll need a working Go compiler to build the Kapitan Helm bindings on OS X.
poetry run sh -c '${VIRTUAL_ENV}/lib/python3.*/site-packages/kapitan/inputs/helm/build.sh'
-
-
Setup a
.envfile to configure Commodore (don't use quotes):# URL of Lieutenant API COMMODORE_API_URL=https://lieutenant-api.example.com/ # Lieutenant API token COMMODORE_API_TOKEN=<my-token> # Base URL for global Git repositories COMMODORE_GLOBAL_GIT_BASE=ssh://git@github.com/projectsyn # Your local user ID to be used in the container (optional, defaults to root) USER_ID=<your-user-id> # Your username to be used in the commits (optional, defaults to your local git config) COMMODORE_USERNAME=<your name> # Your user email to be used in the commits (optional, defaults to your local git config) COMMODORE_USERMAIL=<your email>
For Commodore to work, you need to run an instance of the Lieutenant API somewhere (locally is fine too).
Commodore component repositories must exist in
${COMMODORE_GLOBAL_GIT_BASE}/commodore_components/with the repository named identically to the component name.Or they must be configured in the
commodore.ymlconfig file in the${COMMODORE_GLOBAL_GIT_BASE}/commodore-defaults.gitrepository. -
Run Commodore
poetry run commodore -
Start hacking on Commodore
poetry shell- Write a line of test code, make the test fail
- Write a line of application code, make the test pass
- Repeat
-
Run linting and tests
Auto format with autopep8
poetry run autopepList all Tox targets
poetry run tox -lvRun all linting and tests
poetry run toxRun just a specific target
poetry run tox -e py38
IMPORTANT: After checking out this project, run mkdir -p catalog inventory dependencies in it before running any Docker commands. This will ensure the folders are writable by the current user in the context of the Docker container.
A docker-compose setup enables running Commodore in a container.
The environment variables are picked up from the local .env file.
By default your ~/.ssh/ directory is mounted into the container and an ssh-agent is started.
You can skip starting an agent by setting the SSH_AUTH_SOCK env variable and mounting the socket into the container.
- Build the Docker image inside of the cloned Commodore repository:
docker-compose build- Run the built image:
docker-compose run commodore catalog compile $CLUSTER_IDDocumentation for this component is written using Asciidoc and Antora. It is located in the docs/ folder. The Divio documentation structure is used to organize its content.
Run the make docs command in the docs subfolder to generate the Antora documentation website locally. The website will be available at the _antora/index.html file.
After writing the documentation, please use the make check command and correct any warnings raised by the tool.
This library is licensed under BSD-3-Clause. For information about how to contribute see CONTRIBUTING.