EquipmentOTA.py 5.8 KB

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