Automatic Updates for Kustomize Resources
Project description
lennybot
Usage
GitHub Actions
- uses: raynigon/lennybot@v1.0.0
env:
LB_CONFIG_FILE: ".github/lennybot.yaml"
LB_GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
CLI
Install package with pip install lennybot
.
To start the application run the lennybot
command.
You can specify the Action which should be executed.
This action can be "ci", "plan" or "apply".
The CI CLI action executed apply and handles git operations such as, commit and branch creation.
The plan action allows to plan updates and save the plan for later.
The apply action can either execute an existing plan, or create a new plan and apply it immediately.
Docker
To run the lennybot as docker image execute:
docker run --rm -v "$(pwd):/workspace/ raynigon/lennybot
How it works
The lennybot allows to define multiple applications. Each application has to have a version source, which can be queried to determine the latest version. If a newer version is available, the lennybot executes multiple pre defined actions per application. E.g. Update Docker Image Tags. Sometimes there are conditions which need to be fulfilled before the action can be executed. These conditions can be specified as checks. E.g. Check if the docker image is available in the registry, because sometimes a new version of an applications gets released, but the docker image is not available yet.
The applications, sources, checks and actions can be configured in the config.yml
file.
For more information see below.
Configuration
The lennybot can be configured via the config.yml
file and environment variables.
If the config.yml
file is not in the root of the current working directory, the LB_CONFIG_FILE
environment variable can be used to pass the location of the configuration file to the lennybot.
The configuration file has multiple top level objects. Each section represents a configuration object.
State
Path | Description |
---|---|
state.file | The state file which is used to store the version of each application |
GitHub
Path | Description |
---|---|
state.pr.enabled | Toggle PR creation in CI mode. Has to be either true or false |
state.pr.repository | The name of the repository in github on which the PR should be created |
state.pr.branchPrefix | Prefix for the branch name which should be used to create the PRs |
Applications
Property | Description |
---|---|
applications[*].name | The name of the application which should be updated |
applications[*].source | The configuration for the source of the latest version. This is specific to the type of source, see below for the diffrent source types. |
applications[*].actions[*].type | The action has to be one of these types "image-tag-update", "download-resources" or "update-yaml". See below for details. |
applications[*].actions[*].url | |
applications[*].actions[*].target | |
applications[*].actions[*].image | |
applications[*].actions[*].kustomizePath | |
applications[*].actions[*].tagPattern | |
applications[*].actions[*].targetFile | |
applications[*].actions[*].yamlPath | |
applications[*].actions[*].valuePattern |
Sources
GitHub Source
Property | Description |
---|---|
.type | The source has to be either of the type "github" or of the type "github-query". See below for details. |
.repository | The GitHub Repository which should be used to determine the latest version |
.regex | The regex pattern which is used to extract the semver version code from the tag value |
GitHub Query Source
Property | Description |
---|---|
.type | The source has to be either of the type "github" or of the type "github-query". See below for details. |
.repository | The GitHub Repository which should be used to determine the latest version |
.regex | The regex pattern which is used to extract the semver version code from the tag value |
Checks
Actions
Image Tag Update Action
Property | Description |
---|---|
.type | The action has to be one of these types "image-tag-update", "download-resources" or "update-yaml". See below for details. |
.url | |
.target | |
.image | |
.kustomizePath | |
.tagPattern | |
.targetFile | |
.yamlPath | |
.valuePattern |
Download Resource Action
Update YAML Action
Update JSON Action
Update Dockerfile Action
Origin
Once upon time a colleague (Lenny) left my team. Besides being an Apache Solr genius, one of the tasks he really liked doing, was the updating of the dependencies in our applications. Since everyone else in the team didnt like this job, we needed some automation for this. The lennybot was born to replace our colleague. Since then the lennybot evolved and finally got replaced by the dependabot. Some years later i needed a solution to upgrade components managed with kustomize. This lead to the creation of a new lennybot which is able to automatically search for updates and upgrades the resources with their latest versions.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for lennybot-1.0.31-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | f88be2f3e9f128663c9ae751374e177eaae3a42121156a4edd0d001a8f7a9e5b |
|
MD5 | c371da8c8204b89ab7e2dc216ee35c85 |
|
BLAKE2b-256 | e84ff599d249d23daa2961a00062334c1ec123a92817dcfa5e23d805c42df5ae |