Fast, beautiful and extensible administrative interface framework for Starlette/FastApi applications
Project description
starlette-admin
Fast, beautiful, and extensible administrative interface framework for Starlette & FastApi applications
why starlette-admin?
FastAPI has emerged as a popular web framework for building APIs in Python. However, it lacks a mature admin interface solution like Flask-Admin to quickly manage your data through a user-friendly interface. Although solutions like Sqladmin and Fastapi-Admin exist, they only work with specific ORMs such as SQLAlchemy and Tortoise ORM.
Starlette-admin was born from the need for a FastAPI admin interface that works with various data layer. It aims to provide a complete solution for CRUD interfaces regardless of the database backend. Starlette-admin works out of the box with multiple ORM/ODMs and can also be used with a custom data layer.
Getting started
- Check out the documentation.
- Try the live demo. (Source code)
- Follow the tutorials
- Try the several usage examples included in the /examples folder
- If you find this project helpful or interesting, please consider giving it a star ⭐️
Features
- CRUD any data with ease
- Automatic form validation
- Advanced table widget with Datatables
- Search and filtering
- Search highlighting
- Multi-column ordering
- Export data to CSV/EXCEL/PDF and Browser Print
- Authentication
- Authorization
- Manage Files
- Custom views
- Custom batch actions
- Supported ORMs
- SQLAlchemy
- SQLModel
- MongoEngine
- ODMantic
- Custom backend (doc, example)
- Internationalization
Installation
PIP
$ pip install starlette-admin
Poetry
$ poetry add starlette-admin
Example
This is a simple example with SQLAlchemy model
from sqlalchemy import create_engine
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import Mapped, mapped_column
from starlette.applications import Starlette
from starlette_admin.contrib.sqla import Admin, ModelView
Base = declarative_base()
engine = create_engine("sqlite:///test.db", connect_args={"check_same_thread": False})
# Define your model
class Post(Base):
__tablename__ = "posts"
id: Mapped[int] = mapped_column(primary_key=True)
title: Mapped[str]
Base.metadata.create_all(engine)
app = Starlette() # FastAPI()
# Create admin
admin = Admin(engine, title="Example: SQLAlchemy")
# Add view
admin.add_view(ModelView(Post))
# Mount admin to your app
admin.mount_to(app)
Access your admin interface in your browser at http://localhost:8000/admin
Third party
starlette-admin is built with other open source projects:
Contributing
Contributions are welcome and greatly appreciated! Before getting started, please read our contribution guidelines
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
Hashes for starlette_admin-0.14.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5b6260d7ed3db455585852d669feb7ed9a8c5f9a1e3d48d21a52912ec37e18f9 |
|
MD5 | e68a8ab75138f46a35a5fe8e8a7ace56 |
|
BLAKE2b-256 | bd5aac9ab9846350b40d73539c9094bf447d7900c586e013011af2a9fe995676 |