Skip to main content

This project provides some extra functionalities to be used with Django REST Framework

Project description

drf-addons-plus

Some magic to the base Django REST Framework


Overview

This project provides some extra functionalities to be used with Django REST Framework

  • Field selection to Viewsets, eg. ?fields=id,name
  • Conditional filtering to Viewsets, eg. ?conditional=active,-inactive

Requirements

  • Python 3.8+
  • Django 4.2, 5.0, 5.1
  • Django REST Framework 3.0+ or less, you can test it

Installation

Install using pip...

pip install drf_addons_plus

Examples

  • models.py:
from django.db import models

class FooModel(models.Model):
    name = models.CharField(max_length=100)
    status = models.BooleanField()
    category = models.CharField(choices=['foo', 'bar'])
  • serializers.py:
from drf_addons_plus import serializers

from .models import FooModel


class FooSerializer(serializers.DynamicFieldsModelSerializer):
    class Meta:
        model = FooModel
        fields = ['name', 'status', 'category']
  • views.py:
from rest_framework import filters
from drf_addons_plus import filters as filters_plus
from drf_addons_plus import viewsets

from .models import FooModel
from .serializers import FooSerializer


class FooViewSet(viewsets.FieldsModelViewSet):
    queryset = FooModel.objects.all()
    serializer_class = FooSerializer
    permission_classes = []
    filter_backends = [filters.SearchFilter, filters_plus.ConditionalFilter, filters_plus.FieldsFitlter]
    search_fields = ['name']
    conditional_fields = ['status']
    filter_fields = ['category']
  • Request http://localhost:8000/foo/:
[
    {
        "name": "Bar",
        "status": false,
        "category": "Foo",
    }
]
  • Request http://localhost:8000/foo/?fields=name&conditional=-status:
[
    {
        "name": "Bar"
    }
]
  • Request http://localhost:8000/foo/?conditional=status:
[]
  • Request http://localhost:8000/foo/?category="foo":
[
    {
        "name": "Bar",
        "status": false,
        "category": "Foo",
    }
]

Disclaimer

This project has started and maybe will be maintened, but it's simple enough to probably not give you any trouble.

Credits

Django REST Framework YAtOff

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

drf_addons_plus-0.2.1.tar.gz (18.5 kB view details)

Uploaded Source

Built Distribution

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

drf_addons_plus-0.2.1-py3-none-any.whl (19.3 kB view details)

Uploaded Python 3

File details

Details for the file drf_addons_plus-0.2.1.tar.gz.

File metadata

  • Download URL: drf_addons_plus-0.2.1.tar.gz
  • Upload date:
  • Size: 18.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.3

File hashes

Hashes for drf_addons_plus-0.2.1.tar.gz
Algorithm Hash digest
SHA256 4f523c370af5010f084b7adf1e5194f170e54ee885857eb71d9880c4ee547ecc
MD5 69442e686229b5d60d8864013edb55f4
BLAKE2b-256 61728411913b135957af3ce454618c0601996f4583e9a212fa125617427c3ec2

See more details on using hashes here.

File details

Details for the file drf_addons_plus-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for drf_addons_plus-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 86b7a2476fb435b2fa64c3882d2ed2aa37ec499069113c7d28309ee59e6d7433
MD5 ca2c3bf5108fb9c5e96fecaa8f94cb24
BLAKE2b-256 777b9d09525c237f2be5d7cad7e9fbc8b92442199c6b355e5af816c477afbf77

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