Skip to main content

Sprinkling imperative logic into your template generation process.

Project description

Templatizer

Templatizer allows for sprinkling in some imperative logic to your declarative configuration files.

Why Imperative?

While a fully declarative configuration file is often nice to be able to describe the intended state of the world in a single place, these can also become quite verbose over time.

For Kubernetes, for example, you might be configuring a number of monitoring jobs. These will have different storage, CPU, and memory requirements. They also have unique configuration requirements for each one. I might be holding it wrong, but I find this very hard to make work in Helm and Kustomize without repeating myself over and over again.

What I want is something that runs before Helm, Kustomize, and whatever other tools you're using. I want something to generate files with the ability to do imperative logic first.

Example

import templatizer

class Simple(templatizer.Templatable):
    prop = 12345

class Imperative(templatizer.Templatable):
    tick = 0

    def prop(self):
        return 12345 + self.tick

simple = Simple()
assert simple.propval('prop') == 12345

imperative = Imperative()
assert imperative.propval('prop') == 12345
imperative.tick = 1
assert imperative.propval('prop') == 12346

The templatizer.run function takes a list of Templatable objects, generates them into strings, and adds separators in between. By default the --- separator is used, which is useful for generating YAML documents. This can be changed to suit your use case.

Kubernetes

The templatizer.k8s module includes generated definitions from the Kubernetes OpenAPI Spec.

This allows for generating Kubernetes manifests with imperative hooks. Examples of this are provided in the examples/ directory.

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

pytemplatize-0.0.5.tar.gz (74.7 kB view details)

Uploaded Source

Built Distribution

pytemplatize-0.0.5-py3-none-any.whl (76.5 kB view details)

Uploaded Python 3

File details

Details for the file pytemplatize-0.0.5.tar.gz.

File metadata

  • Download URL: pytemplatize-0.0.5.tar.gz
  • Upload date:
  • Size: 74.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for pytemplatize-0.0.5.tar.gz
Algorithm Hash digest
SHA256 dbf77970743a7da1b8a9eb38e1447b46f802c18ffd79e0c6da3d6ee5283d741b
MD5 a7a9731447d0aa549391764b4fc8c069
BLAKE2b-256 19dbbbba5b70c1052ab3078b6efea2abb003940579f2fcf6c155ef170a8ecf92

See more details on using hashes here.

File details

Details for the file pytemplatize-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: pytemplatize-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 76.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for pytemplatize-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5497a0ba7991d1a6394386a408989a98dbcaf25eac14e203ae0aa128235a66a5
MD5 920b8d67d193227326a0b04bc5ee3e65
BLAKE2b-256 be505154a2e86131ec884b20261db6a588c39f6803f818be43bb2320e690879e

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