mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-01-26 09:14:34 +03:00
c603b98403
* Add failing test when rendering to json a schema with timedelta * Fix JSONOpenAPIRenderer for fields with default=timedelta() * fix isort * fix test for python 3.5 Co-authored-by: Pierre Chiquet <pierre.chiquet@ubikey.fr>
246 lines
7.2 KiB
Python
246 lines
7.2 KiB
Python
import uuid
|
|
from datetime import timedelta
|
|
|
|
from django.core.validators import (
|
|
DecimalValidator, MaxLengthValidator, MaxValueValidator,
|
|
MinLengthValidator, MinValueValidator, RegexValidator
|
|
)
|
|
from django.db import models
|
|
|
|
from rest_framework import generics, permissions, serializers
|
|
from rest_framework.decorators import action
|
|
from rest_framework.response import Response
|
|
from rest_framework.schemas.openapi import AutoSchema
|
|
from rest_framework.views import APIView
|
|
from rest_framework.viewsets import GenericViewSet, ViewSet
|
|
|
|
|
|
class ExampleListView(APIView):
|
|
permission_classes = [permissions.IsAuthenticatedOrReadOnly]
|
|
|
|
def get(self, *args, **kwargs):
|
|
pass
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
pass
|
|
|
|
|
|
class ExampleDetailView(APIView):
|
|
permission_classes = [permissions.IsAuthenticatedOrReadOnly]
|
|
|
|
def get(self, *args, **kwargs):
|
|
pass
|
|
|
|
|
|
class DocStringExampleListView(APIView):
|
|
"""
|
|
get: A description of my GET operation.
|
|
post: A description of my POST operation.
|
|
"""
|
|
permission_classes = [permissions.IsAuthenticatedOrReadOnly]
|
|
|
|
def get(self, *args, **kwargs):
|
|
pass
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
pass
|
|
|
|
|
|
class DocStringExampleDetailView(APIView):
|
|
permission_classes = [permissions.IsAuthenticatedOrReadOnly]
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
A description of my GET operation.
|
|
"""
|
|
pass
|
|
|
|
|
|
# Generics.
|
|
class ExampleSerializer(serializers.Serializer):
|
|
date = serializers.DateField()
|
|
datetime = serializers.DateTimeField()
|
|
duration = serializers.DurationField(default=timedelta())
|
|
hstore = serializers.HStoreField()
|
|
uuid_field = serializers.UUIDField(default=uuid.uuid4)
|
|
|
|
|
|
class ExampleGenericAPIView(generics.GenericAPIView):
|
|
serializer_class = ExampleSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
from datetime import datetime
|
|
now = datetime.now()
|
|
|
|
serializer = self.get_serializer(data=now.date(), datetime=now)
|
|
return Response(serializer.data)
|
|
|
|
|
|
class ExampleGenericViewSet(GenericViewSet):
|
|
serializer_class = ExampleSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
from datetime import datetime
|
|
now = datetime.now()
|
|
|
|
serializer = self.get_serializer(data=now.date(), datetime=now)
|
|
return Response(serializer.data)
|
|
|
|
@action(detail=False)
|
|
def new(self, *args, **kwargs):
|
|
pass
|
|
|
|
@action(detail=False)
|
|
def old(self, *args, **kwargs):
|
|
pass
|
|
|
|
|
|
# Validators and/or equivalent Field attributes.
|
|
class ExampleValidatedSerializer(serializers.Serializer):
|
|
integer = serializers.IntegerField(
|
|
validators=(
|
|
MaxValueValidator(limit_value=99),
|
|
MinValueValidator(limit_value=-11),
|
|
)
|
|
)
|
|
string = serializers.CharField(
|
|
validators=(
|
|
MaxLengthValidator(limit_value=10),
|
|
MinLengthValidator(limit_value=2),
|
|
)
|
|
)
|
|
regex = serializers.CharField(
|
|
validators=(
|
|
RegexValidator(regex=r'[ABC]12{3}'),
|
|
),
|
|
help_text='must have an A, B, or C followed by 1222'
|
|
)
|
|
lst = serializers.ListField(
|
|
validators=(
|
|
MaxLengthValidator(limit_value=10),
|
|
MinLengthValidator(limit_value=2),
|
|
)
|
|
)
|
|
decimal1 = serializers.DecimalField(max_digits=6, decimal_places=2, coerce_to_string=False)
|
|
decimal2 = serializers.DecimalField(max_digits=5, decimal_places=0, coerce_to_string=False,
|
|
validators=(DecimalValidator(max_digits=17, decimal_places=4),))
|
|
decimal3 = serializers.DecimalField(max_digits=8, decimal_places=2, coerce_to_string=True)
|
|
decimal4 = serializers.DecimalField(max_digits=8, decimal_places=2, coerce_to_string=True,
|
|
validators=(DecimalValidator(max_digits=17, decimal_places=4),))
|
|
decimal5 = serializers.DecimalField(max_digits=6, decimal_places=2)
|
|
email = serializers.EmailField(default='foo@bar.com')
|
|
url = serializers.URLField(default='http://www.example.com', allow_null=True)
|
|
uuid = serializers.UUIDField()
|
|
ip4 = serializers.IPAddressField(protocol='ipv4')
|
|
ip6 = serializers.IPAddressField(protocol='ipv6')
|
|
ip = serializers.IPAddressField()
|
|
|
|
|
|
class ExampleValidatedAPIView(generics.GenericAPIView):
|
|
serializer_class = ExampleValidatedSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
serializer = self.get_serializer(integer=33, string='hello', regex='foo', decimal1=3.55,
|
|
decimal2=5.33, email='a@b.co',
|
|
url='http://localhost', uuid=uuid.uuid4(), ip4='127.0.0.1', ip6='::1',
|
|
ip='192.168.1.1')
|
|
return Response(serializer.data)
|
|
|
|
|
|
# Serializer with model.
|
|
class OpenAPIExample(models.Model):
|
|
first_name = models.CharField(max_length=30)
|
|
|
|
|
|
class ExampleSerializerModel(serializers.Serializer):
|
|
date = serializers.DateField()
|
|
datetime = serializers.DateTimeField()
|
|
hstore = serializers.HStoreField()
|
|
uuid_field = serializers.UUIDField(default=uuid.uuid4)
|
|
|
|
class Meta:
|
|
model = OpenAPIExample
|
|
|
|
|
|
class ExampleOperationIdDuplicate1(generics.GenericAPIView):
|
|
serializer_class = ExampleSerializerModel
|
|
|
|
def get(self, *args, **kwargs):
|
|
pass
|
|
|
|
|
|
class ExampleOperationIdDuplicate2(generics.GenericAPIView):
|
|
serializer_class = ExampleSerializerModel
|
|
|
|
def get(self, *args, **kwargs):
|
|
pass
|
|
|
|
|
|
class ExampleGenericAPIViewModel(generics.GenericAPIView):
|
|
serializer_class = ExampleSerializerModel
|
|
|
|
def get(self, *args, **kwargs):
|
|
from datetime import datetime
|
|
now = datetime.now()
|
|
|
|
serializer = self.get_serializer(data=now.date(), datetime=now)
|
|
return Response(serializer.data)
|
|
|
|
|
|
class ExampleAutoSchemaComponentName(generics.GenericAPIView):
|
|
serializer_class = ExampleSerializerModel
|
|
schema = AutoSchema(component_name="Ulysses")
|
|
|
|
def get(self, *args, **kwargs):
|
|
from datetime import datetime
|
|
now = datetime.now()
|
|
|
|
serializer = self.get_serializer(data=now.date(), datetime=now)
|
|
return Response(serializer.data)
|
|
|
|
|
|
class ExampleAutoSchemaDuplicate1(generics.GenericAPIView):
|
|
serializer_class = ExampleValidatedSerializer
|
|
schema = AutoSchema(component_name="Duplicate")
|
|
|
|
def get(self, *args, **kwargs):
|
|
from datetime import datetime
|
|
now = datetime.now()
|
|
|
|
serializer = self.get_serializer(data=now.date(), datetime=now)
|
|
return Response(serializer.data)
|
|
|
|
|
|
class ExampleAutoSchemaDuplicate2(generics.GenericAPIView):
|
|
serializer_class = ExampleSerializerModel
|
|
schema = AutoSchema(component_name="Duplicate")
|
|
|
|
def get(self, *args, **kwargs):
|
|
from datetime import datetime
|
|
now = datetime.now()
|
|
|
|
serializer = self.get_serializer(data=now.date(), datetime=now)
|
|
return Response(serializer.data)
|
|
|
|
|
|
class ExampleViewSet(ViewSet):
|
|
serializer_class = ExampleSerializerModel
|
|
|
|
def list(self, request):
|
|
pass
|
|
|
|
def create(self, request):
|
|
pass
|
|
|
|
def retrieve(self, request, pk=None):
|
|
pass
|
|
|
|
def update(self, request, pk=None):
|
|
pass
|
|
|
|
def partial_update(self, request, pk=None):
|
|
pass
|
|
|
|
def destroy(self, request, pk=None):
|
|
pass
|