views.py 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. # coding=utf-8
  2. import requests
  3. from rest_framework.exceptions import NotFound
  4. from django.db import transaction
  5. from rest_framework.views import APIView
  6. from rest_framework import generics
  7. from rest_framework.decorators import action
  8. from django.db.models import Q
  9. from rest_framework_jwt.views import ObtainJSONWebToken,VerifyJSONWebToken,RefreshJSONWebToken
  10. from rest_framework.serializers import ValidationError
  11. from apps.WechatApplet.models import WechatApplet
  12. from utils import response_ok, response_error
  13. from apps.tenant.config.serializers import Config,ConfigSerializer
  14. from apps.tenant.option.serializers import OptionSerializer,Option
  15. from apps.tenant.area.serializers import AreaSerializer,Area
  16. from apps.tenant.building.models import Building
  17. from apps.tenant.notices.models import Notices
  18. from apps.tenant.notices.serializers import NoticesWXSerializer
  19. from apps.tenant.notices.filters import NoticesFilter
  20. from utils.permission import isLogin
  21. from utils.wx.WXBizDataCrypt import WXBizDataCrypt
  22. from apps.tenant.poster.serializer import PosterSerializer, Poster
  23. from apps.tenant.device.models import DeviceModel
  24. from apps.tenant.repair_order.models import RepairOrder
  25. from .serializers import *
  26. class CustomerRefreshTokenView(RefreshJSONWebToken):
  27. def post(self, request, *args, **kwargs):
  28. try:
  29. ser = self.serializer_class(data=request.data)
  30. if ser.is_valid(raise_exception=True):
  31. return response_ok({'token': ser.validated_data['token']})
  32. except ValidationError as e:
  33. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  34. class CustomerVerifyTokenView(VerifyJSONWebToken):
  35. def post(self, request, *args, **kwargs):
  36. try:
  37. ser = self.serializer_class(data=request.data)
  38. if ser.is_valid(raise_exception=True):
  39. return response_ok({'token': ser.validated_data['token']})
  40. except ValidationError as e:
  41. return response_error(u'登录状态失效,请重新登录[' + e.detail['error'][0] + ']')
  42. class SetUserInfoView(APIView):
  43. permission_classes = [isLogin, ]
  44. def post(self, request, *args, **kwargs):
  45. appid = request.POST.get('appid')
  46. openid = request.POST.get('openid')
  47. encryptedData = request.POST.get('encryptedData')
  48. iv = request.POST.get('iv')
  49. customer_wechat = CustomerWechat.objects.filter(openid=openid).first()
  50. if not customer_wechat:
  51. raise CustomError(u'未找到相应的微信客户!')
  52. employee = self.request.user.employee
  53. if customer_wechat.customer and customer_wechat.customer.id != employee.id:
  54. raise CustomError(u'该微信已同步其他客户!')
  55. if not customer_wechat.customer:
  56. customer_wechat.customer = employee
  57. customer_wechat.save()
  58. pc = WXBizDataCrypt(appid, customer_wechat.session_key)
  59. result = pc.decrypt(encryptedData, iv)
  60. with transaction.atomic():
  61. if employee.name == employee.tel:
  62. employee.name = result['nickName']
  63. employee.gender = result['gender']
  64. employee.face = result['avatarUrl']
  65. employee.save()
  66. customer_log(employee, BizLog.INSERT, u'客户设置信息,id=%d' % employee.id, result)
  67. return response_ok()
  68. class WxLoginView(APIView):
  69. serializer_class = WechatLoginSerializer
  70. def post(self, request, *args, **kwargs):
  71. ser = self.serializer_class(data=request.data)
  72. if ser.is_valid():
  73. return response_ok(ser.validated_data)
  74. else:
  75. return response_error('参数错误')
  76. class WxBindView(APIView):
  77. serializer_class = WechatBindSerializer
  78. def post(self, request, *args, **kwargs):
  79. ser = self.serializer_class(data=request.data)
  80. if ser.is_valid():
  81. return response_ok(ser.validated_data)
  82. else:
  83. return response_error('参数错误')
  84. class HomeStatisticsView(APIView):
  85. '''小程序首页统计数据'''
  86. def get(self, request):
  87. statistics = {
  88. 'total':0, #总报修
  89. 'wait':0, #待维修
  90. 'working':0, #维修中
  91. 'complete':0, #已完工
  92. }
  93. if request.user or request.user.is_authenticated:
  94. tenant = request.user.employee.tenant
  95. rows = RepairOrder.objects.filter(tenant=tenant)
  96. statistics['total'] = rows.filter(status__gte=RepairOrder.CHECKED).count()
  97. statistics['wait'] = rows.filter(status=RepairOrder.CHECKED).count()
  98. statistics['working'] = rows.filter(status=RepairOrder.DISPATCH).count()
  99. statistics['complete'] = rows.filter(status__in=[RepairOrder.FINISH,RepairOrder.APPRAISE,]).count()
  100. return response_ok(statistics)
  101. else:
  102. return response_ok(statistics)
  103. class StatisticsView(APIView):
  104. '''小程序统计数据'''
  105. def get(self, request):
  106. statistics = {
  107. 'total':0, #总报修
  108. 'wait':0, #待维修
  109. 'working':0, #维修中
  110. 'complete':0, #已完工
  111. }
  112. if request.user or request.user.is_authenticated:
  113. tenant = request.user.employee.tenant
  114. rows = RepairOrder.objects.filter(tenant=tenant)
  115. statistics['total'] = rows.filter(status__gte=RepairOrder.CHECKED).count()
  116. statistics['wait'] = rows.filter(status=RepairOrder.CHECKED).count()
  117. statistics['working'] = rows.filter(status=RepairOrder.DISPATCH).count()
  118. statistics['complete'] = rows.filter(status__in=[RepairOrder.FINISH,RepairOrder.APPRAISE,]).count()
  119. return response_ok(statistics)
  120. else:
  121. return response_ok(statistics)
  122. class PosterView(generics.ListAPIView):
  123. '''小程序首页数据'''
  124. queryset = Poster.objects.filter(enable=True)
  125. serializer_class = PosterSerializer
  126. def filter_queryset(self, queryset):
  127. is_auth = False
  128. if self.request.user and self.request.user.is_authenticated:
  129. is_auth = True
  130. queryset = queryset.filter(tenant__isnull=True)
  131. if is_auth:
  132. queryset = queryset.filter(Q(tenant__isnull=True) | Q(tenant=self.request.user.employee.tenant))
  133. return queryset
  134. def list(self, request, *args, **kwargs):
  135. try:
  136. data = super(PosterView, self).list(request)
  137. except NotFound:
  138. return response_ok([])
  139. return data
  140. class DictView(APIView):
  141. permission_classes = [isLogin, ]
  142. def get(self, request):
  143. tenant = request.user.employee.tenant
  144. ret = {
  145. 'repair_type': OptionSerializer(Option.objects.filter(delete=False,type=Option.REPAIRS_TYPE, enable=True, tenant=tenant), many=True).data,
  146. 'fault_cause': OptionSerializer(Option.objects.filter(delete=False,type=Option.FAULT_CAUSE, enable=True, tenant=tenant), many=True).data,
  147. }
  148. return response_ok(ret)
  149. class NoticesView(generics.ListAPIView):
  150. queryset = Notices.objects.filter()
  151. serializer_class = NoticesWXSerializer
  152. def filter_queryset(self, queryset):
  153. if self.request.user and self.request.user.is_authenticated:
  154. queryset = queryset.filter(tenant=self.request.user.employee.tenant)
  155. else:
  156. queryset = queryset.filter(tenant=0)
  157. f = NoticesFilter(self.request.GET, queryset=queryset)
  158. return f.qs
  159. class NoticesDetailView(generics.RetrieveAPIView):
  160. permission_classes = [isLogin, ]
  161. queryset = Notices.objects.filter()
  162. serializer_class = NoticesWXSerializer
  163. def get_queryset(self):
  164. queryset = self.queryset.filter(tenant=self.request.user.employee.tenant)
  165. return queryset
  166. def retrieve(self, request, *args, **kwargs):
  167. return response_ok(NoticesWXSerializer(self.get_object()).data)
  168. class DeviceView(APIView):
  169. permission_classes = [isLogin, ]
  170. def get(self, request):
  171. param = request.GET.get('param')
  172. data = []
  173. rows = DeviceModel.objects.filter(tenant=request.user.employee.tenant)
  174. if param:
  175. rows = rows.filter(Q(name=param) | Q(device_no=param) | Q(device_model=param))
  176. else:
  177. rows = rows[:10]
  178. for item in rows:
  179. build_dict = {
  180. 'id': item.id,
  181. 'name':item.name,
  182. 'device_no':item.device_no,
  183. 'device_model':item.device_model,
  184. 'branch':item.branch,
  185. 'address':item.address,
  186. }
  187. data.append(build_dict)
  188. return response_ok(data)