Skip to main content

ZodiacCore-Py: A high-performance core library for modern Python web services.

Project description

ZodiacCore-Py

Python 3.12+ FastAPI Pydantic v2 Async First MIT License

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 ZodiacException to standard HTTP 4xx/5xx JSON responses.
  • 💾 Database Abstraction: Async SQLAlchemy session management and BaseSQLRepository with pagination helpers (paginate_query).
  • 🎁 Standard Response Wrapper: Automatic wrapping of API responses into code / data / message via APIRouter.
  • 📄 Standard Pagination: PageParams and PagedResponse[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.

uv add "zodiac-core[zodiac]"
zodiac new my_app --tpl standard-3tier -o ./projects
cd projects/my_app
uv sync --extra 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

🤝 Contributing

Contributions are welcome. Please read CONTRIBUTING.md for development setup and workflow.

📄 License

This project is licensed under the MIT License.

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

zodiac_core-0.2.0.tar.gz (37.6 kB view details)

Uploaded Source

Built Distribution

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

zodiac_core-0.2.0-py3-none-any.whl (38.6 kB view details)

Uploaded Python 3

File details

Details for the file zodiac_core-0.2.0.tar.gz.

File metadata

  • Download URL: zodiac_core-0.2.0.tar.gz
  • Upload date:
  • Size: 37.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for zodiac_core-0.2.0.tar.gz
Algorithm Hash digest
SHA256 1aae947fafc18912274bf0ecb4c72f7505ad88d21879c7bc20fe6a63ee2fcd7a
MD5 3d49e27089fefe64963d11dbf7da3989
BLAKE2b-256 63b6e5b007ae81b69dfcec28a7ac9ad1d19dc2c10a426f6cd8b4737dea42d3ee

See more details on using hashes here.

Provenance

The following attestation bundles were made for zodiac_core-0.2.0.tar.gz:

Publisher: ci.yml on TTWShell/ZodiacCore-Py

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

File details

Details for the file zodiac_core-0.2.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for zodiac_core-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fcdef5a8cf9cb7d8e906a51f5e83dd1f5b9dc76179fe04380ef028469dc26c23
MD5 b352c69bc33c1d147d37a6905ee4ddf8
BLAKE2b-256 713a9f11f6c8409f63ce86cb6b5259fb58c51f6faec0ea755deb2fd8f474819e

See more details on using hashes here.

Provenance

The following attestation bundles were made for zodiac_core-0.2.0-py3-none-any.whl:

Publisher: ci.yml on TTWShell/ZodiacCore-Py

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