Skip to main content

A framework to build and run data pipelines and workflows.

Project description

NoETL

NoETL is an automation framework for orchestrating APIs, databases, and scripts using a declarative Playbook DSL.

Execution is standardized around an MCP-style tool model: consistent tool contracts, structured input/output, and a predictable lifecycle. From an MCP perspective, tools include API endpoints, database operations, and scripts/utilities NoETL orchestrates and optimizes them via playbooks.

With NoETL Gateway, playbooks can be deployed as a distributed backend: developers ship business logic as playbooks, and UIs/clients call stable endpoints without deploying dedicated microservices for each workflow.

PyPI version

Documentation

https://noetl.dev — user-facing site.

NoETL wiki — operator and developer reference. Pages mirror the code tree under noetl/noetl.

Async batch acceptance and recovery references (on the wiki):

Distributed runtime components

Reference docs for the event-sourced, projection-backed runtime (implements v2 distributed-runtime spec phases 0–2; spec lives in noetl/docs at docs/features/noetl_distributed_runtime_spec.md):

  • Event Store — durable append-only event log (port + Postgres adapter), EventRecord envelope, optimistic concurrency via expected_version.
  • Projection Store — version-monotonic projection + snapshot store (port + Postgres adapter), query interface for replay state.
  • Outbox — transactional outbox publisher (python -m noetl.outbox) that drains noetl.outbox to NATS with at-least-once retry/backoff.
  • Projector — out-of-process projection worker (python -m noetl.projector), durable NATS pull consumer, shard-stable, Prometheus metrics, replay-state folding shared with the in-process replay API.

Repository model (ai-meta driven)

NoETL development is now coordinated through the ai-meta repository:

ai-meta tracks all component repositories as Git submodules and is the primary place to coordinate cross-repo changes, pointer bumps, and release choreography.

End-to-end integration playbooks, fixture payloads, local credential templates, notebooks, and Gateway UI test fixtures live in noetl/e2e.

Distribution channels

License

Dual License — see LICENSE for details.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

noetl-2.99.0.tar.gz (802.7 kB view details)

Uploaded Source

Built Distribution

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

noetl-2.99.0-py3-none-any.whl (897.4 kB view details)

Uploaded Python 3

File details

Details for the file noetl-2.99.0.tar.gz.

File metadata

  • Download URL: noetl-2.99.0.tar.gz
  • Upload date:
  • Size: 802.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","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 noetl-2.99.0.tar.gz
Algorithm Hash digest
SHA256 9f7eb086238ae7d8944fe7ec0dba656a1d939e020abbdcf518f6b6e73c3914ae
MD5 994230b596c7e49dc4a1ac0af4e69f0d
BLAKE2b-256 3c73fc8d5e77a3d5d0ad358e9c064833d1342186e3d1a86d4f31be01d3d1b02f

See more details on using hashes here.

File details

Details for the file noetl-2.99.0-py3-none-any.whl.

File metadata

  • Download URL: noetl-2.99.0-py3-none-any.whl
  • Upload date:
  • Size: 897.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","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 noetl-2.99.0-py3-none-any.whl
Algorithm Hash digest
SHA256 355f37ed64272716a0fdb55c93e71ce46eee099e31e4520c73744bbb2cc484f9
MD5 d01618af264b7c4bc81a611c5b31f281
BLAKE2b-256 eec03841d9e51665ec87d9512b9c08e8c8e0195fb49857c04ef32d58c55a0501

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