A minimal ASGI-style API framework
Project description
PathiumAPI — Minimal ASGI API Framework
Version 0.1.11 | GitHub | PyPI
PathiumAPI is a small, synchronous-friendly ASGI-style web framework inspired by FastAPI and other micro-frameworks. It focuses on a compact, explicit API for routing, request/response helpers, middleware, and simple route parameter converters. It's ideal for small services, learning, or as a foundation to build more opinionated tooling.
Key Features
- Minimal Core: Dependency-free routing and ASGI handling
- Request/Response Helpers: Simple
RequestandResponseobjects with JSON support - Path Converters: Type-aware parameter conversion (e.g.
{id:int}) - Pydantic Integration: Request body and query parameter validation with
@validate_bodyand@validate_query - OpenAPI Support: Auto-generated OpenAPI 3.0 specs and interactive Swagger UI docs
- Authentication: JWT middleware and helpers for protected routes
- Built-in Middleware: CORS, security headers, rate limiting, logging, and error handling
- CLI Tools: Scaffold and run apps with
pathiumapi newandpathiumapi run
Installation
Install from PyPI:
pip install PathiumAPI
Quickstart
Create app.py:
from pathiumapi import Pathium, Response
from pydantic import BaseModel
app = Pathium()
class User(BaseModel):
name: str
email: str
@app.get("/")
async def index(req):
return Response("Hello, PathiumAPI!")
@app.get("/users/{id:int}")
async def get_user(req, id: int):
return Response.json({"id": id, "name": f"User {id}"})
@app.post("/users")
@app.validate_body(User)
async def create_user(req):
user_data = req.validated_body
return Response.json({"created": user_data.dict()}, status=201)
Run with uvicorn:
pip install uvicorn
uvicorn app:app --reload
Visit http://localhost:8000/docs for interactive API documentation!
Examples and Documentation
Available Examples
examples/app.py— Minimal app with basic routingexamples/auth_app.py— JWT authentication with login and protected routesexamples/middleware_demo.py— CORS, security headers, and rate limitingexamples/query_app.py— Query parameter validation with Pydantic models
Features Overview
OpenAPI & Documentation
from pathiumapi.openapi_pydantic import add_openapi, add_docs
add_openapi(app, title="My API", version="1.0.0")
add_docs(app) # Serves Swagger UI at /docs
Request Validation
from pydantic import BaseModel
class QueryParams(BaseModel):
page: int = 1
limit: int = 10
@app.get("/items")
@app.validate_query(QueryParams)
async def list_items(req):
params = req.validated_query
return Response.json({"page": params.page, "limit": params.limit})
JWT Authentication
from pathiumapi.auth import jwt_middleware_factory, create_token
# Protect routes requiring authentication
app.use(jwt_middleware_factory(secret="your-secret-key"))
Middleware
from pathiumapi.middleware import cors_middleware, security_headers_middleware
app.use(cors_middleware(allow_origins=["*"]))
app.use(security_headers_middleware())
For comprehensive usage details, see usage.md.
Development
- Run tests:
python -m pytest -q - Static checks (optional):
flake8andmypy
Contributing
See CONTRIBUTING.md for branch naming, PR workflow, and guidelines. Open a
PR against main when ready and include tests for new functionality.
What's New
v0.1.11 (Latest)
- Auto-generation of OpenAPI query parameter schemas from Pydantic models
@validate_querydecorator with OpenAPI integration- Enhanced query parameter validation and documentation
Recent Releases
- v0.1.10 — Common middleware (CORS, security headers, rate limiting)
- v0.1.9 — JWT authentication middleware and helpers
- v0.1.8 — Pydantic integration for request body validation
- v0.1.7 — OpenAPI generation and Swagger UI documentation
See CHANGELOG.md for complete release history and release-notes/ for detailed notes.
License
MIT
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 pathiumapi-0.1.13.tar.gz.
File metadata
- Download URL: pathiumapi-0.1.13.tar.gz
- Upload date:
- Size: 18.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7bf08a7ea0e79ea2b2546fa309cc1ec0669a92a0183db65b6c9b88e706f52f96
|
|
| MD5 |
36fe9097ef2df80f16afa079d7f91bad
|
|
| BLAKE2b-256 |
f787b6db4f3496561d69c540f5603d0a5e4c46551d4df1f2ace8d14f99c5f9b1
|
File details
Details for the file pathiumapi-0.1.13-py3-none-any.whl.
File metadata
- Download URL: pathiumapi-0.1.13-py3-none-any.whl
- Upload date:
- Size: 23.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.25
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
49b42d7cc65902f1b6f72356e60aa45d58d2371118ec03fab72c210306680113
|
|
| MD5 |
a7918d753eda42ad84481211ec7fda42
|
|
| BLAKE2b-256 |
e332f7104108c43c4fc330b9aba4cc7161df973704323b8239e5349a24cdda4c
|