EquipmentOTA.py 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. import os
  2. import simplejson as json
  3. import time
  4. from django.utils import timezone
  5. from django.utils.decorators import method_decorator
  6. from django.views.decorators.csrf import csrf_exempt
  7. from django.views.generic.base import View
  8. from Ansjer.config import BASE_DIR, SERVER_DOMAIN
  9. from Model.models import Equipment_Version
  10. from Object.ResponseObject import ResponseObject
  11. from Object.TokenObject import TokenObject
  12. from Service.CommonService import CommonService
  13. from Service.ModelService import ModelService
  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. response.lang = tko.lang
  37. if tko.code != 0:
  38. return response.json(tko.code)
  39. userID = tko.userID
  40. if userID is None:
  41. return response.json(309)
  42. operation = request_dict.get('operation', None)
  43. if operation == 'delete':
  44. return self.delete(request_dict, userID, response)
  45. elif operation == 'query':
  46. return self.query(request_dict, userID, response)
  47. elif operation == 'find':
  48. return self.find(request_dict, userID, response)
  49. elif operation == 'update':
  50. return self.update(request_dict, userID, response)
  51. else:
  52. return response.json(444, 'operation')
  53. def delete(self, request_dict, userID, response):
  54. eid = request_dict.get('eid', None)
  55. if not eid:
  56. return response.json(444, 'eid')
  57. own_perm = ModelService.check_perm(userID=userID, permID=230)
  58. if not own_perm:
  59. return response.json(404)
  60. ev = Equipment_Version.objects.filter(eid=eid)
  61. if not ev.exists():
  62. return response.json(173)
  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. ev.delete()
  71. except Exception as e:
  72. return response.json(176, repr(e))
  73. else:
  74. return response.json(0)
  75. def query(self, request_dict, userID, response):
  76. page = int(request_dict.get('page', None))
  77. line = int(request_dict.get('line', None))
  78. lang = request_dict.get('lang', None)
  79. if page is None or line is None:
  80. return response.json(444, 'page,line')
  81. own_permission = ModelService.check_perm(userID=userID, permID=240)
  82. if own_permission is not True:
  83. return response.json(404)
  84. if lang is None:
  85. qs = Equipment_Version.objects.all().order_by('-data_joined')
  86. else:
  87. qs = Equipment_Version.objects.filter(lang=lang).order_by('-data_joined')
  88. if qs.exists():
  89. count = qs.count()
  90. res = qs[(page - 1) * line:page * line]
  91. send_json = CommonService.qs_to_dict(res)
  92. send_json['count'] = count
  93. return response.json(0, send_json)
  94. return response.json(0)
  95. def find(self, request_dict, userID, response):
  96. page = int(request_dict.get('page', None))
  97. line = int(request_dict.get('line', None))
  98. content = request_dict.get('content', None)
  99. if page is None or line is None or content is None:
  100. return response.json(444)
  101. own_permission = ModelService.check_perm(userID=userID, permID=250)
  102. if own_permission is not True:
  103. return response.json(404)
  104. content = json.loads(content)
  105. search_kwargs = CommonService.get_kwargs(data=content)
  106. qs = Equipment_Version.objects.filter(**search_kwargs)
  107. if not qs.exists():
  108. return response.json(0, [])
  109. count = qs.count()
  110. res = qs[(page - 1) * line:page * line]
  111. send_json = CommonService.qs_to_dict(res)
  112. send_json['count'] = count
  113. return response.json(0, send_json)
  114. def update(self, request_dict, userID, response):
  115. eid = request_dict.get('eid', None)
  116. if eid is None:
  117. return response.json(444, 'eid')
  118. own_permission = ModelService.check_perm(userID=userID, permID=230)
  119. if own_permission is not True:
  120. return response.json(404)
  121. ev = Equipment_Version.objects.filter(eid=eid)
  122. if not ev.exists():
  123. return response.json(10, 'ev none')
  124. status = request_dict.get('status', None)
  125. try:
  126. update_time = timezone.localtime(timezone.now())
  127. ev.update(status=status, update_time=update_time)
  128. except Exception as e:
  129. print(repr(e))
  130. pass
  131. else:
  132. return response.json(0, {'update_time': str(update_time)})
  133. class EquipmentVersionView(View):
  134. def get(self, request, *args, **kwargs):
  135. request.encoding = 'utf-8'
  136. operation = kwargs.get('operation')
  137. return self.validation(request.GET, operation)
  138. def post(self, request, *args, **kwargs):
  139. request.encoding = 'utf-8'
  140. operation = kwargs.get('operation')
  141. return self.validation(request.POST, operation)
  142. def validation(self, request_dict, operation):
  143. response = ResponseObject()
  144. if operation is None:
  145. return response.json(444, 'error path')
  146. elif operation == 'checkVer':
  147. return self.do_check_ver(request_dict, response)
  148. token = request_dict.get('token', None)
  149. # 设备主键uid
  150. tko = TokenObject(token)
  151. response.lang = tko.lang
  152. if tko.code != 0:
  153. return response.json(tko.code)
  154. userID = tko.userID
  155. own_perm = ModelService.check_perm(userID, 240)
  156. if own_perm is False:
  157. return response.json(404)
  158. if operation == 'query':
  159. return self.do_query(request_dict, response)
  160. else:
  161. return response.json(444, 'error path')
  162. def do_check_ver(self, request_dict, response):
  163. code = request_dict.get('code', None)
  164. ov = request_dict.get('ov', None)
  165. uid = request_dict.get('uid', '')
  166. if not code:
  167. return response.json(444, 'code')
  168. eqs = Equipment_Version.objects.filter(code=uid, status=1, lang='en').order_by('-data_joined')
  169. if not eqs.exclude():
  170. eqs = Equipment_Version.objects.filter(code=code, status=1, lang='en').order_by('-data_joined')
  171. if not eqs.exists():
  172. return response.json(900)
  173. if ov is not None:
  174. # 判断大小
  175. if ov > eqs[0].softwareVersion:
  176. return response.json(0, {'softwareVersion': ov})
  177. file_path = eqs[0].filePath
  178. if file_path.find('static/Upgrade/') != -1:
  179. path = file_path.replace('static/Upgrade/', '').replace('\\', '/')
  180. url = SERVER_DOMAIN + 'OTA/downloads/' + path + '?time=' + str(time.time())
  181. elif file_path.find('static/otapack') != -1:
  182. url = SERVER_DOMAIN + 'OTA/downloadsPack/' + file_path + '?time=' + str(time.time())
  183. else:
  184. return response.json(900, '2')
  185. res = {
  186. "url": url,
  187. "fileSize": eqs[0].fileSize,
  188. "Description": eqs[0].Description,
  189. "softwareVersion": eqs[0].softwareVersion
  190. }
  191. return response.json(0, res)
  192. def do_query(self, request_dict, response):
  193. mci = request_dict.get('mci', None)
  194. page = request_dict.get('page', None)
  195. line = request_dict.get('line', None)
  196. code = request_dict.get('code', None)
  197. if not page or not line:
  198. return response.json(444, 'page,line')
  199. else:
  200. page = int(page)
  201. line = int(line)
  202. cv_qs = Equipment_Version.objects
  203. if mci is not None:
  204. cv_qs = cv_qs.filter(mci=mci)
  205. if code is not None:
  206. cv_qs = cv_qs.filter(code__contains=code)
  207. cv_qs = cv_qs.order_by('code').values_list('code', flat=True).distinct()
  208. count = cv_qs.count()
  209. cv_qs = list(cv_qs[(page - 1) * line:page * line])
  210. # return response.json(0, cv_qs)
  211. ev_qs = Equipment_Version.objects.filter(code__in=list(cv_qs)).values()
  212. ev_list = CommonService.qs_to_list(ev_qs)
  213. datas = {}
  214. # 组装数据
  215. for ev in ev_list:
  216. for code in cv_qs:
  217. if code not in datas.keys():
  218. datas[code] = []
  219. if code == ev['code']:
  220. datas[code].append(ev)
  221. res = {
  222. 'datas': datas,
  223. 'count': count
  224. }
  225. return response.json(0, res)