Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/biobuddies/helicopyter
Python-defined infrastructure
https://github.com/biobuddies/helicopyter
ansible cdktf python terraform
Last synced: 3 months ago
JSON representation
Python-defined infrastructure
- Host: GitHub
- URL: https://github.com/biobuddies/helicopyter
- Owner: biobuddies
- License: mpl-2.0
- Created: 2023-06-17T15:10:56.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-01T23:11:32.000Z (3 months ago)
- Last Synced: 2024-11-07T17:17:01.573Z (3 months ago)
- Topics: ansible, cdktf, python, terraform
- Language: Shell
- Homepage:
- Size: 155 KB
- Stars: 5
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Helicopyter
Helicopyter allows people to conveniently describe infrastructure using Python.
Perhaps like a helicopter hovering between the clouds and the ground, it allows this in a way that's
less like the AWS Cloud Development Kit (CDK) and more like Terraform.## Background
Helicopyter uses [CDKTF](https://github.com/hashicorp/terraform-cdk) and is inspired by
[Configerator](https://research.facebook.com/file/877841159827226/holistic-configuration-management-at-facebook.pdf) and
[Terraformpy](https://github.com/NerdWalletOSS/terraformpy).## What Helicopyter does (goals)
- Name in the resource-prefix Terraform style, instead of the hash-suffix CDK style. This makes
reviewing plan output easier, and aligns with "Namespaces are one honking great idea -- let's do
more of those!"
- Simplify `main.py` files by
* Removing the `App` class, which does not correspond to a Terraform concept. Instead
- A string attribute provides name information
- Resource-specific scopes are provided by `HeliStack.push()`
- The `synth` method is replaced by a module-level function, and called from a central
location instead of distributed boilerplate.
* Making custom TerraformStack/HeliStack subclasses optional instead of required. Defining a
subclass only to instantiate one instance of it is more complicated than instantiating the
base class and modifying the instance.
```diff
--- documentation/learn_cdktf_docker.py 2024-08-05 08:47:30
+++ documentation/learn_helicopyter_docker.py 2024-08-05 08:47:25
@@ -1,28 +1,18 @@
-from cdktf import App, TerraformStack
from cdktf_cdktf_provider_docker.container import Container
from cdktf_cdktf_provider_docker.image import Image
-from cdktf_cdktf_provider_docker.provider import DockerProvider
-from constructs import Construct
+from helicopyter import HeliStack
-class MyStack(TerraformStack):
- def __init__(self, scope: Construct, ns: str):
- super().__init__(scope, ns)
+def synth(stack: HeliStack):
-
- DockerProvider(self, 'docker')
+ stack.provide('docker')
- docker_image = Image(self, 'nginxImage', name='nginx:latest', keep_locally=False)
+ docker_image = stack.push(Image, 'nginxImage', name='nginx:latest', keep_locally=False)
- Container(
- self,
- 'nginxContainer',
- name='tutorial',
- image=docker_image.name,
- ports=[{'internal': 80, 'external': 8000}],
- )
+ stack.push(
+ Container,
+ 'nginxContainer',
+ name='tutorial',
+ image=docker_image.name,
+ ports=[{'internal': 80, 'external': 8000}],
+ )
-
-
-app = App()
-MyStack(app, 'learn-cdktf-docker')
-
-app.synth()
```
- Enable hand-written and auto-generated Hashicorp Configuration Language (HCL) files to
co-exist, allowing incremental adoption.
- Separate object instantiation from synthesis, allowing Python script to import the objects/data
and do completely different things with them.
- Golang Terraform has a pretty good command line interface. The `ht[aip]` functions in
`includes.sh` try to wrap it very lightly.## What Helicopyter will probably never do (non-goals)
- Support languages other than Python
- Make use of CDKTF's command line interface. Integration with it is untested and not recommended.## What Helicopyter might do in the future
- Support multiple backend configurations per codename
- Iterate on supported directory structures. For hysterical raisins, the currently supported
directory structure is `f'deploys/{cona}/terraform'`, grouping
* Primarily by COdeNAme (CONA), which is probably synonymous with application, deployment, and service
* Secondarily by tool, such as `ansible`, `docker`, `terraform`, `python`
- `__str__()` for `to_string()`, etc.
- Why do we need a Node.js server? Can we build dataclasses or Pydantic models out of the type annotations already being
generated?
- Provide helper classes or functions for useful but annoyingly verbose patterns such as local-exec provisioner command
- Backend / state file linter such as: prod must exist, and region/bucket/workspace_key_prefix/key must follow pattern