Skip to main content

Governed infrastructure-operations profile and RExecOp domain package over GovEngine and SCLite.

Project description

Tecrax

Tecrax is a governed infrastructure-operations profile for RExecOp, using GovEngine governance and SCLite artifact truth.

Current source line: tecrax==0.3.5a0, depending on govengine>=0.16.0,<0.17, sclite-core>=1.0.4,<1.1, and rexecop>=0.2.6a0,<0.3. Latest published PyPI baseline: tecrax==0.3.5a0; it contains the coordinated B2 dependency floor and policy vector.

This package provides:

  • RExecOp domain profile — bundled YAML profile with intents, workflows, connectors, and validation rules (entry point rexecop.profiles:tecrax).
  • Local fixture review — dry-run proof slice without live infrastructure.
  • Read-only host inventory profile — fixed SSH command shapes and bounded normalization for operator-configured Ubuntu inventory, with a sanitized GovEngine B2 policy-control example for receipt, digest, timeout, step and output bounds.
  • Verified read-only service slices — NTP synchronization and Docker systemd service health over fixed SSH commands, plus bounded Zabbix API version health through RExecOp http_api, AdGuard DNS/login reachability, and unauthenticated Portainer status through verified TLS.
  • Read-only network device inventory slice — bounded legacy CLI inventory through an operator-managed local wrapper; target addresses, keys and wrapper implementation stay outside the repository.
  • Monitoring-host reaction pack — deterministic domain findings map only to existing read-only intents; unknown states escalate without a free-form action.
  • Operator catalog metadata — target kinds, required capabilities, side-effect classes, validation references and runbook references projected by RExecOp from the profile; sanitized target-catalog example included.

It does not execute infrastructure changes or manage credentials. Live SSH execution is performed by RExecOp only from explicit operator configuration outside this package.

Stack ownership:

Tecrax profile -> RExecOp plan -> GovEngine admission -> RExecOp execution -> SCLite evidence
  • SCLite owns canonical evidence, receipts and review artifacts.
  • GovEngine owns governance, PolicyEngine and admission decisions.
  • RExecOp owns domain-neutral lifecycle, execution and deterministic reaction mechanics.
  • Tecrax owns infrastructure intent, connector, normalization, validation and runbook semantics.

RExecOp profile

Install the coordinated published line to register the current domain profile:

pip install "tecrax==0.3.5a0"
tecrax status

For an explicit cross-stack pin, pip install "rexecop[tecrax]==0.2.6a0" resolves the same coordinated release line.

The profile root is exposed via tecrax:profile_root (directory src/tecrax/profile/). For network devices, see docs/network-device-readonly-runbook.md; real target configuration and legacy SSH compatibility wrappers stay outside this repository.

Target and operation catalog

Tecrax intent files contain profile-owned operator catalog metadata. RExecOp derives the operation list from those same intent and workflow files; there is no second manually maintained operation registry.

Use the sanitized template in examples/catalogs/targets.readonly.example.yaml as the shape for an operator-owned catalog outside Git:

rexecop targets list --catalog /path/outside/repo/targets.yaml
rexecop operations list --catalog /path/outside/repo/targets.yaml \
  --target monitoring-host-01

An admission_required result means only that target kind, capabilities and connectors match. GovEngine still decides whether a concrete plan may execute. See docs/operation-catalog.md.

Deterministic reactions

Tecrax owns the monitoring vocabulary and rules in src/tecrax/profile/reactions/reaction_pack.yaml. Build a canonical observation from a bounded diagnose_monitoring_host result, then pass it to RExecOp:

tecrax reaction-observation \
  --input diagnosis.json \
  --operation op-source \
  --target monitoring-host-01 > observation.json

rexecop reaction-plan \
  --profile tecrax \
  --env /path/outside/repo/environment.yaml \
  --observation observation.json \
  --target monitoring-host-01

The first release is deliberately read-only. It can re-run bounded host inventory, NTP, Docker service, Zabbix, AdGuard, Portainer, or network device inventory checks; a healthy observation is no_op, and an unclassified state is escalate. RExecOp owns deterministic mechanics and lifecycle, GovEngine owns admission, and SCLite owns the evidence chain.

Local fixture proof

tecrax fixture-review --service demo-web

The command emits a public-safe fixture review payload. It uses GovEngine profile/planning/supervision/runtime-review contracts and binds its fixture receipt through an SCLite artifact descriptor. It has no live runner, host inventory, credential path, or infrastructure adapter.

The published 0.3.5-alpha line combines the profile-owned read-only reaction pack and B2 policy vector over RExecOp 0.2.6a0, GovEngine 0.16.0, and SCLite 1.0.4. It does not add a second policy engine, lifecycle runner, or truth layer.

The Ubuntu environment example uses profile-owned policy semantics, but GovEngine compiles and admits the controls and RExecOp enforces them. Tecrax does not claim that writing obligations in YAML alone satisfies them.

Validation

python scripts/validate_public_truth.py
python -m pytest -q

The validator keeps domain semantics in Tecrax and lifecycle/execution in RExecOp. Any future mutation, credential, scheduler, discovery, or carrier-adapter claim must be backed by code and tests before it becomes public truth.

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

tecrax-0.3.5a0.tar.gz (35.0 kB view details)

Uploaded Source

Built Distribution

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

tecrax-0.3.5a0-py3-none-any.whl (35.4 kB view details)

Uploaded Python 3

File details

Details for the file tecrax-0.3.5a0.tar.gz.

File metadata

  • Download URL: tecrax-0.3.5a0.tar.gz
  • Upload date:
  • Size: 35.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for tecrax-0.3.5a0.tar.gz
Algorithm Hash digest
SHA256 c878b165d6f3b8af12043164be2bb31c34800e7742d3e735784e4828ae79d2fd
MD5 1bcf4de1a5b8ec0203f18aee185a1fbf
BLAKE2b-256 eeae74bb389b89c1fd1f93ea08ce6a4161afa7ca1f2180a7b844d3dee69c1bf0

See more details on using hashes here.

File details

Details for the file tecrax-0.3.5a0-py3-none-any.whl.

File metadata

  • Download URL: tecrax-0.3.5a0-py3-none-any.whl
  • Upload date:
  • Size: 35.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.4

File hashes

Hashes for tecrax-0.3.5a0-py3-none-any.whl
Algorithm Hash digest
SHA256 0d6fce619903980b7ff0f2bf0240c3e795c34dfe718b39c5884dd2649a8320b0
MD5 03c329a0828931bfb242929c3d05a47c
BLAKE2b-256 024b617b2d26a068575e59db61eab55f8336edd3bf9521246f30112d040cd234

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