1 from django.http import Http404
2 from rest_framework.views import APIView
3 from rest_framework.response import Response
4 from rest_framework import status
6 from core.api.keys import add_key, delete_key, get_keys, update_key
7 from core.serializers import KeySerializer
8 from util.request import parse_request
11 class KeyListCreate(APIView):
13 List all users or create a new key.
16 def post(self, request, format = None):
17 data = parse_request(request.DATA)
18 if 'auth' not in data:
19 return Response(status=status.HTTP_400_BAD_REQUEST)
21 key = add_key(data['auth'], data['key'])
22 serializer = KeySerializer(key)
23 return Response(serializer.data, status=status.HTTP_201_CREATED)
25 keys = get_keys(data['auth'])
26 serializer = KeySerializer(keys, many=True)
27 return Response(serializer.data)
30 class KeyRetrieveUpdateDestroy(APIView):
32 Retrieve, update or delete a key
35 def post(self, request, pk, format=None):
37 data = parse_request(request.DATA)
38 if 'auth' not in data:
39 return Response(status=status.HTTP_400_BAD_REQUEST)
40 keys = get_keys(data['auth'], pk)
42 return Response(status=status.HTTP_404_NOT_FOUND)
43 serializer = KeySerializer(keys[0])
44 return Response(serializer.data)
46 def put(self, request, pk, format=None):
48 data = parse_request(request.DATA)
49 if 'auth' not in data:
50 return Response(status=status.HTTP_400_BAD_REQUEST)
51 elif 'key' not in data:
52 return Response(status=status.HTTP_400_BAD_REQUEST)
54 key = update_key(pk, data['key'])
55 serializer = KeySerializer(key)
56 return Response(serializer.data)
58 def delete(self, request, pk, format=None):
59 data = parse_request(request.DATA)
60 if 'auth' not in data:
61 return Response(status=status.HTTP_400_BAD_REQUEST)
62 delete_key(data['auth'], pk)
63 return Response(status=status.HTTP_204_NO_CONTENT)