A fast and elegant HTTP client library with decorator-based request handling built on aiohttp
Project description
FastHTTP
A fast and elegant HTTP client library with decorator-based request handling, built on top of aiohttp.
FastHTTP provides a clean, intuitive interface for making HTTP requests in Python, featuring automatic resource management, connection pooling, and a unique decorator-based API that makes your code more readable and maintainable.
✨ Features
- Decorator-based API: Clean and intuitive request handling
- Async/Await Support: Built on aiohttp for high performance
- Automatic Resource Management: No more connection leaks
- Connection Pooling: Efficient connection reuse
- URL Template Support: Dynamic URL building with parameters
- Request/Response Middleware: Easy customization
- Type Hints: Full typing support for better IDE experience
- Debug Mode: Comprehensive logging for development
🚀 Quick Start
Installation
# pip
pip install fastaiohttp
# uv
uv add fastaiohttp
Basic Usage
import asyncio
from fasthttp import FastHTTP
# Create a client instance
http = FastHTTP(base_url="https://jsonplaceholder.typicode.com")
@http.get("/posts/{post_id}")
async def get_post(response, post_id: int):
"""Fetch a single post by ID."""
return await response.json()
@http.post("/posts")
async def create_post(response, title: str, body: str, userId: int):
"""Create a new post."""
return await response.json()
async def main():
# Fetch a post
post = await get_post(post_id=1)
print(f"Post title: {post['title']}")
# Create a new post
new_post = await create_post(
json={
"title": "My New Post",
"body": "This is the content of my post",
"userId": 1
}
)
print(f"Created post with ID: {new_post['id']}")
if __name__ == "__main__":
asyncio.run(main())
📖 Documentation
Client Configuration
from fasthttp import FastHTTP
import aiohttp
http = FastHTTP(
base_url="https://api.example.com",
timeout=30, # Request timeout in seconds
headers={"User-Agent": "MyApp/1.0"},
auth=aiohttp.BasicAuth("username", "password"),
cookies={"session": "abc123"},
debug=True, # Enable debug logging
auto_cleanup=True # Automatic resource cleanup
)
HTTP Methods
FastHTTP supports all standard HTTP methods:
@http.get("/users")
async def list_users(response):
return await response.json()
@http.post("/users")
async def create_user(response, **user_data):
return await response.json()
@http.put("/users/{user_id}")
async def update_user(response, user_id: int, **user_data):
return await response.json()
@http.patch("/users/{user_id}")
async def partial_update_user(response, user_id: int, **changes):
return await response.json()
@http.delete("/users/{user_id}")
async def delete_user(response, user_id: int):
return response.status == 204
@http.head("/users/{user_id}")
async def user_exists(response, user_id: int):
return response.status == 200
@http.options("/users")
async def get_allowed_methods(response):
return response.headers.get("Allow", "").split(", ")
URL Templates
Use URL templates with dynamic parameters:
@http.get("/users/{user_id}/posts/{post_id}")
async def get_user_post(response, user_id: int, post_id: int):
return await response.json()
# Usage
post = await get_user_post(user_id=123, post_id=456)
Request Parameters
Pass various request parameters:
@http.get("/search")
async def search(response, query: str, page: int = 1):
return await response.json()
# Usage with query parameters
results = await search(
query="python",
params={"page": 1, "limit": 10}
)
# Usage with JSON body
@http.post("/users")
async def create_user(response):
return await response.json()
user = await create_user(
json={"name": "John Doe", "email": "john@example.com"}
)
# Usage with form data
@http.post("/upload")
async def upload_file(response):
return await response.json()
result = await upload_file(
data={"file": open("document.pdf", "rb")}
)
Error Handling
import aiohttp
@http.get("/users/{user_id}")
async def get_user(response, user_id: int):
if response.status == 404:
return None
response.raise_for_status() # Raise exception for HTTP errors
return await response.json()
# Or use raise_for_status parameter
@http.get("/users/{user_id}")
async def get_user_safe(response, user_id: int):
return await response.json()
try:
user = await get_user_safe(user_id=999, raise_for_status=True)
except aiohttp.ClientResponseError as e:
print(f"HTTP error: {e.status}")
Context Manager
Use FastHTTP as an async context manager for automatic resource cleanup:
async def main():
async with FastHTTP(base_url="https://api.example.com") as http:
@http.get("/data")
async def get_data(response):
return await response.json()
data = await get_data()
print(data)
# Resources are automatically cleaned up here
Custom Connectors
For advanced use cases, you can provide custom connectors:
import aiohttp
# Custom connector with specific settings
connector = aiohttp.TCPConnector(
limit=100,
limit_per_host=10,
ttl_dns_cache=300,
use_dns_cache=True,
keepalive_timeout=30,
enable_cleanup_closed=True
)
http = FastHTTP(
base_url="https://api.example.com",
connector=connector
)
🔧 Advanced Usage
Debugging
Enable debug mode for detailed logging:
import logging
# Configure logging
logging.basicConfig(level=logging.DEBUG)
# Create client with debug enabled
http = FastHTTP(
base_url="https://api.example.com",
debug=True
)
🤝 Contributing
We welcome contributions! Please see our Contributing Guidelines for details.
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for your changes
- Ensure all tests pass
- Submit a pull request
📋 Requirements
- Python 3.8+
- aiohttp 3.8+
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
🙏 Acknowledgments
- Built on top of the excellent aiohttp library
- Inspired by modern API design patterns
- Thanks to all contributors and users
📞 Support
- 📫 Issues: GitHub Issues
- 💬 Discussions: GitHub Discussions
Made with ❤️ by the FastHTTP team
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 fastaiohttp-0.1.0.tar.gz.
File metadata
- Download URL: fastaiohttp-0.1.0.tar.gz
- Upload date:
- Size: 108.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c2adb9ba5b10b9f0332d810f109e85a623619636741a7ab4177db2c7c090525c
|
|
| MD5 |
6500acade04c4b3e0823b9b5ac426d08
|
|
| BLAKE2b-256 |
9c34e93e7b5b8ca540306203cc1711ab5ff8d274fb9d0e70b140ff66e44b0da3
|
File details
Details for the file fastaiohttp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: fastaiohttp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 8.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4fe3393db09e3744de926e7f94a684cead83d1612c14a232f7dfb433ee46eeda
|
|
| MD5 |
c40ef42bddcb597a9889a801a30ac4c0
|
|
| BLAKE2b-256 |
d6d794cdbf03ccd4c6683cf5efb84b0639f8b844daac7c2a24090fbf59765bb3
|