Skip to main content

Modern Python web framework for building APIs with minimal boilerplate

Project description

Zenith Framework

PyPI version Python 3.12-3.13 License: MIT Tests Documentation

A modern Python web framework with intuitive developer experience and exceptional performance.

๐ŸŽฏ Modern DX: Zero-config setup, database models with chainable queries, one-liner features, and clean architecture patterns - making Python web development incredibly productive.

What is Zenith?

Zenith brings together exceptional productivity, outstanding performance, and full type safety:

  • ๐Ÿš€ Zero-config setup - app = Zenith() just works with intelligent defaults
  • ๐Ÿ—๏ธ Intuitive models - User.where(active=True).order_by('-created_at').limit(10)
  • โšก One-liner features - app.add_auth(), app.add_admin(), app.add_api()
  • ๐ŸŽฏ Enhanced DX - No session management, ZenithModel handles it automatically
  • ๐ŸŽ๏ธ Exceptional performance - 9,600+ req/s with full async support
  • ๐Ÿ›ก๏ธ Production-ready - Security, monitoring, and middleware built-in

๐Ÿš€ Zero-Config Quick Start

pip install zenithweb
from zenith import Zenith
from zenith import Session  # Database session dependency
from zenith.db import ZenithModel  # Modern database models
from sqlmodel import Field
from typing import Optional

# ๐ŸŽฏ Zero-config setup - just works!
app = Zenith()

# โšก Add features in one line each
app.add_auth()    # JWT authentication + /auth/login
app.add_admin()   # Admin dashboard at /admin
app.add_api("My API", "1.0.0")  # API docs at /docs

# ๐Ÿ—๏ธ Modern models with chainable query patterns
class User(ZenithModel, table=True):
    id: Optional[int] = Field(primary_key=True)
    name: str = Field(max_length=100)
    email: str = Field(unique=True)
    active: bool = Field(default=True)

# ๐ŸŽจ Clean routes with enhanced DX
@app.get("/")
async def home():
    return {"message": "Modern DX in Python!"}

@app.get("/users")
async def list_users():  # โœจ No session management needed!
    # Clean chaining: User.where().order_by().limit()
    users = await User.where(active=True).order_by('-id').limit(10).all()
    return {"users": [user.to_dict() for user in users]}

@app.post("/users")
async def create_user(user_data: dict):
    # Clean API: User.create() - no session management!
    user = await User.create(**user_data)
    return {"user": user.to_dict()}

@app.get("/users/{user_id}")
async def get_user(user_id: int):
    # Automatic 404 handling
    user = await User.find_or_404(user_id)
    return {"user": user.to_dict()}

# ๐Ÿƒโ€โ™‚๏ธ Run it
if __name__ == "__main__":
    import uvicorn
    uvicorn.run(app, host="127.0.0.1", port=8000)

Run with:

uvicorn main:app --reload

๐ŸŽฏ Modern DX Features

๐Ÿš€ Zero-Config Setup

app = Zenith()  # Just works! No complex configuration needed
  • Intelligent defaults - Development vs production auto-detection
  • Automatic middleware - Security, CORS, logging configured automatically
  • Environment-aware - Uses ZENITH_ENV or sensible detection

๐Ÿ—๏ธ Intuitive Database Models

# Intuitive database operations - seamless chaining!
users = await User.where(active=True).order_by('-created_at').limit(10).all()
user = await User.find_or_404(123)  # Automatic 404 handling
user = await User.create(name="Alice", email="alice@example.com")
  • ZenithModel - Modern ORM with chainable queries
  • Automatic sessions - No manual database session management
  • Type-safe queries - Full async support with SQLModel integration

โšก One-Liner Features

app.add_auth()     # JWT authentication + /auth/login endpoint
app.add_admin()    # Admin dashboard at /admin with health checks
app.add_api()      # API documentation at /docs and /redoc
  • Instant features - Complex functionality in single lines
  • Production-ready - Each feature includes monitoring and security
  • Configurable - Sensible defaults with full customization options

๐ŸŽฏ Clean Dependency Injection

@app.get("/users")
async def get_users(session: AsyncSession = Session):
    # Simple database session injection
    users = await User.all()  # ZenithModel uses the session automatically
    return users
  • Simple patterns - Session for database, Auth for current user
  • Service injection - Inject(ServiceClass) for business logic
  • Type-safe - Full IDE support and autocompletion

๐ŸŽ๏ธ Exceptional Performance

  • 9,600+ req/s - Exceptional performance with modern features
  • No performance penalty - Zero overhead from convenience features
  • Async-first - Full async/await with Python 3.12+ optimizations
  • Production tested - 70% middleware retention with full feature stack

๐Ÿ›ก๏ธ Production-Ready

  • Security by default - CSRF, CORS, security headers automatic
  • Built-in monitoring - /health, /metrics, request tracing
  • Error handling - Structured errors with proper HTTP status codes
  • Testing framework - Comprehensive testing utilities included

๐ŸŒ Full-Stack Support

  • Serve SPAs (React, Vue, SolidJS) with app.spa("dist")
  • WebSocket support with connection management
  • Static file serving with caching
  • Database integration with async SQLAlchemy

๐Ÿ“ Project Structure

Clean organization with zero configuration:

your-app/
โ”œโ”€โ”€ main.py         # app = Zenith() + routes
โ”œโ”€โ”€ models.py       # ZenithModel classes
โ”œโ”€โ”€ services.py     # Business logic (optional)
โ”œโ”€โ”€ migrations/     # Database migrations (auto-generated)
โ””โ”€โ”€ tests/          # Testing with built-in TestClient

Or traditional clean architecture:

your-app/
โ”œโ”€โ”€ main.py         # Application entry point
โ”œโ”€โ”€ models/         # ZenithModel classes
โ”œโ”€โ”€ services/       # Service classes with @Service decorator
โ”œโ”€โ”€ routes/         # Route modules (optional)
โ”œโ”€โ”€ middleware/     # Custom middleware
โ””โ”€โ”€ tests/          # Comprehensive test suite

Performance

Verified Benchmark Results:

  • Simple endpoints: 9,557 req/s
  • JSON endpoints: 9,602 req/s
  • With full middleware: 6,694 req/s (70% retention)

Run your own benchmarks:

python scripts/run_performance_tests.py --quick

Performance varies by hardware and application complexity.

Documentation

๐Ÿ“š Examples

๐Ÿ”ฅ Modern DX Examples:

๐Ÿš€ Complete Examples:

CLI Tools

# Create new project with secure defaults
zen new my-api

# Generate secure SECRET_KEY
zen keygen

# Development server with hot reload
zen dev

# Production server
zen serve --workers 4

Installation

# Basic installation
pip install zenithweb

# With production dependencies
pip install "zenithweb[production]"

# With development tools
pip install "zenithweb[dev]"

Production Deployment

Docker

FROM python:3.12-slim

WORKDIR /app
COPY . .
RUN pip install "zenithweb[production]"

CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8000"]

Environment Configuration

from zenith import Zenith

app = Zenith()

# Environment-specific behavior:
# development (or dev): Enhanced error reporting, auto-generated secrets
# production (or prod): Optimized for deployment, requires SECRET_KEY
# test: Testing mode with rate limiting disabled
# staging: Production-like with enhanced monitoring

# Manual configuration if needed
from zenith.config import Config
app = Zenith(
    config=Config(
        database_url=os.getenv("DATABASE_URL"),
        redis_url=os.getenv("REDIS_URL"),
        secret_key=os.getenv("SECRET_KEY")
        # debug automatically set based on ZENITH_ENV
    )
)

Contributing

We welcome contributions! Please see our Contributing Guide.

git clone https://github.com/nijaru/zenith.git
cd zenith
pip install -e ".[dev]"
pytest  # Run tests

Status

Latest Version: v0.0.3 Python Support: 3.12-3.13 Test Suite: 100% passing (862 tests) Performance: Production-ready with 9,600+ req/s capability
Architecture: Clean separation with Service system and simple dependency patterns

Zenith is production-ready with comprehensive middleware, performance optimizations, and clean architecture patterns for modern Python applications.

License

MIT License. See LICENSE for details.

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

zenithweb-0.0.5.tar.gz (261.5 kB view details)

Uploaded Source

Built Distribution

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

zenithweb-0.0.5-py3-none-any.whl (213.7 kB view details)

Uploaded Python 3

File details

Details for the file zenithweb-0.0.5.tar.gz.

File metadata

  • Download URL: zenithweb-0.0.5.tar.gz
  • Upload date:
  • Size: 261.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for zenithweb-0.0.5.tar.gz
Algorithm Hash digest
SHA256 0cf6fb16b9ba48a551f399c04494a695bd3e7a2636a524c74532b924a60ae196
MD5 63d5c00831e9178504297dad60f27e67
BLAKE2b-256 5576a250bbe6ca5e14c0e628785452e5990478c2c32cf480babfc03f7a493231

See more details on using hashes here.

File details

Details for the file zenithweb-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: zenithweb-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 213.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for zenithweb-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 1b2d22ca17b991566d4db6cc0b4b63c59d9fd0ecdbf58d9c4b5d3393e5d485dd
MD5 a6be44b77a6012b21c0ab781a63d73a5
BLAKE2b-256 b4cdcb61a92d53eeeb7271e940303dfc95742acb7748361b6eadba9e3a52ed55

See more details on using hashes here.

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