Skip to main content

Python infrastructure platform for managing VM workspaces and clusters to deploy and maintain an automated container orchestration platform.

Project description

strata

You already have Terraform. The problem is you have eight environment folders — dev, staging, prd, prd-eu, prd-us, dr, sandbox, perf — and they are 90% identical. Every change gets applied to one folder, forgotten in three others, and you only find out when production drifts. strata is a YAML config layer over Terraform, Helm, and scripts that treats your environments as data, not as copy-pasted folders. One source of truth, one command to validate it, one command to deploy it.

📖 Full documentation


Quick Start

pipx install xyz-strata                        # install
strata sln init                                             # scaffold a new config workspace
strata validate --file stack/my-environment.yaml        # validate before you touch anything
strata deploy run --file deploy/my-environment.yaml     # deploy to the target environment

New here? See the Getting Started guide for the full walkthrough. Dev install: uv sync.


Automation & AI Agents

Set STRATA_OUTPUT=json once (or strata config set output json) and every command returns a structured JSON envelope on stdout:

{
  "success": true,
  "command": "validate",
  "execution_id": "fb063135-...",
  "timestamp": "2026-05-18T14:31:47.267924",
  "data": { "validation_passed": true, "errors": [] },
  "messages": [],
  "errors": []
}

Key conventions for automation:

Concern Guidance
Output format Always use --output json or STRATA_OUTPUT=json
Exit codes 0 success · 1 system failure · 2 bad args · 3 validation failure
Workspace Set STRATA_WORK_PATH to target a workspace without cd
Error stream In console mode, errors go to stderr; structured JSON always goes to stdout
Execution correlation execution_id in the envelope maps directly to strata audit list --execution-id <id>
Env-var overrides Every CLI flag has an XYZ_<OPTION> equivalent (STRATA_VERBOSE=true, STRATA_QUIET=true, …)

Safe read-only commands that work outside an initialized workspace (INIT_REQUIRED=False): validate, status, schema list, schema get.


License

GNU Affero General Public License v3.0 — see LICENSE.

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

xyz_strata-0.0.6.tar.gz (313.2 kB view details)

Uploaded Source

Built Distribution

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

xyz_strata-0.0.6-py3-none-any.whl (430.9 kB view details)

Uploaded Python 3

File details

Details for the file xyz_strata-0.0.6.tar.gz.

File metadata

  • Download URL: xyz_strata-0.0.6.tar.gz
  • Upload date:
  • Size: 313.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for xyz_strata-0.0.6.tar.gz
Algorithm Hash digest
SHA256 b2c9a56257b39513174eba01a82a97f4e3589afa4a0d8f92d617698988829a9f
MD5 d4725caa4594c8e5f89c19edfb0f3fbe
BLAKE2b-256 0bafbe98d84f611642545f4e22e11bcc01c1b4fe3f9c8c9e9fd3f973c655194d

See more details on using hashes here.

File details

Details for the file xyz_strata-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: xyz_strata-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 430.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.17 {"installer":{"name":"uv","version":"0.11.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for xyz_strata-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e2cc858b890a404a212eae91f774e17e6eba85526d4922288dc24df2758184f1
MD5 390c442c1962c26a6422f3c74864845f
BLAKE2b-256 b15c1ac393328f7916c480d1b03613aeffdfb9bbab1fa5766b5a0691932f02c6

See more details on using hashes here.

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