Fluent async workflows with lazy execution for Python
Project description
🚀 FlowKit - Simplify Async Workflows
FlowKit provides fluent async workflows with lazy execution and minimal boilerplate.
⚡ Why FlowKit?
Before (Traditional Async):
async def fetch_user_data(user_id):
async with aiohttp.ClientSession() as session:
async with session.get(f"https://api.example.com/users/{user_id}") as response:
user = await response.json()
async with session.get("https://api.example.com/posts", params={"userId": user_id}) as posts_response:
posts = await posts_response.json()
return {"user": user, "posts": posts}
After (FlowKit):
@flowkit.simple
def fetch_user_data(user_id):
user = flowkit.get(f"https://api.example.com/users/{user_id}").json()
posts = flowkit.get("https://api.example.com/posts", params={"userId": user_id}).json()
return {"user": user, "posts": posts}
🎯 Key Features
- 🔗 Fluent API - Chain operations with
.pipe()method - 🛡️ Type Safe - Full IDE support and type hints
- 🚀 Modern Foundation - Built on battle-tested httpx
- 🔧 Framework Ready - FastAPI, Django, Flask examples
- 📦 Simple Installation -
pip install flowkit-async
📦 Installation
pip install flowkit-async
🔧 How FlowKit Works
FlowKit provides lazy async pipelines - operations are queued and executed when awaited.
import flowkit
# FlowKit operations return awaitable Flow objects
user_flow = flowkit.get("https://api.example.com/users/1")
posts_flow = flowkit.get("https://api.example.com/posts")
# Execute both operations
user = await user_flow.json()
posts = await posts_flow.json()
Core Concept: Flow Objects
Flow objects are awaitable pipelines that:
- Chain operations without immediate execution
- Execute when awaited in the current event loop
- Enable fluent, readable async patterns
This is structured async workflows, not sync-to-async magic.
🔧 How FlowKit Works
FlowKit provides lazy async pipelines. API calls return awaitable Flow objects that record operations and execute asynchronously when awaited.
FlowKit does NOT:
- convert blocking code into async
- use threads or greenlets
- bypass the event loop
This is structured async composition, not async magic.
🏆 Real-World Examples
Data Processing Pipeline
@flowkit.simple
def fetch_user_data(user_id: int):
"""Fetch and process user data."""
return (flowkit.get(f"https://jsonplaceholder.typicode.com/users/{user_id}")
.json()
.pipe(lambda user: {**user, "processed": True}))
Note: @flowkit.simple is intended for synchronous functions.
If used on async functions, it acts as a pass-through wrapper.
Concurrent Operations
@flowkit.simple
def fetch_dashboard():
"""Fetch multiple data sources concurrently."""
users = flowkit.get("https://jsonplaceholder.typicode.com/users").json()
posts = flowkit.get("https://jsonplaceholder.typicode.com/posts").json()
comments = flowkit.get("https://jsonplaceholder.typicode.com/comments").json()
# These execute concurrently when awaited
return {"users": users, "posts": posts, "comments": comments}
🛠 When to Use FlowKit
FlowKit is ideal for:
- API-heavy applications with multiple calls
- Data pipelines and processing workflows
- Teams wanting consistent async patterns
- Rapid prototyping with clean syntax
⚠️ Important Notes
FlowKit does NOT:
- Block the event loop or use thread pools
- Make synchronous code magically non-blocking
- Replace understanding of asyncio fundamentals
- Work with CPU-bound operations
Always use async/await with CPU-intensive tasks.
🆚 How FlowKit Compares
| Feature | FlowKit | aiohttp | httpx | requests |
|---|---|---|---|---|
| Fluent API | ✅ | ❌ | ❌ | ❌ |
| Type Safe | ✅ | ✅ | ✅ | ✅ |
| Sessions | ✅ | ✅ | ✅ | ❌ |
| Pipelines | ✅ | ❌ | ❌ | ❌ |
FlowKit provides structured async workflows with minimal overhead on top of httpx and is comparable in performance for typical I/O-bound workloads.
📋 License
MIT License - see LICENSE file for details.
🤝 Contributing
We welcome contributions! Please see our Contributing Guide for details.
🚀 Try FlowKit today for cleaner async workflows:
pip install flowkit-async
⭐ Star us on GitHub! github.com/flowkit/flowkit
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file flowkit_async-1.0.0.tar.gz.
File metadata
- Download URL: flowkit_async-1.0.0.tar.gz
- Upload date:
- Size: 11.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4865e168616d86c1fdf5cb4aac14221ee473b73088d54dd7195d0682421c13ae
|
|
| MD5 |
0224c72d5631b4b670226a6e88d1488c
|
|
| BLAKE2b-256 |
680b2f3f9e4937d0ef8ef0861d3a2bfc9ee2528c1f6b708c0a22d1881fd8b0b5
|
File details
Details for the file flowkit_async-1.0.0-py3-none-any.whl.
File metadata
- Download URL: flowkit_async-1.0.0-py3-none-any.whl
- Upload date:
- Size: 8.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aab1d522737ec26c6ac160e1c7871e28e77e5affaf78c7d022e91424b5597c28
|
|
| MD5 |
25a17179211bab8df30340ac32ed331e
|
|
| BLAKE2b-256 |
7298890db335dd8ec4429c942d5cf008111835b3af2752c7819620d16c12d583
|