Skip to main content

Declarative parametrization, extension and validation of Inmanta DSL models.

Project description

GitOps module

pypi version build status

This package is an integration module that is meant to be used with the inmanta orchestrator: https://docs.inmanta.com

It allows you to easily parametrize a model by defining slices, and then instantiating as many slices as you need to by simply creating json or yaml files in the project repository. This module aims at enabling its users to manage an infra in a "Git-Ops" fashion. Key ideas are:

  1. Declarative Configuration: The desired state of your infrastructure and applications is described in a declarative format (json/yaml files) within a Git repository.
  2. Version Control: Git serves as the central source of truth, meaning all changes are committed to the repository, providing a complete history of the system's evolution.
  3. Automated Synchronization: The orchestrator continuously monitors the Git repository and pulls in new updates.
  4. Pull Requests for Changes: When you want to make a change, you create a pull request to modify the Git repository.
  5. Deployment & Reconciliation: Once the pull request is approved and merged, the orchestrator automatically pulls the changes and deploys them to the live environment, ensuring the actual system state matches the desired state in Git.

All of this is already natively supported by the orchestrator by modifying the main.cf file of a project. This works but scales poorly and it is not possible to track deleted items, this modules aims at addressing these limitations.

More details about the design in the docs folder.

Cli

This module also provides a cli interface, to facilitate the creation of a module based on git_ops and the management of a project using git_ops.

If the module is installed in your venv, just run the git-ops command.

$ git-ops --help
Usage: git-ops [OPTIONS] COMMAND [ARGS]...

  Inmanta module git_ops CLI tool.

Options:
  --log-level [DEBUG|INFO|WARNING|ERROR]
  --help                          Show this message and exit.

Commands:
  module   Commands to manage the module containing slice definitions.
  project  Commands to manage the current Inmanta project.

Running tests

  1. Set up a new virtual environment, then install the module in it. The first line assumes you have virtualenvwrapper installed. If you don't, you can replace it with python3 -m venv .env && source .env/bin/activate.
mkvirtualenv inmanta-test -p python3 -a .
pip install -e . -c requirements.txt -r requirements.dev.txt
  1. Run tests
pytest tests

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

inmanta_module_git_ops-0.2.0.tar.gz (40.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

inmanta_module_git_ops-0.2.0-py3-none-any.whl (34.0 kB view details)

Uploaded Python 3

File details

Details for the file inmanta_module_git_ops-0.2.0.tar.gz.

File metadata

  • Download URL: inmanta_module_git_ops-0.2.0.tar.gz
  • Upload date:
  • Size: 40.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for inmanta_module_git_ops-0.2.0.tar.gz
Algorithm Hash digest
SHA256 e0976b2f6b234c53add6fa0890e5b33fba5787729ceb6516f24927141e720e4f
MD5 d0d4aff83efcb25cadef26a90461550d
BLAKE2b-256 a9e74fc9630f811de522f2c1bdff403ca79569f6689640ca77dacfe3b01c79b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for inmanta_module_git_ops-0.2.0.tar.gz:

Publisher: continuous-delivery.yml on edvgui/inmanta-module-git-ops

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file inmanta_module_git_ops-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for inmanta_module_git_ops-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 03a231e154f918d487e7fa3f62318a303499570c2f50499ccb35786e418dd59c
MD5 99b6db11930e0c40c5302742736cda95
BLAKE2b-256 365109bdf850972a7ee08bf95254b60d8281228977099c692351cb8345eaeb2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for inmanta_module_git_ops-0.2.0-py3-none-any.whl:

Publisher: continuous-delivery.yml on edvgui/inmanta-module-git-ops

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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