X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fapigen%2Fapi.template.py;h=de05fe6a405ca5a6383fd543fcd4825309c38e9e;hb=e3bbcf622e692f93fcc62ff7be7f49a206249b6c;hp=15995af7abf38384975ee4161ab1a85778c1e877;hpb=3bbf5ed2faffb4eb4b23df0ba659f1ab82a83549;p=plstackapi.git diff --git a/planetstack/apigen/api.template.py b/planetstack/apigen/api.template.py index 15995af..de05fe6 100644 --- a/planetstack/apigen/api.template.py +++ b/planetstack/apigen/api.template.py @@ -14,6 +14,7 @@ from django.forms import widgets plural: English plural of object name camel: CamelCase version of object name refs: list of references to other Model objects + props: list of properties minus refs TODO: Deal with subnets """ @@ -23,8 +24,7 @@ from django.forms import widgets @api_view(['GET']) def api_root(request, format=None): return Response({ - {% for object in generator.all %} - '{{ object.plural }}': reverse('{{ object }}-list', request=request, format=format), + {% for object in generator.all %}'{{ object.plural }}': reverse('{{ object }}-list', request=request, format=format), {% endfor %} }) @@ -35,11 +35,15 @@ def api_root(request, format=None): class {{ object.camel }}Serializer(serializers.HyperlinkedModelSerializer): id = serializers.Field() {% for ref in object.refs %} - sites = serializers.HyperlinkedRelatedField(view_name='{{ ref }}-detail') + {% if ref.multi %} + {{ ref.plural }} = serializers.HyperlinkedRelatedField(many=True, read_only=True, view_name='{{ ref }}-detail') + {% else %} + {{ ref }} = serializers.HyperlinkedRelatedField(many=True, read_only=True, view_name='{{ ref }}-detail') + {% endif %} {% endfor %} class Meta: model = {{ object }} - fields = ('id',{% for ref in object.refs %}'{{ ref }}',{% endfor %}) + fields = ({% for prop in object.props %}'{{ prop }}',{% endfor %}) {% endfor %} serializerLookUp = { @@ -53,11 +57,41 @@ serializerLookUp = { {% for object in generator.all %} class {{ object.camel }}List(generics.ListCreateAPIView): - queryset = {{ object.camel }}.objects.all() + queryset = {{ object.camel }}.objects.select_related.all() serializer_class = {{ object.camel }}Serializer + + def get_queryset(self): + return {{ object.camel }}.select_by_user(self.request.user) + + def create(self, request, *args, **kwargs): + #obj = {{ object.camel }}().update(request.DATA) + obj = self.get_object() + obj.caller = request.user + if obj.can_update(request.user): + return super({{ object.camel }}List, self).create(request, *args, **kwargs) + else: + return Response(status=status.HTTP_400_BAD_REQUEST) class {{ object.camel }}Detail(generics.RetrieveUpdateDestroyAPIView): - queryset = {{ object.camel }}.objects.all() + queryset = {{ object.camel }}.objects.select_related.all() serializer_class = {{ object.camel }}Serializer + + def get_queryset(self): + return {{ object.camel }}.select_by_user(self.request.user) + + def update(self, request, *args, **kwargs): + obj = self.get_object() + if obj.can_update(request.user): + return super({{ object.camel }}Detail, self).update(request, *args, **kwargs) + else: + return Response(status=status.HTTP_400_BAD_REQUEST) + + def destroy(self, request, *args, **kwargs): + obj = self.get_object() + if obj.can_update(request.user): + return super({{ object.camel }}Detail, self).destroy(request, *args, **kwargs) + else: + return Response(status=status.HTTP_400_BAD_REQUEST) + {% endfor %}