Build REST APIs with Django REST Framework patterns in FastAPI
Transform your FastAPI development with familiar Django REST Framework patterns.
FastAPI Ronin brings the beloved patterns and conventions from Django REST Framework to FastAPI, providing a structured and efficient way to build REST APIs. With familiar concepts like ViewSets, permissions, pagination, and serialization, you can rapidly develop robust API applications.
Just like skilled ronin who master their craft with precision and expertise, FastAPI Ronin helps you build reliable, well-structured APIs with time-tested patterns and best practices.
Documentation: bubaley.github.io/fastapi-ronin
Install FastAPI Ronin using UV:
uv add fastapi-roninHere's a complete example showing how to build a REST API with FastAPI Ronin:
# main.py - Complete FastAPI Ronin application
from fastapi import APIRouter, FastAPI
from tortoise import fields
from tortoise.contrib.fastapi import register_tortoise
from tortoise.models import Model
from fastapi_ronin.decorators import action, viewset
from fastapi_ronin.pagination import PageNumberPagination
from fastapi_ronin.schemas import SchemaMeta, build_schema, rebuild_schema
from fastapi_ronin.viewsets import ModelViewSet
from fastapi_ronin.wrappers import PaginatedResponseDataWrapper, ResponseDataWrapper
# Database setup
def register_database(app: FastAPI):
register_tortoise(
app,
db_url='sqlite://db.sqlite3',
modules={'models': ['main']},
generate_schemas=True,
add_exception_handlers=True,
)
# Models
class Company(Model):
id = fields.IntField(primary_key=True)
name = fields.CharField(max_length=255)
full_name = fields.TextField(null=True)
created_at = fields.DatetimeField(auto_now_add=True)
updated_at = fields.DatetimeField(auto_now=True)
# Schema meta
class CompanyMeta(SchemaMeta):
include = ('id', 'name', 'full_name', 'created_at', 'updated_at')
# Schemas
CompanySchema = build_schema(Company, meta=CompanyMeta)
CompanyCreateSchema = rebuild_schema(CompanySchema, exclude_readonly=True)
# Views
router = APIRouter(prefix='/companies', tags=['companies'])
@viewset(router)
class CompanyViewSet(ModelViewSet[Company]):
model = Company
read_schema = CompanySchema
create_schema = CompanyCreateSchema
pagination = PageNumberPagination
list_wrapper = PaginatedResponseDataWrapper
single_wrapper = ResponseDataWrapper
# permission_classes = [IsAuthenticatedOrReadOnly]
@action(methods=['GET'], detail=False, response_model=dict[str, int])
async def stats(self):
return {'total': await Company.all().count()}
# Application
app = FastAPI(title='My API')
register_database(app)
app.include_router(router)Start server:
uvicorn main:app --reloadTry API Endpoints:
"""
This creates the following endpoints:
- GET /companies/ - List companies with pagination
- POST /companies/ - Create new company
- GET /companies/{item_id}/ - Get specific company
- PUT /companies/{item_id}/ - Update company
- DELETE /companies/{item_id}/ - Delete company
- GET /companies/stats/ - Custom stats endpoint
Example API Responses:
GET /companies/ (with pagination wrapper):
{
"data": [
{
"id": 1,
"name": "Acme Corp",
"full_name": "Acme Corporation Ltd.",
"created_at": "2023-01-01T10:00:00Z",
"updated_at": "2023-01-01T10:00:00Z"
}
],
"pagination": {
"page": 1,
"page_size": 10,
"total_pages": 5,
"total_items": 47
}
}
GET /companies/1/ (with single wrapper):
{
"data": {
"id": 1,
"name": "Acme Corp",
"full_name": "Acme Corporation Ltd.",
"created_at": "2023-01-01T10:00:00Z",
"updated_at": "2023-01-01T10:00:00Z"
}
}
GET /companies/stats/ (custom action):
{
"total": 123
}
"""FastAPI Ronin is designed with these principles in mind:
- Familiar: If you know Django REST Framework, you already know FastAPI Ronin
- Flexible: Customize every aspect while maintaining sensible defaults
- Fast: Built on FastAPI's high-performance foundation
- Modular: Use only what you need, when you need it
Ready to build amazing APIs? Start with our Quick Start guide to get up and running in minutes.
Want to dive deeper? Explore our comprehensive guides:
- ViewSets - Learn about the core ViewSet concepts
- Schemas & Meta - Master schema generation and meta classes
- Permissions - Secure your APIs with permission classes
- Pagination - Implement efficient data pagination
- State Management - Manage request-scoped state
- Response Wrappers - Format consistent API responses
FastAPI Ronin is open source and welcomes contributions! Whether you're reporting bugs, suggesting features, or submitting pull requests, your involvement helps make the library better for everyone.
- GitHub: github.com/bubaley/fastapi-ronin
- Issues: Report bugs and request features
- Discussions: Get help and share ideas
FastAPI Ronin is released under the MIT License.
