EquipmentOTA.py 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  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. param_flag = CommonService.get_param_flag(data=[eid])
  56. if param_flag is True:
  57. own_permission = ModelService.check_perm(userID=userID, permID=230)
  58. if own_permission is True:
  59. ev = Equipment_Version.objects.filter(eid=eid)
  60. if ev.exists():
  61. try:
  62. has_ev = Equipment_Version.objects.filter(filePath=ev[0].filePath)
  63. if has_ev.exists():
  64. pass
  65. else:
  66. filepath = os.path.join(BASE_DIR, ev[0].filePath)
  67. os.remove(filepath)
  68. except Exception as e:
  69. pass
  70. ev.delete()
  71. return response.json(0)
  72. else:
  73. return response.json(404)
  74. return response.json(444)
  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, 30)
  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. res = {
  184. "url": url,
  185. "fileSize": eqs[0].fileSize,
  186. "Description": eqs[0].Description,
  187. "softwareVersion": eqs[0].softwareVersion
  188. }
  189. return response.json(0, res)
  190. def do_query(self, request_dict, response):
  191. mci = request_dict.get('mci', None)
  192. page = request_dict.get('page', None)
  193. line = request_dict.get('line', None)
  194. if not page or not line:
  195. return response.json(444, 'page,line')
  196. else:
  197. page = int(page)
  198. line = int(line)
  199. if mci is not None:
  200. cv_qs = Equipment_Version.objects.filter(mci=mci).order_by('code').values_list('code', flat=True).distinct()
  201. count = cv_qs.count()
  202. cv_qs = list(cv_qs[(page - 1) * line:page * line])
  203. else:
  204. cv_qs = Equipment_Version.objects.order_by('code').values_list('code', flat=True).distinct()
  205. count = cv_qs.count()
  206. cv_qs = list(cv_qs[(page - 1) * line:page * line])
  207. # return response.json(0, cv_qs)
  208. ev_qs = Equipment_Version.objects.filter(code__in=list(cv_qs)).values()
  209. ev_list = CommonService.qs_to_list(ev_qs)
  210. datas = {}
  211. # 组装数据
  212. for ev in ev_list:
  213. for code in cv_qs:
  214. if code not in datas.keys():
  215. datas[code] = []
  216. if code == ev['code']:
  217. datas[code].append(ev)
  218. res = {
  219. 'datas': datas,
  220. 'count': count
  221. }
  222. return response.json(0, res)
  223. # def do_query(self, request_dict, response):
  224. # mci = request_dict.get('mci', None)
  225. # page = request_dict.get('page', None)
  226. # line = request_dict.get('line', None)
  227. # if not page or not line:
  228. # return response.json(444, 'page,line')
  229. # else:
  230. # page = int(page)
  231. # line = int(line)
  232. # datas = {}
  233. # if mci is not None:
  234. # cv_qs = Equipment_Version.objects.order_by('code').filter(mci=mci).values('code', 'lang').distinct()
  235. # count = cv_qs.count()
  236. # cv_qs = cv_qs[(page - 1) * line:page * line]
  237. # code_list = []
  238. # for cv in cv_qs:
  239. # code_list.append(cv['code'])
  240. # ev_qs = Equipment_Version.objects.filter(code__in=code_list).values()
  241. # datas = {}
  242. # # 组装数据
  243. # for ev in ev_qs:
  244. # for code in cv_qs:
  245. # if code not in datas.keys():
  246. # datas[code] = []
  247. # if code == ev['code']:
  248. # datas[code].append(ev)
  249. # for cv in cv_qs:
  250. # ev_qs = Equipment_Version.objects.filter(code=cv['code'], lang=cv['lang'])
  251. # if cv['code'] not in datas.keys():
  252. # datas[cv['code']] = []
  253. # else:
  254. # ev_qs
  255. # if code not in datas.keys():
  256. # datas[code] = []
  257. # if code == ev['code']:
  258. # datas[code].append(ev)
  259. # else:
  260. # pass
  261. # # return response.json(0, cv_qs)
  262. # ev_qs = Equipment_Version.objects.filter(code__in=list(cv_qs)).values()
  263. # ev_list = CommonService.qs_to_list(ev_qs)
  264. # datas = {}
  265. # # 组装数据
  266. #
  267. # res = {
  268. # 'datas': datas,
  269. # 'count': count
  270. # }
  271. # return response.json(0, res)