Skip to main content

Keep your dependencies in your projects fresh and up2date

Project description

I’m Kebechet, goddess of freshness. I will keep your sources and dependencies fresh and up-to-date.

Kebechet is a SourceOps bot that automates updating dependencies of your project. Currently, it supports managing and updating Python projects based on pipenv files (Pipfile and Pipfile.lock) or requirements.txt/requirements.in files (see pip-tools - Kebechet is a replacement for it)

Configuration of Kebechet

Kebechet is configured using a simple YAML configuration file. Check documentation of managers to get all the available options.

Each configuration entry configures a manager. Please check managers and examples to get info about configuration options.

The YAML configuration file can be supplied directly as a path to a file on filesystem as well as a URL to a file - handy for managing configuration of your Kebechet deployment in a Git repository (you have to supply a URL to a raw YAML configuration file).

Managers

Kebechet consists of managers that perform certain actions.

A list of managers with their configuration (documentation lives in the manger directory) can be found in the repo.

Issues created by Kebechet

If there are any issues that have serious impact on Kebechet functionality, Kebechet will automatically open an issue in the given repository. These issues can be configuration issues of Kebechet itself or issues in manager itself.

Suppressing bot verbosity

Bot updates pull requests and issues and notifies about updates via comments (to issues or pull requests). You can suppress this behaviour by setting lable ‘silent-bot’ to issue or to a pull request. The bot will still perform updates but update comments will not be added.

This is especially helpful for example if you have failing updates of your dependency and you would like to keep the pull request opened and check for fix later. Setting ‘silent-bot’ label to the PR will suppress Kebechet to post updates and you will not retrieve spam messages anymore.

Notes

To issue an update to Git repository, Kebechet creates branches in the provided repository.

Deploying Kebechet

To deploy kebechet on OpenShift cluster. Use the following Ansible command with required parameters:

ansible-playbook \
  --extra-vars=OCP_URL=<openshift_cluster_url> \
  --extra-vars=OCP_TOKEN=<openshift_cluster_token> \
  --extra-vars=KEBECHET_INFRA_NAMESPACE=<openshift_cluster_namespace> \
  --extra-vars=KEBECHET_APPLICATION_NAMESPACE=<openshift_cluster_namespace> \
  --extra-vars=KEBECHET_CONFIGURATION_PATH=<config.yaml> \
  --extra-vars=KEBECHET_TOKEN=<oauth_token> \
  --extra-vars=KEBECHET_SSH_PRIVATE_KEY_PATH=<git_ssh_private_key_path> \
  playbooks/provision.yaml
  • KEBECHET_SSH_PRIVATE_KEY_PATH: The path where the GitHub ssh private key is stored should be provided. (Example: $HOME/.ssh/id_rsa). If the field is undefined then the script will create the ssh keys for you and then you can set up the given public key to GitHub repository.

  • KEBECHET_TOKEN: To raise a pull request bot requires user rights and premissions. The GitHub OAuth tokens are to be set for raising pull request whenever updates are encounter by the Kebechet.

  • KEBECHET_CONFIGURATION_PATH: Path to the YAML configuration file to be used for Kebechet to check for dependency updates.

  • KEBECHET_INFRA_NAMESPACE: The OpenShift namespace can be used for the infrastructural purposes, all the images stream are stored in the KEBECHET_INFRA_NAMESPACE.

  • KEBECHET_APPLICATION_NAMESPACE: The OpenShift namespace can be used for the application purposes, all the templates, builds, secrets, configmap and jobs are stored in the KEBECHET_APPLICATION_NAMESPACE.

  • OCP_URL and OCP_TOKEN: The OpenShift credentials used to login to.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kebechet-1.0.5.tar.gz (79.5 kB view details)

Uploaded Source

Built Distribution

kebechet-1.0.5-py3-none-any.whl (44.8 kB view details)

Uploaded Python 3

File details

Details for the file kebechet-1.0.5.tar.gz.

File metadata

  • Download URL: kebechet-1.0.5.tar.gz
  • Upload date:
  • Size: 79.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/39.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.8

File hashes

Hashes for kebechet-1.0.5.tar.gz
Algorithm Hash digest
SHA256 b66ac4e9e65c69cd6ed4d0542455d58d7daba7923981d07ac8d10ac933012d7f
MD5 7595c6834ac7634857a472581d9df43d
BLAKE2b-256 9a8f823040bfa02015217f752f9ce54d33f874095e5c564425708f0d2da6cae4

See more details on using hashes here.

File details

Details for the file kebechet-1.0.5-py3-none-any.whl.

File metadata

  • Download URL: kebechet-1.0.5-py3-none-any.whl
  • Upload date:
  • Size: 44.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/39.2.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.6.8

File hashes

Hashes for kebechet-1.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 4b82c47e66d4b4376db6f50f887a7555b3845e8f4a3c0cbe0c4b23c30b8f7369
MD5 7e3d6f5cca58e3f688958967fcd4ac77
BLAKE2b-256 24787bd65d70bcb66a9edcab76c7940fb4a4bd18e2e216bb5209e695fb2c0b0f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page