Skip to main content

A Python library for building task-based workflows with scheduling, webhooks, artifact management, and observability

Project description

Task Framework

A Python library for building and executing task-based workflows with built-in support for scheduling, webhooks, artifact management, and observability.

Features

  • Multi-Task Server: Deploy multiple task definitions to a single server, each with isolated execution environments
  • Thread Execution: Run tasks synchronously or asynchronously with full state management
  • Artifact Management: Track inputs and outputs with support for JSON, text, and file artifacts
  • File Storage: Pluggable file storage interface with local filesystem and pre-signed URL support
  • Scheduling: Cron-based scheduling with APScheduler integration
  • Webhooks: Event-driven notifications with automatic retry and delivery tracking
  • Observability: Built-in Prometheus metrics and structured logging
  • OpenAPI 3.1.0: Auto-generated API documentation at /docs

Installation

pip install task-framework

Or with uv:

uv add task-framework

Quick Start

Multi-Task Server

The Task Framework runs as a server that can host multiple task definitions. Each task is packaged as a zip file with its code and metadata.

Start a task server:

# Start server with auto-discovery from task_definitions/ directory
task-framework serve --host 0.0.0.0 --port 3000

# Or for development, load a task from source
task-framework serve --dev-task /path/to/my-task/

Deploy a task via API:

curl -X POST http://localhost:3000/admin/tasks \
  -H "X-API-Key: your-admin-key" \
  -F "file=@my-task-1.0.0.zip"

Task Zip Structure:

my-task-1.0.0.zip/
  task_metadata.json    # Task metadata and schemas
  task.py              # Task implementation
  pyproject.toml       # Dependencies (optional)

Example Task Function:

async def my_task(context):
    # Get input artifacts
    inputs = await context.get_input_artifacts()
    
    # Process inputs
    result = {"message": "Task completed", "input_count": len(inputs)}
    
    # Publish output
    from task_framework.models.artifact import Artifact
    await context.publish_output_artifacts([
        Artifact(kind="json", value=result, media_type="application/json")
    ])

## API Usage

### Create a Thread (Execute Task)

```bash
curl -X POST http://localhost:3000/threads \
  -H "X-API-Key: your-api-key" \
  -H "X-User-Id: user123" \
  -H "X-App-Id: app456" \
  -H "Content-Type: application/json" \
  -d '{
    "mode": "sync",
    "inputs": [{"kind": "json", "value": {"data": "test"}}]
  }'

In multi-task mode, add ?task_id=my-task&version=1.0.0 query parameters.

List Threads

curl http://localhost:3000/threads \
  -H "X-API-Key: your-api-key" \
  -H "X-User-Id: user123" \
  -H "X-App-Id: app456"

Health Check

curl http://localhost:3000/health

Task Package Format

A task package is a zip file containing:

my-task-1.0.0.zip/
  task_metadata.json    # Task metadata
  task.py              # Task implementation
  pyproject.toml       # Dependencies

Example task_metadata.json:

{
  "name": "my-task",
  "version": "1.0.0",
  "description": "My task description",
  "entry_point": "task:my_task_function",
  "input_schemas": [
    {"kind": "json", "media_type": "application/json", "required": true}
  ],
  "output_schemas": [
    {"kind": "json", "media_type": "application/json"}
  ]
}

Documentation

  • API Documentation: Start the server and visit /docs for interactive Swagger UI
  • User Guide: See docs/user/ for getting started guides
  • Architecture: See docs/architecture/ for system design documentation
  • Feature Documentation: See docs/features/ for detailed feature documentation

Authentication

The framework uses API key authentication via the X-API-Key header:

  • Regular API Keys: Require user_id and app_id metadata for access control
  • Admin API Keys: Full access to all endpoints including /admin/* routes

Public endpoints (no authentication required):

  • GET /health - Health check
  • GET /metrics - Prometheus metrics
  • GET /task/metadata - Task metadata discovery

Requirements

  • Python 3.13+
  • FastAPI
  • Pydantic 2.x
  • uvicorn

License

MIT License - see LICENSE file for details.

Contributing

Contributions are welcome! Please see the development documentation in docs/developer/ for setup instructions.

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

task_framework_py-0.0.2b0.tar.gz (310.2 kB view details)

Uploaded Source

Built Distribution

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

task_framework_py-0.0.2b0-py3-none-any.whl (409.9 kB view details)

Uploaded Python 3

File details

Details for the file task_framework_py-0.0.2b0.tar.gz.

File metadata

  • Download URL: task_framework_py-0.0.2b0.tar.gz
  • Upload date:
  • Size: 310.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.3

File hashes

Hashes for task_framework_py-0.0.2b0.tar.gz
Algorithm Hash digest
SHA256 136f31a4b9ba094c7f7ba737545afcff168284e6f90012f92c86dc1ef6b1ef2b
MD5 23f6f0eab3d20d423ced42485061e7c5
BLAKE2b-256 50d915dd7c351a8bfdddbf80cf2b5a31e2adebd1601d0c941b90c1809ea53258

See more details on using hashes here.

File details

Details for the file task_framework_py-0.0.2b0-py3-none-any.whl.

File metadata

File hashes

Hashes for task_framework_py-0.0.2b0-py3-none-any.whl
Algorithm Hash digest
SHA256 d4303b9013af80c01cdbb9297634a3b8f8332122ed1877ba87d8424845d7876b
MD5 fadfc5f5e78006ed12d134c7e492a55c
BLAKE2b-256 d34b2ad5d06dc3158faa3ba8e9056365cb800d7fcce00bb155569e48416dd080

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