EquipmentOTA.py 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. from django.views.generic.base import View
  2. from django.utils.decorators import method_decorator
  3. from django.views.decorators.csrf import csrf_exempt
  4. from Service.TokenManager import JSONTokenManager
  5. from Service.ModelService import ModelService
  6. from Service.CommonService import CommonService
  7. from Model.models import Equipment_Version
  8. from Ansjer.config import *
  9. from django.utils import timezone
  10. import os
  11. from Service.ResponseService import *
  12. '''
  13. http://192.168.136.45:8077/equipment/OTA?token=test&operation=query&page=1&line=10
  14. http://192.168.136.45:8077/equipment/OTA?token=test&operation=find&page=1&line=10&content={}
  15. http://192.168.136.40:8077/equipment/OTA?eid=138001524641441203480138000&token=test&operation=delete
  16. http://192.168.136.40:8077/equipment/OTA?eid=138001524641441203480138000&token=test&operation=update&status=1
  17. '''
  18. class EquipmentOTA(View):
  19. @method_decorator(csrf_exempt)
  20. def dispatch(self, *args, **kwargs):
  21. return super(EquipmentOTA, self).dispatch(*args, **kwargs)
  22. def get(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. return self.validation(request_dict=request.GET)
  25. def post(self, request, *args, **kwargs):
  26. request.encoding = 'utf-8'
  27. return self.validation(request_dict=request.POST)
  28. def validation(self, request_dict, *args, **kwargs):
  29. token = request_dict.get('token', None)
  30. if token is not None:
  31. tokenManager = JSONTokenManager()
  32. error_code = tokenManager.verify_AToken(token)
  33. if error_code == 0:
  34. userID = tokenManager.accessDict.get('userID', None)
  35. operation = request_dict.get('operation', None)
  36. param_flag = CommonService.get_param_flag(data=[userID, operation])
  37. if param_flag is True:
  38. if operation == 'delete':
  39. return self.delete(request_dict=request_dict, userID=userID)
  40. elif operation == 'query':
  41. return self.query(request_dict=request_dict, userID=userID)
  42. elif operation == 'find':
  43. return self.find(request_dict=request_dict, userID=userID)
  44. elif operation == 'update':
  45. return self.update(request_dict=request_dict, userID=userID)
  46. return ResponseJSON(444)
  47. else:
  48. return HttpResponse(tokenManager.errorCodeInfo(error_code))
  49. else:
  50. return ResponseJSON(311)
  51. def delete(self, request_dict, userID):
  52. eid = request_dict.get('eid', None)
  53. param_flag = CommonService.get_param_flag(data=[eid])
  54. if param_flag is True:
  55. own_permission = ModelService.check_permission(userID=userID,permID=230)
  56. if own_permission is True:
  57. ev = Equipment_Version.objects.filter(eid=eid)
  58. if ev.exists():
  59. try:
  60. has_ev = EquipmentOTA.objects.filter(filePath = ev[0].filePath)
  61. if has_ev.exists():
  62. pass
  63. else:
  64. filepath = os.path.join(BASE_DIR,ev[0].filePath)
  65. os.remove(filepath)
  66. except Exception as e:
  67. pass
  68. ev.delete()
  69. return ResponseJSON(0)
  70. else:
  71. return ResponseJSON(404)
  72. return ResponseJSON(444)
  73. def query(self, request_dict,userID):
  74. page = int(request_dict.get('page', None))
  75. line = int(request_dict.get('line', None))
  76. param_flag = CommonService.get_param_flag(data=[page,line])
  77. if param_flag is True:
  78. own_permission = ModelService.check_permission(userID=userID, permID=240)
  79. if own_permission is True:
  80. equipment_version_queryset = Equipment_Version.objects.all().order_by('-data_joined')
  81. if equipment_version_queryset.exists():
  82. count = equipment_version_queryset.count()
  83. res = equipment_version_queryset[(page - 1) * line:page * line]
  84. send_json = CommonService.query_set_to_dict(res)
  85. send_json['count'] = count
  86. return ResponseJSON(0, send_json)
  87. else:
  88. return ResponseJSON(404)
  89. else:
  90. return ResponseJSON(444)
  91. def find(self, request_dict,userID):
  92. page = int(request_dict.get('page', None))
  93. line = int(request_dict.get('line', None))
  94. content = request_dict.get('content', None)
  95. param_flag = CommonService.get_param_flag(data=[page,line,content])
  96. if param_flag is True:
  97. own_permission = ModelService.check_permission(userID=userID, permID=250)
  98. if own_permission is True:
  99. content = json.loads(content)
  100. search_kwargs = CommonService.get_kwargs(data=content)
  101. equipment_version_queryset = Equipment_Version.objects.filter(**search_kwargs)
  102. if equipment_version_queryset.exists():
  103. count = equipment_version_queryset.count()
  104. res = equipment_version_queryset[(page - 1) * line:page * line]
  105. send_json = CommonService.query_set_to_dict(res)
  106. send_json['count'] = count
  107. return ResponseJSON(0, send_json)
  108. else:
  109. return ResponseJSON(0)
  110. else:
  111. return ResponseJSON(404)
  112. else:
  113. return ResponseJSON(444)
  114. def update(self,request_dict,userID):
  115. eid = request_dict.get('eid', None)
  116. param_flag = CommonService.get_param_flag(data=[eid])
  117. if param_flag is True:
  118. own_permission = ModelService.check_permission(userID=userID, permID=230)
  119. if own_permission is True:
  120. ev = Equipment_Version.objects.filter(eid=eid)
  121. if ev.exists():
  122. status = request_dict.get('status',None)
  123. try:
  124. update_time = timezone.localtime(timezone.now())
  125. ev.update(status=status,update_time=update_time)
  126. except Exception as e:
  127. print(repr(e))
  128. pass
  129. return ResponseJSON(0,{'update_time':str(update_time)})
  130. else:
  131. return ResponseJSON(404)
  132. return ResponseJSON(444)