Skip to main content

A generic, reusable task management system built with FastAPI and asyncio

Project description

Brinjal

A generic, reusable task management system built with FastAPI and asyncio. Brinjal provides a flexible foundation for building task-based applications with real-time progress updates via Server-Sent Events (SSE).

Features

  • Generic Task Management: Base Task class that can be extended for any type of task
  • Real-time Updates: Server-Sent Events (SSE) for live progress updates
  • Asynchronous Execution: Built on asyncio for high-performance task processing
  • Flexible Integration: No hardcoded prefixes - easily integrated into any FastAPI application
  • Web Components: Reusable frontend components for displaying tasks
  • Progress Tracking: Built-in progress monitoring and status updates

Quick Start

Installation

pip install brinjal

Running the Development Server

# Clone the repository
git clone https://github.com/sg-s/brinjal.git
cd brinjal

# Install dependencies
uv sync

# Run the development server
make dev

The server will start at http://localhost:8000.

End-to-End Testing

  1. Start the server: make dev
  2. Add a task: curl -X POST http://localhost:8000/api/tasks/example_task
  3. View the test page: Open http://localhost:8000/api/tasks/test in your browser
  4. Watch real-time updates: The task will appear and progress in real-time

Usage in Other Projects

Basic Integration

from fastapi import FastAPI
from brinjal.api.router import router as brinjal_router

app = FastAPI()

# Include brinjal with your desired prefix
app.include_router(brinjal_router, prefix="/api/tasks")

Advanced Integration with Custom Endpoints

from fastapi import APIRouter
from brinjal.api.router import router as brinjal_router
from brinjal.manager import task_manager

# Create your main router with the desired prefix
router = APIRouter(prefix="/api/tasks")

# Include all of brinjal's functionality
router.include_router(brinjal_router)

# Add your custom endpoints
@router.post("/custom_task")
async def custom_task():
    # Your custom logic here
    pass

# Include in your main app
app.include_router(router)

Frontend Integration

<!-- Load the TaskList component from your brinjal endpoint -->
<script src="/api/tasks/static/TaskList.js"></script>

<!-- Use the component -->
<task-list base_url="https://yourdomain.com"></task-list>

API Reference

Core Endpoints

  • GET /api/tasks/queue - Get all tasks
  • POST /api/tasks/example_task - Create an example task
  • GET /api/tasks/{task_id}/stream - Stream task updates via SSE
  • GET /api/tasks/static/{file} - Static files (TaskList.js, etc.)

Data Models

  • TaskUpdate: Generic task update model with task_id, task_type, status, progress, img, heading, body

Development

Running Tests

# Run all tests
make test

# Run specific test suites
make test-task-manager
make test-example-task

# Run with coverage
make test-cov

Building Documentation

make docs

Building the Package

make build

Architecture

Brinjal is designed with separation of concerns in mind:

  • Task: Base class for all tasks with common functionality
  • TaskManager: Manages task execution and SSE event generation
  • ExampleTask: Concrete implementation demonstrating task patterns
  • Router: FastAPI router with generic endpoints (no hardcoded prefixes)
  • Static Files: Web components and assets for frontend integration

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Add tests for new functionality
  5. Ensure all tests pass
  6. Submit a pull request

License

MIT License - see LICENSE.txt 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

brinjal-0.7.0.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

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

brinjal-0.7.0-py3-none-any.whl (34.6 kB view details)

Uploaded Python 3

File details

Details for the file brinjal-0.7.0.tar.gz.

File metadata

  • Download URL: brinjal-0.7.0.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for brinjal-0.7.0.tar.gz
Algorithm Hash digest
SHA256 88e6fcf2237dbb36a24acddde61114b416cf4dab42277baf971315f0e8cb243a
MD5 d61bdcdb3edb3ec1c5e06769c438c07d
BLAKE2b-256 8eaccf19ef4cbb6065cd7975c073224dd014c75ecca18086e54b118909df503b

See more details on using hashes here.

Provenance

The following attestation bundles were made for brinjal-0.7.0.tar.gz:

Publisher: pypi.yml on sg-s/brinjal

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

File details

Details for the file brinjal-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: brinjal-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 34.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for brinjal-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a960ab064ce2fe1adf047520447250c7a3a116bfc7d5187adb285e46b2495e6d
MD5 50c5cd878a4c9f983fe249f9908fdf11
BLAKE2b-256 f57336aac0d90a55ee9ad9e17eb54b1f0d2f08fa7ac7c2119e22a6b1a9885b65

See more details on using hashes here.

Provenance

The following attestation bundles were made for brinjal-0.7.0-py3-none-any.whl:

Publisher: pypi.yml on sg-s/brinjal

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