views.py 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. from django.http import StreamingHttpResponse
  2. from rest_framework import viewsets
  3. from rest_framework.settings import api_settings
  4. from .files import FileRenderCN, FileRenderEN
  5. from .models import ListModel
  6. from . import serializers
  7. from utils.page import MyPageNumberPagination
  8. from rest_framework.filters import OrderingFilter
  9. from django_filters.rest_framework import DjangoFilterBackend
  10. from rest_framework.response import Response
  11. from .filter import Filter
  12. from rest_framework.exceptions import APIException
  13. from .serializers import FileRenderSerializer
  14. class APIViewSet(viewsets.ModelViewSet):
  15. """
  16. retrieve:
  17. Response a data list(get)
  18. list:
  19. Response a data list(all)
  20. create:
  21. Create a data line(post)
  22. delete:
  23. Delete a data line(delete)
  24. partial_update:
  25. Partial_update a data(patch:partial_update)
  26. update:
  27. Update a data(put:update)
  28. """
  29. pagination_class = MyPageNumberPagination
  30. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  31. ordering_fields = ['id', "create_time", "update_time", ]
  32. filter_class = Filter
  33. def get_project(self):
  34. try:
  35. id = self.kwargs.get('pk')
  36. return id
  37. except:
  38. return None
  39. def get_queryset(self):
  40. id = self.get_project()
  41. if self.request.user:
  42. if id is None:
  43. return ListModel.objects.filter(openid=self.request.auth.openid, is_delete=False)
  44. else:
  45. return ListModel.objects.filter(openid=self.request.auth.openid, id=id, is_delete=False)
  46. else:
  47. return ListModel.objects.none()
  48. def get_serializer_class(self):
  49. if self.action in ['list', 'retrieve', 'destroy']:
  50. return serializers.CustomerGetSerializer
  51. elif self.action in ['create']:
  52. return serializers.CustomerPostSerializer
  53. elif self.action in ['update']:
  54. return serializers.CustomerUpdateSerializer
  55. elif self.action in ['partial_update']:
  56. return serializers.CustomerPartialUpdateSerializer
  57. else:
  58. return self.http_method_not_allowed(request=self.request)
  59. def create(self, request, *args, **kwargs):
  60. data = self.request.data
  61. data['openid'] = self.request.auth.openid
  62. if ListModel.objects.filter(openid=data['openid'], customer_name=data['customer_name'], is_delete=False).exists():
  63. raise APIException({"detail": "Data exists"})
  64. else:
  65. serializer = self.get_serializer(data=data)
  66. serializer.is_valid(raise_exception=True)
  67. serializer.save()
  68. headers = self.get_success_headers(serializer.data)
  69. return Response(serializer.data, status=200, headers=headers)
  70. def update(self, request, pk):
  71. qs = self.get_object()
  72. if qs.openid != self.request.auth.openid:
  73. raise APIException({"detail": "Cannot update data which not yours"})
  74. else:
  75. data = self.request.data
  76. serializer = self.get_serializer(qs, data=data)
  77. serializer.is_valid(raise_exception=True)
  78. serializer.save()
  79. headers = self.get_success_headers(serializer.data)
  80. return Response(serializer.data, status=200, headers=headers)
  81. def partial_update(self, request, pk):
  82. qs = self.get_object()
  83. if qs.openid != self.request.auth.openid:
  84. raise APIException({"detail": "Cannot partial_update data which not yours"})
  85. else:
  86. data = self.request.data
  87. serializer = self.get_serializer(qs, data=data, partial=True)
  88. serializer.is_valid(raise_exception=True)
  89. serializer.save()
  90. headers = self.get_success_headers(serializer.data)
  91. return Response(serializer.data, status=200, headers=headers)
  92. def destroy(self, request, pk):
  93. qs = self.get_object()
  94. if qs.openid != self.request.auth.openid:
  95. raise APIException({"detail": "Cannot delete data which not yours"})
  96. else:
  97. qs.is_delete = True
  98. qs.save()
  99. serializer = self.get_serializer(qs, many=False)
  100. headers = self.get_success_headers(serializer.data)
  101. return Response(serializer.data, status=200, headers=headers)
  102. class FileDownloadView(viewsets.ModelViewSet):
  103. renderer_classes = (FileRenderCN, ) + tuple(api_settings.DEFAULT_RENDERER_CLASSES)
  104. filter_backends = [DjangoFilterBackend, OrderingFilter, ]
  105. ordering_fields = ['id', "create_time", "update_time", ]
  106. filter_class = Filter
  107. def get_project(self):
  108. try:
  109. id = self.kwargs.get('pk')
  110. return id
  111. except:
  112. return None
  113. def get_queryset(self):
  114. id = self.get_project()
  115. if self.request.user:
  116. if id is None:
  117. return ListModel.objects.filter(openid=self.request.auth.openid, is_delete=False)
  118. else:
  119. return ListModel.objects.filter(openid=self.request.auth.openid, id=id, is_delete=False)
  120. else:
  121. return ListModel.objects.none()
  122. def get_serializer_class(self):
  123. if self.action in ['list']:
  124. return serializers.FileRenderSerializer
  125. else:
  126. return self.http_method_not_allowed(request=self.request)
  127. def get_lang(self, data):
  128. lang = self.request.META.get('HTTP_LANGUAGE')
  129. if lang:
  130. if lang == 'zh-hans':
  131. return FileRenderCN().render(data)
  132. else:
  133. return FileRenderEN().render(data)
  134. else:
  135. return FileRenderEN().render(data)
  136. def list(self, request, *args, **kwargs):
  137. from datetime import datetime
  138. dt = datetime.now()
  139. data = (
  140. FileRenderSerializer(instance).data
  141. for instance in self.filter_queryset(self.get_queryset())
  142. )
  143. renderer = self.get_lang(data)
  144. response = StreamingHttpResponse(
  145. renderer,
  146. content_type="text/csv"
  147. )
  148. response['Content-Disposition'] = "attachment; filename='customer_{}.csv'".format(str(dt.strftime('%Y%m%d%H%M%S%f')))
  149. return response