Skip to main content

Framework for Task orchestration

Project description

FlowTask

FlowTask is a plugin-based, component-driven task execution framework for create complex Tasks.

FlowTask runs Tasks defined in JSON, YAML or TOML files, any Task is a combination of Components, and every component in the Task run sequentially or depend of others, like a DAG.

Can create a Task combining Commands, Shell scripts and other specific Components (as TableInput: Open a Table using a datasource, DownloadFromIMAP: Download a File from a IMAP Folder, and so on), any Python Callable can be a Component inside a Task, or can extends UserComponent to build your own componets.

Every designed Task can run from CLI, programmatically, via RESTful API (using our aioHTTP-based Handler), called by WebHooks or even dispatched to a external Worker using our built-in Scheduler.

Quickstart

pip install flowtask

Tasks can organizated into directory structure like this:

tasks / ├── programs / ├── test / ├── tasks /

The main reason of this structure, is maintain organized several tasks by tenant/program, avoiding filling a directory with several task files.

FlowTask support "TaskStorage", a Task Storage is the main repository for tasks, main Task Storage is a directory in any filesystem path (optionally you can syncronize that path using git), but Tasks can be saved onto a Database or a S3 bucket.

Dependencies

  • aiohttp (Asyncio Web Framework and Server) (required by navigator)
  • AsyncDB
  • QuerySource
  • Navigator-api
  • (Optional) Qworker (for distributing asyncio Tasks on distributed workers).

Features

  • Component-based Task execution framework with several components covering several actions (download files, create pandas dataframes from files, mapping dataframe columns to a json-dictionary, etc)
  • Built-in API for execution of Tasks.

How I run a Task?

Can run a Task from CLI:

task --program=test --task=example

on CLI, you can pass an ENV (enviroment) to change the environment file on task execution.

ENV=dev task --program=test --task=example

or Programmatically:

from flowtask import Task
import asyncio

task = Task(program='test', task='example')
results = asyncio.run(task.run())
# we can alternatively, using the execution mode of task object:
results = asyncio.run(task())

Requirements

Contribution guidelines

Please have a look at the Contribution Guide

  • Writing tests
  • Code review
  • Other guidelines

Who do I talk to?

  • Repo owner or admin
  • Other community or team contact

License

Navigator is licensed under Apache 2.0 License. See the LICENSE file for more 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

flowtask-5.12.6.tar.gz (1.3 MB view details)

Uploaded Source

Built Distributions

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

flowtask-5.12.6-cp313-cp313-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (3.4 MB view details)

Uploaded CPython 3.13manylinux: glibc 2.17+ x86-64

flowtask-5.12.6-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (3.5 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.17+ x86-64

flowtask-5.12.6-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (3.4 MB view details)

Uploaded CPython 3.11manylinux: glibc 2.17+ x86-64

File details

Details for the file flowtask-5.12.6.tar.gz.

File metadata

  • Download URL: flowtask-5.12.6.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for flowtask-5.12.6.tar.gz
Algorithm Hash digest
SHA256 47ffb624f1cb297c85d039b14f9b707a7cb152cf230293f941aa11ed88a143d0
MD5 b5cc1c6442ea3d5711a1a67b7f8ce04f
BLAKE2b-256 a19bbe589be8550dbea4141641fefe45cad96e6746be7c8e0fc7d99a061935ec

See more details on using hashes here.

Provenance

The following attestation bundles were made for flowtask-5.12.6.tar.gz:

Publisher: release.yml on phenobarbital/flowtask

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flowtask-5.12.6-cp313-cp313-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for flowtask-5.12.6-cp313-cp313-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 865e0c7c1714801c7aa18ffc521f3bb2e44a412951c9514e45682e978cc96f13
MD5 5450427e45b83fa288d08bd8a77136ba
BLAKE2b-256 dab19fb200e921e225b31e89d50f1884e20ecb44a2ea24a7d659d78d2e607e81

See more details on using hashes here.

Provenance

The following attestation bundles were made for flowtask-5.12.6-cp313-cp313-manylinux2014_x86_64.manylinux_2_17_x86_64.whl:

Publisher: release.yml on phenobarbital/flowtask

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flowtask-5.12.6-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for flowtask-5.12.6-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 e8da67a57b27acf5a86fc6f191e679b0fcda76cc19e14f737d9ce93ad2e30b32
MD5 7298c8a0cfca97887a3ed713208707b9
BLAKE2b-256 a579af58a705d1a76377e049702dd2dfd532bdc654bee55c191a6f1972795689

See more details on using hashes here.

Provenance

The following attestation bundles were made for flowtask-5.12.6-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.whl:

Publisher: release.yml on phenobarbital/flowtask

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file flowtask-5.12.6-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for flowtask-5.12.6-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 178d23f067d0da6fc06b6c8f3008f3ca552859e2bf71ccded9999423c4cce9b8
MD5 ebfb08c599cd32656407bf314359ebc5
BLAKE2b-256 e787372df3a3a3b4aa3c6dead2bd5b2b4cfa6edcc9f65ff6d3d1ce7fc227f1ab

See more details on using hashes here.

Provenance

The following attestation bundles were made for flowtask-5.12.6-cp311-cp311-manylinux2014_x86_64.manylinux_2_17_x86_64.whl:

Publisher: release.yml on phenobarbital/flowtask

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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