ZodiacCore-Py: A high-performance core library for modern Python web services.
Project description
ZodiacCore-Py
The opinionated, async-first core library for modern Python web services.
🎯 Mission
Stop copy-pasting your infrastructure code.
Every new FastAPI project starts the same way: setting up logging, error handling, database sessions, pagination... It's tedious, error-prone, and inconsistent across teams.
ZodiacCore solves this in two ways: a library you drop into any FastAPI app, and a CLI that scaffolds a full project so you can start coding in seconds.
✨ Key Features
- 🔍 Observability First: Built-in JSON structured logging with Trace ID injection across the entire request lifecycle (Middleware → Context → Log).
- 🛡️ Robust Error Handling: Centralized exception handlers that map
ZodiacExceptionto standard HTTP 4xx/5xx JSON responses. - 💾 Database Abstraction: Async SQLAlchemy session management and
BaseSQLRepositorywith pagination helpers (paginate_query). - 🎁 Standard Response Wrapper: Automatic wrapping of API responses into
code/data/messageviaAPIRouter. - 📄 Standard Pagination:
PageParamsandPagedResponse[T]with repository integration. - ⚡ Async Ready: Python 3.12+ async/await from the ground up.
- ⌨️ zodiac CLI: Scaffold a 3-tier FastAPI project (DI, routers, config) with one command.
📦 Quick Install
| Use case | Install |
|---|---|
| Library only (use in your app) | uv add zodiac-core |
| Library + CLI (scaffold new projects) | uv add "zodiac-core[zodiac]" |
Extras (combinable): zodiac-core[sql] (SQLModel), zodiac-core[mongo] (Motor, helpers planned), zodiac-core[zodiac] (CLI). See the Installation Guide for details.
🚀 Two ways to use ZodiacCore
1. Scaffolding (fastest start)
Use the zodiac CLI to generate a full project: 3-tier architecture, dependency injection, config, and tests.
Note:
dfd-servicebelow is the name of the new project you want to create; replace it with your own.
mkdir dfd-service
cd dfd-service
uv init --python 3.12
uv add "zodiac-core[zodiac,sql]"
zodiac new dfd-service --tpl standard-3tier -o .. --force
uv add "fastapi[standard]" --dev
uv run fastapi run --reload
Open http://127.0.0.1:8000/docs and http://127.0.0.1:8000/api/v1/health. See Getting started and CLI docs.
2. Library (use in your own app)
Add zodiac-core to an existing FastAPI project and wire up logging, middleware, and response wrapping.
from fastapi import FastAPI
from zodiac_core.routing import APIRouter
from zodiac_core.logging import setup_loguru
from zodiac_core.middleware import register_middleware
from zodiac_core.exception_handlers import register_exception_handlers
from zodiac_core.exceptions import NotFoundException
from loguru import logger
setup_loguru(level="INFO", json_format=True)
app = FastAPI()
register_middleware(app)
register_exception_handlers(app)
router = APIRouter()
@router.get("/items/{item_id}")
async def read_item(item_id: int):
logger.info(f"request: item_id={item_id}")
if item_id == 0:
raise NotFoundException(message="Item not found")
return {"item_id": item_id}
app.include_router(router)
📚 Documentation
- Online: https://ttwshell.github.io/ZodiacCore-Py/ (multiple versions via release).
- Local:
make docs-serve(sources indocs/).
🤝 Contributing
Contributions are welcome. Please read CONTRIBUTING.md for development setup and workflow.
📄 License
This project is licensed under the MIT License.
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 zodiac_core-0.5.3.tar.gz.
File metadata
- Download URL: zodiac_core-0.5.3.tar.gz
- Upload date:
- Size: 45.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c129a398e20468b2453757a7032e544042b162f95be082fe87179087a45ba55b
|
|
| MD5 |
67014c4e82a68f095e9fd8fcd9544b4a
|
|
| BLAKE2b-256 |
8cec0eb6ac929b83cafba983d99f57001b7f28c6baf23f95f2e76412ff87fc42
|
Provenance
The following attestation bundles were made for zodiac_core-0.5.3.tar.gz:
Publisher:
ci.yml on TTWShell/ZodiacCore-Py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zodiac_core-0.5.3.tar.gz -
Subject digest:
c129a398e20468b2453757a7032e544042b162f95be082fe87179087a45ba55b - Sigstore transparency entry: 1115118343
- Sigstore integration time:
-
Permalink:
TTWShell/ZodiacCore-Py@c6832acb0734577a7906530680e044beb68e34ab -
Branch / Tag:
refs/tags/0.5.3 - Owner: https://github.com/TTWShell
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
ci.yml@c6832acb0734577a7906530680e044beb68e34ab -
Trigger Event:
release
-
Statement type:
File details
Details for the file zodiac_core-0.5.3-py3-none-any.whl.
File metadata
- Download URL: zodiac_core-0.5.3-py3-none-any.whl
- Upload date:
- Size: 44.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
842b3e40492726e04e7cc312a9456389bc176ea8291dfe3cf2ee7282c0fcb4cf
|
|
| MD5 |
09383b0148a4e2d302386108f21a5a5a
|
|
| BLAKE2b-256 |
9e10ab5b6e78a78d85c9b0732e0008cd481af5e8ec08bd7224ceab896fef9913
|
Provenance
The following attestation bundles were made for zodiac_core-0.5.3-py3-none-any.whl:
Publisher:
ci.yml on TTWShell/ZodiacCore-Py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zodiac_core-0.5.3-py3-none-any.whl -
Subject digest:
842b3e40492726e04e7cc312a9456389bc176ea8291dfe3cf2ee7282c0fcb4cf - Sigstore transparency entry: 1115118362
- Sigstore integration time:
-
Permalink:
TTWShell/ZodiacCore-Py@c6832acb0734577a7906530680e044beb68e34ab -
Branch / Tag:
refs/tags/0.5.3 - Owner: https://github.com/TTWShell
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
ci.yml@c6832acb0734577a7906530680e044beb68e34ab -
Trigger Event:
release
-
Statement type: