Skip to main content

This is the orchestrator workflow engine.

Project description

Orchestrator-Core

Downloads codecov pypi_version Supported python versions Discord

Production ready Orchestration Framework to manage product lifecycle and workflows. Easy to use, built on top of FastAPI and Pydantic

Documentation

The documentation can be found at workfloworchestrator.org.

Installation (quick start)

Simplified steps to install and use the orchestrator-core. For more details, read the Getting started documentation.

Step 1 - Install the package

Create a virtualenv and install the orchestrator-core.

python -m venv .venv
source .venv/bin/activate
pip install orchestrator-core

Step 2 - Setup the database

Create a postgres database:

createuser -sP nwa
createdb orchestrator-core -O nwa  # set password to 'nwa'

Configure the database URI in your local environment:

export DATABASE_URI=postgresql://nwa:nwa@localhost:5432/orchestrator-core

Step 3 - Create main.py and wsgi.py

Create a main.py file for running the CLI.

from orchestrator.cli.main import app as core_cli

if __name__ == "__main__":
    core_cli()

Create a wsgi.py file for running the web server.

from orchestrator import OrchestratorCore
from orchestrator.settings import AppSettings

app = OrchestratorCore(base_settings=AppSettings())

Step 4 - Run the database migrations

Initialize the migration environment and database tables.

python main.py db init
python main.py db upgrade heads

Step 5 - Run the app

export OAUTH2_ACTIVE=False
uvicorn --reload --host 127.0.0.1 --port 8080 wsgi:app

Visit the ReDoc or OpenAPI page to view and interact with the API.

Contributing

We use uv to manage dependencies and docker compose to provide services required for unit tests (redis, postgresql)

To get started, follow these steps:

# on your local machine
git clone https://github.com/workfloworchestrator/orchestrator-core
cd orchestrator-core
just pytest  # Run unit tests
just pytest -vx  # Stop at first failed test
just pytest --last-failed  # re-run only failed tests
just pytest --failed-first  # run tests starting with tests that failed

For more details please read the development docs.

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

orchestrator_core-5.0.0rc1.tar.gz (345.7 kB view details)

Uploaded Source

Built Distribution

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

orchestrator_core-5.0.0rc1-py3-none-any.whl (569.3 kB view details)

Uploaded Python 3

File details

Details for the file orchestrator_core-5.0.0rc1.tar.gz.

File metadata

  • Download URL: orchestrator_core-5.0.0rc1.tar.gz
  • Upload date:
  • Size: 345.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","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 orchestrator_core-5.0.0rc1.tar.gz
Algorithm Hash digest
SHA256 1cc2fefaf27cd13eed5bbcecdec022c6b9afc2af2016e03bccb2789713df27cd
MD5 57c1e4d021f0af93868ba88490c0fb30
BLAKE2b-256 b565a9bf6b501b0c2fbd785a11a73f9a75c1af2c2d649ecb9c6c7e3e2f053c7a

See more details on using hashes here.

File details

Details for the file orchestrator_core-5.0.0rc1-py3-none-any.whl.

File metadata

  • Download URL: orchestrator_core-5.0.0rc1-py3-none-any.whl
  • Upload date:
  • Size: 569.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.6 {"installer":{"name":"uv","version":"0.11.6","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 orchestrator_core-5.0.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 11c769d698722f5a2f3127b4c5d7b95356d0efb05aa07cc2171f4d5b9376c68c
MD5 5b4d1f84afd13e735597a42fd5ab2404
BLAKE2b-256 2529a88bb19633dcc9ffb74000b2e4c91d7aa2addd872d63b83b3582e5eeac05

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