Just Encapsulated Controllers — The Class-Based System for Application Program Interfaces
Project description
JEC-API
A powerful wrapper around FastAPI that brings class-based routing, strict method mapping, and modern developer tools to your API development.
Features
- Class-Based Routes: Group related endpoints into a single class for better organization.
- Strict Method Mapping: Methods named
get,post,put, etc., are automatically mapped to HTTP verbs. - Data Object Support: Native Pydantic integration for automatic request/response validation and schema generation.
- API Decorators: Built-in
@log,@speed, and@versiondecorators for observability and control. - Programmatic Configuration: Unified
core.tinker()method to configure FastAPI and Uvicorn. - JEC DevTools: Real-time, dark-themed developer console at
/__dev__for monitoring traffic and performance.
Installation
pip install jec-api
Quick Start
- Define a Route Class
from pydantic import BaseModel
from jec_api import Route, log, speed
class UserResponse(BaseModel):
id: int
name: str
class Users(Route):
@log
@speed
async def get(self) -> list[UserResponse]:
"""List all users with logging and speed tracking"""
return [UserResponse(id=1, name="Alice")]
- Configure and Run
from jec_api import Core
from routes import Users
core = Core()
core.tinker(
title="My API",
dev=True, # Enable JEC DevTools
reload=True # Auto-reload on changes
)
core.register(Users)
if __name__ == "__main__":
core.run(port=8000)
Usage Guide
Defining Routes
Inherit from jec_api.Route. The class name is converted to kebab-case for the base path (e.g., UserProfiles -> /user-profiles), unless overridden with the path attribute.
Method Mapping
Methods named exactly after HTTP verbs (e.g., get, post) are registered as endpoints. Others are ignored.
API Decorators
Enhance your endpoints with built-in decorators:
@log: Logs function calls, arguments, and return values/exceptions.@speed: Measures execution time in milliseconds.@version(">=1.0.0"): Enforces semver constraints via theX-API-Versionheader.
Configuration (core.tinker())
The tinker() method provides a unified interface for configuration:
- FastAPI Options:
title,description,version,docs_url, etc. - Uvicorn Options:
host,port,reload,log_level, etc. - DevTools: Set
dev=Trueto enable the developer console. - Versioning:
strict_versioning=Trueto require version headers on all versioned routes.
JEC DevTools
Access a premium, real-time monitoring dashboard at /__dev__ (or your custom dev_path). It provides:
- Live request/response tracking via SSE.
- Visual execution timing (Green/Yellow/Red).
- Expanded logs for @log decorated methods.
- Version check results.
License
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 jec_api-0.1.3.tar.gz.
File metadata
- Download URL: jec_api-0.1.3.tar.gz
- Upload date:
- Size: 7.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f1f5e437a7f9c1b7359ef7c103d5537a95a279044921d2e21b52d485c48ac8db
|
|
| MD5 |
9595033e9b9f18b934ee1d8851314be8
|
|
| BLAKE2b-256 |
3c235d366017f1c9b8748489b6e059fb910b7c14f34f9318279f81c613513950
|
File details
Details for the file jec_api-0.1.3-py3-none-any.whl.
File metadata
- Download URL: jec_api-0.1.3-py3-none-any.whl
- Upload date:
- Size: 42.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a0b924c4f29dd77b58eba0685c7f175a065e19863d66b4a8d44bcdbe64c32d03
|
|
| MD5 |
b0dd17ead95ea5862bfe0c2c40417627
|
|
| BLAKE2b-256 |
5d083642324506719336bf36e97962208c31e156520b8d0af2d1f4897cc9bc62
|