Skip to main content

DRF-интеграция для django-basemodels — готовый сериализатор BaseModel и минимальные утилиты для работы с REST.

Project description

django-basemodels-rest

Лёгкая интеграция django-basemodels с Django REST Framework. Предоставляет готовый BaseModelSerializer, который корректно сериализует ключевые поля базовой модели: pk, created_at, updated_at, active_start, active_end, а также дополнительные вычисляемые поля is_active и polymorphic_ctype.

Установка

# в том же окружении, где установлен django-basemodels и DRF
poetry add django-basemodels-rest
poetry add djangorestframework

Требования

  • django-basemodels
  • djangorestframework

Что даёт пакет

  • BaseModelSerializerModelSerializer, который:
    • возвращает is_active по свойству is_active_real (учёт временных границ и состояния Celery),
    • возвращает polymorphic_ctype (id типа полиморфной модели),
    • предоставляет базовый набор полей для всех моделей-наследников BaseModel.

Быстрое использование

# serializers.py
from rest_framework import viewsets
from django_basemodels_rest.serializers import BaseModelSerializer
from .models import Article  # Article наследует BaseModel


class ArticleSerializer(BaseModelSerializer):
    class Meta(BaseModelSerializer.Meta):
        model = Article
        fields = BaseModelSerializer.Meta.fields + ("title", "body")
        writable_fields = ("title", "body")
# views.py
from rest_framework import viewsets
from .models import Article
from .serializers import ArticleSerializer


class ArticleViewSet(viewsets.ModelViewSet):
    queryset = Article.objects.all()
    serializer_class = ArticleSerializer

Расширение / Кастомизация

  • Для добавления полей — унаследуйте BaseModelSerializer и добавьте нужные поля в Meta.fields.
  • Для записи указывайте writable_fields в Meta — по умолчанию сериализатор делает все стандартные поля (pk, created_at, updated_at) только для чтения.

Примечания по тестированию

  • При тестах учитывайте, что is_active сериализуется из is_active_real. Для моков патчьте ту функцию, которую использует код сериализатора (в зависимости от того, как реализован импорт в django_basemodels).
  • Подключение пакета в проект не создаёт миграций — используйте миграции ваших моделей-наследников.

Лицензия

MIT

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

django_basemodels_rest-0.0.2.tar.gz (2.6 kB view details)

Uploaded Source

Built Distribution

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

django_basemodels_rest-0.0.2-py3-none-any.whl (3.2 kB view details)

Uploaded Python 3

File details

Details for the file django_basemodels_rest-0.0.2.tar.gz.

File metadata

  • Download URL: django_basemodels_rest-0.0.2.tar.gz
  • Upload date:
  • Size: 2.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.0 CPython/3.13.0 Windows/11

File hashes

Hashes for django_basemodels_rest-0.0.2.tar.gz
Algorithm Hash digest
SHA256 fc2579b7cc990019bcaad4a25567035b528136edbf4143f5773f6649c92919f9
MD5 64f17ff7f7fac3651e0cb4be4deda09e
BLAKE2b-256 ed3465c304881897d5a7ae40155df31c37f77981d37f6fbd13639825881c0a10

See more details on using hashes here.

File details

Details for the file django_basemodels_rest-0.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for django_basemodels_rest-0.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1d5bbacbc5f514003dabe3b60b7e87995d418140fc72eb1ce5e34e5697592f9e
MD5 95a32d31d821cee718bf68dc84e0619e
BLAKE2b-256 8d07b091ec092af8797e59c621e04ba75bde93eec6a58de0f197c235a414a1e5

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