X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fapigen%2Fapi.template.py;h=e9dbeb8af59f362b5e072a30e5bd380f45969927;hb=798881268d3586ecbaf4483b69d71cf8ec27583b;hp=6638808bca153738f62befbcf61fb45929f0ada8;hpb=86fd8a38d6ce40991b86c5378e2286ca2dc33420;p=plstackapi.git diff --git a/planetstack/apigen/api.template.py b/planetstack/apigen/api.template.py index 6638808..e9dbeb8 100644 --- a/planetstack/apigen/api.template.py +++ b/planetstack/apigen/api.template.py @@ -5,6 +5,7 @@ from rest_framework import serializers from rest_framework import generics from core.models import * from django.forms import widgets +from rest_framework import filters """ Schema of the generator object: @@ -45,6 +46,21 @@ class {{ object.camel }}Serializer(serializers.HyperlinkedModelSerializer): class Meta: model = {{ object.camel }} fields = ({% for prop in object.props %}'{{ prop }}',{% endfor %}{% for ref in object.refs %}{%if ref.multi %}'{{ ref.plural }}'{% else %}'{{ ref }}'{% endif %},{% endfor %}) + +class {{ object.camel }}IdSerializer(serializers.ModelSerializer): + id = serializers.Field() + {% for ref in object.refs %} + {% if ref.multi %} + {{ ref.plural }} = serializers.HyperlinkedRelatedField(many=True, read_only=True, view_name='{{ ref }}-detail') + {% else %} + {{ ref }} = serializers.HyperlinkedRelatedField(read_only=True, view_name='{{ ref }}-detail') + {% endif %} + {% endfor %} + class Meta: + model = {{ object.camel }} + fields = ({% for prop in object.props %}'{{ prop }}',{% endfor %}{% for ref in object.refs %}{%if ref.multi %}'{{ ref.plural }}'{% else %}'{{ ref }}'{% endif %},{% endfor %}) + + {% endfor %} serializerLookUp = { @@ -60,7 +76,17 @@ serializerLookUp = { class {{ object.camel }}List(generics.ListCreateAPIView): queryset = {{ object.camel }}.objects.select_related().all() serializer_class = {{ object.camel }}Serializer - + id_serializer_class = {{ object.camel }}IdSerializer + filter_backends = (filters.DjangoFilterBackend,) + filter_fields = ({% for prop in object.props %}'{{ prop }}',{% endfor %}{% for ref in object.refs %}{%if ref.multi %}'{{ ref.plural }}'{% else %}'{{ ref }}'{% endif %},{% endfor %}) + + def get_serializer_class(self): + no_hyperlinks = self.request.QUERY_PARAMS.get('no_hyperlinks', False) + if (no_hyperlinks): + return self.id_serializer_class + else: + return self.serializer_class + def get_queryset(self): return {{ object.camel }}.select_by_user(self.request.user) @@ -76,6 +102,14 @@ class {{ object.camel }}List(generics.ListCreateAPIView): class {{ object.camel }}Detail(generics.RetrieveUpdateDestroyAPIView): queryset = {{ object.camel }}.objects.select_related().all() serializer_class = {{ object.camel }}Serializer + id_serializer_class = {{ object.camel }}IdSerializer + + def get_serializer_class(self): + no_hyperlinks = self.request.QUERY_PARAMS.get('no_hyperlinks', False) + if (no_hyperlinks): + return self.id_serializer_class + else: + return self.serializer_class def get_queryset(self): return {{ object.camel }}.select_by_user(self.request.user)