EquipmentOTA.py 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  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.ModelService import ModelService
  5. from Service.CommonService import CommonService
  6. from Model.models import Equipment_Version
  7. from django.utils import timezone
  8. import os,simplejson as json
  9. from Object.ResponseObject import ResponseObject
  10. from Object.TokenObject import TokenObject
  11. from Ansjer.settings import BASE_DIR
  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. response = ResponseObject()
  31. if token is not None:
  32. tko = TokenObject(token)
  33. tko.valid()
  34. response.lang = tko.lang
  35. if tko.code == 0:
  36. userID = tko.userID()
  37. if userID is not None:
  38. operation = request_dict.get('operation', None)
  39. if operation is not None:
  40. if operation == 'delete':
  41. return self.delete(request_dict, userID, response)
  42. elif operation == 'query':
  43. return self.query(request_dict, userID, response)
  44. elif operation == 'find':
  45. return self.find(request_dict, userID, response)
  46. elif operation == 'update':
  47. return self.update(request_dict, userID, response)
  48. return response.json(444, 'operation')
  49. else:
  50. return response.json(310)
  51. else:
  52. return response.json(tko.code)
  53. else:
  54. return response.json(311)
  55. def delete(self, request_dict, userID,response):
  56. eid = request_dict.get('eid', None)
  57. param_flag = CommonService.get_param_flag(data=[eid])
  58. if param_flag is True:
  59. own_permission = ModelService.check_permission(userID=userID, permID=230)
  60. if own_permission is True:
  61. ev = Equipment_Version.objects.filter(eid=eid)
  62. if ev.exists():
  63. try:
  64. has_ev = Equipment_Version.objects.filter(filePath=ev[0].filePath)
  65. if has_ev.exists():
  66. pass
  67. else:
  68. filepath = os.path.join(BASE_DIR, ev[0].filePath)
  69. os.remove(filepath)
  70. except Exception as e:
  71. pass
  72. ev.delete()
  73. return response.json(0)
  74. else:
  75. return response.json(404)
  76. return response.json(444)
  77. def query(self, request_dict, userID,response):
  78. page = int(request_dict.get('page', None))
  79. line = int(request_dict.get('line', None))
  80. param_flag = CommonService.get_param_flag(data=[page, line])
  81. if param_flag is True:
  82. own_permission = ModelService.check_permission(userID=userID, permID=240)
  83. if own_permission is True:
  84. equipment_version_queryset = Equipment_Version.objects.all().order_by('-data_joined')
  85. if equipment_version_queryset.exists():
  86. count = equipment_version_queryset.count()
  87. res = equipment_version_queryset[(page - 1) * line:page * line]
  88. send_json = CommonService.qs_to_dict(res)
  89. send_json['count'] = count
  90. return response.json(0, send_json)
  91. return response.json(0)
  92. else:
  93. return response.json(404)
  94. else:
  95. return response.json(444)
  96. def find(self, request_dict, userID,response):
  97. page = int(request_dict.get('page', None))
  98. line = int(request_dict.get('line', None))
  99. content = request_dict.get('content', None)
  100. param_flag = CommonService.get_param_flag(data=[page, line, content])
  101. if param_flag is True:
  102. own_permission = ModelService.check_permission(userID=userID, permID=250)
  103. if own_permission is True:
  104. content = json.loads(content)
  105. search_kwargs = CommonService.get_kwargs(data=content)
  106. equipment_version_queryset = Equipment_Version.objects.filter(**search_kwargs)
  107. if equipment_version_queryset.exists():
  108. count = equipment_version_queryset.count()
  109. res = equipment_version_queryset[(page - 1) * line:page * line]
  110. send_json = CommonService.qs_to_dict(res)
  111. send_json['count'] = count
  112. return response.json(0, send_json)
  113. else:
  114. return response.json(0)
  115. else:
  116. return response.json(404)
  117. else:
  118. return response.json(444)
  119. def update(self, request_dict, userID,response):
  120. eid = request_dict.get('eid', None)
  121. param_flag = CommonService.get_param_flag(data=[eid])
  122. if param_flag is True:
  123. own_permission = ModelService.check_permission(userID=userID, permID=230)
  124. if own_permission is True:
  125. ev = Equipment_Version.objects.filter(eid=eid)
  126. if ev.exists():
  127. status = request_dict.get('status', None)
  128. try:
  129. update_time = timezone.localtime(timezone.now())
  130. ev.update(status=status, update_time=update_time)
  131. except Exception as e:
  132. print(repr(e))
  133. pass
  134. return response.json(0, {'update_time': str(update_time)})
  135. else:
  136. return response.json(404)
  137. return response.json(444)