Skip to main content

A python based plugable and extensible manifest processing system

Project description

py_animus

animus as in a sense of purpose and reason

A python based plugable and extensible manifest processing system

The general idea is to create an extensible system that would be responsible for processing YAML Manifest files (similar to Kubernetes) in a consistent way to ensure the desired state as described in these files can be achieved.

Why use this solution

The project was created as a result of finding a better way to manage environments with a mixture of deployment technologies including AWS CloudFormation and Terraform.

This project is not a replacement of any of these technologies but rather a wrapper of sorts that can use any number of existing deployments systems in any number of on-premise or public cloud scenarios.

More specifically, this project includes the base classes and basic processing and will rely on other projects to provide the detailed implementation logic for systems like AWS CloudFormation and Terraform.

Note Imagine you have a mixed on-premise environment where you have some infrastructure as code in shell scripts and Terraform and you also have several public cloud accounts, each with their own tooling for deploying infrastructure as code. Now imagine you have complex applications that need to provision resources in multiple of these environments when deployed. How to you coordinate and orchestrate something like that? Existing tools like Terraform and others could be used. This implementation is a Python based approach to this problem and does not replace any of your existing tooling, but merely helps you bind it all together to perform some really complex orchestration.

Although the initial focus was on Infrastructure, it could very well be used in many other types of scenarios, including:

  • Provisioning of public cloud accounts in a bootstrapping type scenario
  • Deploying a mixture of Kubernetes based applications where some may use Helm and others using other technologies and/or package management solution.

Advantages of this system or approach:

  • None of your existing tooling have to be replaced and often no additional modifications are required
  • This tool can assist in orchestration of several existing tools to accomplish a single goal, for example the provisioning of infrastructure to support the deployment of an application
  • This tool has no knowledge of anything, and all logic to process any manifest needs to be provided as Python code. In the future there will hopefully be a growing library of manifest processing implementations that support a growing number of environments and tools
  • Implementation classes can be versioned and can be tied to specific versions of a manifest. In a real life scenario you could maintain various versions of implementation logic and manifests along side each other.
  • A built in manifest dependency reference system allows you to dictate which manifests depend on which other manifests. The system will determine from this the order in which manifests needs to be applied
  • The solution provides a class to store various variables that are shared and usable among all manifest implementations. Therefore, some context derived in the processing of one manifest can be stored and made available for consuming while processing other manifest implementations.
  • The logic for applying and deleting manifest state is provided and in future releases also rollback and other features will be supported
  • A basic command line tool is provided, as well as a containerized version of the command line tool. Just point to the class sources and the manifests and the system will process and implement state as defined and implemented.
  • Apart from the command line tool, it is also possible to have full control over the processing of manifests, as all classes can be extended as required. You can therefore roll your own unique version of the command line tools.

what is animus

The Manifest File

Any Manifest file has the following top-level attribute names:

  • kind
  • apiVersion
  • metadata
  • spec

The goal is to implement classes that can process any kind of manifest of a specific version (or range of versions).

Processing a class means essentially to take the metadata and spec sub-attributes into consideration to ensure the stated configuration is applied during processing.

Processing must ensure that the desired end-state of the manifest can be implemented by user-defined logic.

Overall the system needs to be able to derive the implemented state versus the desired state in order to calculate and implement changes required to reach a desired state as defined in the manifest.

If this sounds very familiar, then yes - it is basically how Kubernetes work. The difference is that this library is not Kubernetes specific and aims to be more generalized methods that could be employed by potentially any system that must be continuously monitored and updated to fit a desired state.

Documentation

Warning I no longer consider this to be beta software, but real life usage is still limited. Therefore note that there may still be bugs. Please log all bugs as an issue.

Quick Intro Usage

Installation

This project is also hosted on https://pypi.org/project/py-animus/

Installation:

pip install py-animus

Note It is always a good idea to use Python Virtual environments and I encourage it as well.

Using pre-built Docker Image

Pull the image:

docker pull ghcr.io/nicc777/py-animus:latest

Get quick help:

docker run --rm -e "DEBUG=1" ghcr.io/nicc777/py-animus:latest -h

Use (as per the hello world example):

docker run --rm -e "DEBUG=1" \
  -v $PWD/examples/hello-world/src:/tmp/src \
  -v $PWD/examples/hello-world/manifest:/tmp/data \
  -v /tmp/results:/tmp/hello-world-result \
  ghcr.io/nicc777/py-animus:latest apply -m /tmp/data/hello-v1.yaml -s /tmp/src

The above command will create a file in /tmp/results with the content as defined in the manifest file:

$ cat /tmp/results/output.txt
This is the contents of the file
specified in the content property
of the spec.

More complex example:

docker run --rm -e "DEBUG=1" \
  -v $PWD/examples/linked-manifests/src:/tmp/src \
  -v $PWD/examples/linked-manifests/manifest/round_1:/tmp/data \
  -v /tmp/results:/tmp/example-page-result \
  ghcr.io/nicc777/py-animus:latest apply -m /tmp/data/linked-v1.yaml -s /tmp/src

To reverse out any of the applied commands, just use the command delete instead of apply

The file will no longer be available

$ cat /tmp/results/output.txt
cat: /tmp/results/output.txt: No such file or directory

Acknowledgements

Icons

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

py_animus-1.0.6.tar.gz (36.7 kB view details)

Uploaded Source

Built Distribution

py_animus-1.0.6-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file py_animus-1.0.6.tar.gz.

File metadata

  • Download URL: py_animus-1.0.6.tar.gz
  • Upload date:
  • Size: 36.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for py_animus-1.0.6.tar.gz
Algorithm Hash digest
SHA256 76a8fa08901aab0f5b774ab90df45b662f6d7da9e499d8e1fd5a7c5c11eeb40d
MD5 0e8c3245467c9affa3f928386a1337e7
BLAKE2b-256 9ec0d4010a32638a40e3baa01bf5ad07de1cbc68e76642b804250ed604b7afad

See more details on using hashes here.

Provenance

File details

Details for the file py_animus-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: py_animus-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 29.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for py_animus-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 929a14a46deebbef896aaf60f979972d7131f00f0ecd6934c98aa9a9a0165e38
MD5 f8a69254398f0c84f44eda6c90ae9d9f
BLAKE2b-256 8271a7b1d13173c43d4e48644352a5065d692ba3afae544a99c3da616cf6d80f

See more details on using hashes here.

Provenance

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