Skip to main content

Generic FastAPI + SQLAlchemy admin backend.

Project description

xladmin

xladmin это backend-пакет админки для FastAPI + SQLAlchemy.

Важно:

  • имя пакета в PyPI: xladmin
  • импорт в Python: from xladmin import ...
  • исходники монорепы: Artasov/xladmin

Основной API

  • AdminConfig — корневой декларативный конфиг
  • ModelConfig — конфиг одной ORM-модели
  • FieldConfig — переопределение поведения конкретного поля
  • BulkActionConfig — кастомное действие над несколькими объектами
  • ObjectActionConfig — кастомное действие над одним объектом
  • ModelsBlock — блок моделей для sidebar и overview
  • ListFilterConfig — декларативный фильтр списка модели
  • HttpConfig — контракт интеграции с проектом
  • create_router(...) — фабрика FastAPI-router

Короткие имена считаются основными. Старые Admin* имена и create_admin_router(...) оставлены как alias для совместимости.

Минимальный пример

from xladmin import AdminConfig, HttpConfig, ModelConfig, create_router

from src.core.auth.dependencies import get_current_user
from src.core.db.session import get_db_session
from src.modules.identity.models import UserORM


xladmin_config = AdminConfig(
    models=(
        ModelConfig(model=UserORM),
    ),
)

router = create_router(
    HttpConfig(
        registry=xladmin_config,
        get_db_session_dependency=get_db_session,
        get_current_user_dependency=get_current_user,
        is_allowed=lambda user: bool(user.is_staff),
    ),
)

ModelConfig(model=UserORM) уже достаточно для базовой админки. Библиотека сама достроит:

  • slug
  • title
  • базовые search_fields
  • базовый ordering

Что есть в библиотеке

  • list / detail / create / patch / delete
  • bulk actions и object actions
  • relation choices
  • model descriptions
  • model blocks
  • query_for_list для кастомизации list-query
  • list_filters для фильтров списка в отдельной правой панели на странице модели
  • option-specific filter_handler у select-фильтров для canned query scopes
  • width_px у FieldConfig для ширины колонок списка
  • display_kind="image" у FieldConfig для image-preview в списке и на detail-странице
  • авто-детект JSON полей
  • RU / EN locale
  • delete preview для single delete и bulk delete
  • удаление обязательных дочерних one-to-many связей даже без явного ORM cascade
  • дефолтный порядок полей по порядку объявления в ORM-модели

Совместимость

  • FastAPI >=0.115,<1.0
  • Pydantic >=2.9,<3.0
  • SQLAlchemy >=2.0,<3.0

Документация

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

xladmin-0.1.8.tar.gz (25.8 kB view details)

Uploaded Source

Built Distribution

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

xladmin-0.1.8-py3-none-any.whl (19.8 kB view details)

Uploaded Python 3

File details

Details for the file xladmin-0.1.8.tar.gz.

File metadata

  • Download URL: xladmin-0.1.8.tar.gz
  • Upload date:
  • Size: 25.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for xladmin-0.1.8.tar.gz
Algorithm Hash digest
SHA256 e0ef98a72ad7850bf7f2df9e18f12b7a8ea71802af80cebfdf78cea2ae078ee4
MD5 b76ad7ee605a7fcb594627dc843f2603
BLAKE2b-256 2ef73da00c992c8fa9e8a7cde121c5b96fe1edbf2683ca5c2c6d8f907435f89a

See more details on using hashes here.

File details

Details for the file xladmin-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: xladmin-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 19.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for xladmin-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 b3be2226636266864e58c068efee437ed0a218a7558fff69be9d9b8df919a15e
MD5 8d64b84c50518396b9c9d21225973160
BLAKE2b-256 9052762e9b1cef65bf4d1f1d0b7a9c11bc2a3ba7dc55cff5f8afb595b69112b9

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