Skip to main content

ccflow is a collection of tools for workflow configuration, orchestration, and dependency injection

Project description

ccflow logo, 'ccflow' with letters in color

Build Status codecov GitHub issues License PyPI Version

ccflow (Composable Configuration Flow) is a collection of tools for workflow configuration, orchestration, and dependency injection. It is intended to be flexible enough to handle diverse use cases, including data retrieval, validation, transformation, and loading (i.e. ETL workflows), model training, microservice configuration, and automated report generation.

The framework provides:

  • a way to manage hierarchical, strongly typed configurations and the relationships between them through composition
  • a way to associate user-defined functions with configurations, and in doing so, to define and name configurable workflow graphs
  • a way to manage dependency injection and inversion of control for objects in these graphs
  • flexibility in how to interact with configurations and workflows, including files/command line, native python/Jupyter notebook, Airflow/job scheduler, REST API, etc (in progress)

It heavily leverages pydantic, and users are expected to implement their own configuration and workflow building blocks by implementing pydantic models.

It also integrates closely with hydra for file-based configuration and command line interaction, but can also be used natively from Python without it.

This library was partially inspired by this blog post by Suneeta Mall (@suneeta-mall). We have taken these ideas a step further by introducing the concept of the ModelRegistry, which allows for the configs to be managed without hydra, and also allows us to implement dependency injection.

We aim to provide additional (and optional) tools for workflow orchestration on top of the configuration framework.

More information is available in our wiki

Installation

ccflow can be installed via pip or conda, the two primary package managers for the Python ecosystem.

To install ccflow via pip, run this command in your terminal:

pip install ccflow

To install ccflow via conda, run this command in your terminal:

conda install ccflow -c conda-forge

Community

  • Contribute to ccflow and help improve the project

License

This software is licensed under the Apache 2.0 license. See the LICENSE file for details.

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

ccflow-0.8.3.tar.gz (222.7 kB view details)

Uploaded Source

Built Distribution

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

ccflow-0.8.3-py3-none-any.whl (277.1 kB view details)

Uploaded Python 3

File details

Details for the file ccflow-0.8.3.tar.gz.

File metadata

  • Download URL: ccflow-0.8.3.tar.gz
  • Upload date:
  • Size: 222.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for ccflow-0.8.3.tar.gz
Algorithm Hash digest
SHA256 136832648c43a51e6334c7083b3a17bfd6f5e7bf68e7d91c25fb6e1c035f7ea0
MD5 624191b3cd05f7ab529343c0c355a5b3
BLAKE2b-256 7c696583842732404fc19d0e15a8e5951b6af3116b88d826c8576e661abfecd9

See more details on using hashes here.

File details

Details for the file ccflow-0.8.3-py3-none-any.whl.

File metadata

  • Download URL: ccflow-0.8.3-py3-none-any.whl
  • Upload date:
  • Size: 277.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for ccflow-0.8.3-py3-none-any.whl
Algorithm Hash digest
SHA256 563a9b843e352ae688c061e32617b6db4483cc0ce07efb5aaa70eeb6e9e20df8
MD5 77d7ff9eee4876caffdc56cc8d1db326
BLAKE2b-256 5aa9bb8b8b26a7afd65acbd63dcc069e5357a31ce060a42fd3d8ebfcc322683a

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