PcInfo.py 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730
  1. import hashlib
  2. import logging
  3. import shutil
  4. import time
  5. import traceback
  6. import os
  7. from urllib import request, parse
  8. import requests
  9. from boto3 import Session
  10. from django.http import HttpResponse
  11. from django.views.generic.base import View
  12. from Controller.PctestController import TokenObject1
  13. from Model.models import Pc_Info, PctestlogModel, AVSSVersion
  14. from Object.ResponseObject import ResponseObject
  15. from Object.TokenObject import TokenObject
  16. from Service.CommonService import CommonService
  17. from Ansjer.config import AWS_ARN, BASE_DIR
  18. import boto3
  19. import botocore
  20. from botocore import client
  21. from wsgiref.util import FileWrapper
  22. from zlib import crc32
  23. from typing import Union
  24. from django.conf import settings
  25. AWS_ACCESS_KEY_ID = settings.AWS_ACCESS_KEY_ID
  26. AWS_SECRET_ACCESS_KEY = settings.AWS_SECRET_ACCESS_KEY
  27. class PcInfo(View):
  28. def dispatch(self, requset, *args, **kwargs):
  29. return super(PcInfo, self).dispatch(requset, *args, **kwargs)
  30. def get(self, request, *args, **kwargs):
  31. operation = kwargs.get('operation')
  32. request.encoding = 'utf-8'
  33. return self.validation(request.GET, request, operation)
  34. def post(self, request, *args, **kwargs):
  35. operation = kwargs.get('operation')
  36. request.encoding = 'utf-8'
  37. return self.validation(request.POST, request, operation)
  38. def validation(self, request_dict, request, operation):
  39. response = ResponseObject()
  40. if not operation:
  41. return response.json(444, 'operation')
  42. else:
  43. if operation == 'query': # pc端调用查询
  44. return self.query(request_dict, response)
  45. elif operation == 's3addandupload':
  46. return self.s3addandupload(request_dict, response, request)
  47. elif operation == 's3addanduploadlog': #上传日志文件
  48. return self.s3addanduploadlog(request_dict, response, request)
  49. elif operation == 's3download':
  50. return self.s3download(request_dict, response)
  51. elif operation == 's3downloadlog': #下载日志文件
  52. return self.s3downloadlog(request_dict, response)
  53. elif operation == 's3delete':
  54. return self.s3delete(request_dict, response)
  55. elif operation == 'edit':
  56. return self.edit(request_dict, response)
  57. elif operation == 'getnewversion': # 获取当前软件的最新版本
  58. return self.getnewversion(request_dict, response)
  59. elif operation == 'getnewversionV2': # 获取当前软件的最新版本
  60. return self.getnewversionV2(request_dict, response)
  61. elif operation == 'queryall': # 后台查询
  62. return self.queryall(request_dict, response)
  63. elif operation == 'addandupload': # 上传到服务器
  64. return self.addandupload(request_dict, response, request)
  65. elif operation == 'download': # 服务器下载
  66. return self.download(request_dict, response)
  67. elif operation == 'delete':
  68. return self.delete(request_dict, response)
  69. elif operation == 'AVSS/check-version':
  70. return self.check_version(request_dict, response)
  71. else:
  72. return response.json(414)
  73. def getnewversion(self, request_dict, response):
  74. pc_name = request_dict.get('pc_name', None)
  75. bundle_version = request_dict.get('bundle_version', None)
  76. pc_version = request_dict.get('pc_version', None)
  77. pc_test = request_dict.get('pc_test', None)
  78. param_flag = CommonService.get_param_flag(
  79. data=[pc_name, bundle_version, pc_version, pc_test])
  80. if param_flag is not True:
  81. return response.json(444)
  82. file = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_test=pc_test)
  83. if not file:
  84. return response.json(173)
  85. app_list = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_test=pc_test)
  86. all_version = app_list.values('pc_version')
  87. v = []
  88. for i in all_version:
  89. v.append(i['pc_version'])
  90. new_version = max(v)
  91. if pc_version == new_version:
  92. return response.json(10045)
  93. else:
  94. path = app_list.filter(pc_version=new_version).values('download_link')[0]['download_link']
  95. print('path', path)
  96. aws_s3_guonei = boto3.client(
  97. 's3',
  98. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  99. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  100. config=botocore.client.Config(signature_version='s3v4'),
  101. region_name='cn-northwest-1')
  102. response_url = aws_s3_guonei.generate_presigned_url(
  103. ClientMethod='get_object',
  104. Params={'Bucket': 'pc-package', 'Key': path}, ExpiresIn=3600)
  105. res = {'pc_name': pc_name,
  106. 'new_version': new_version,
  107. 'path': path,
  108. 'response_url': response_url}
  109. return response.json(0, res)
  110. def getnewversionV2(self, request_dict, response):
  111. pc_name = request_dict.get('pc_name', None)
  112. bundle_version = request_dict.get('bundle_version', None)
  113. pc_version = request_dict.get('pc_version', None)
  114. pc_test = request_dict.get('pc_test', None)
  115. param_flag = CommonService.get_param_flag(
  116. data=[pc_name, bundle_version, pc_version, pc_test])
  117. if param_flag is not True:
  118. return response.json(444)
  119. file = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_test=pc_test)
  120. if not file.exists():
  121. return response.json(173)
  122. aws_s3_guonei = boto3.client(
  123. 's3',
  124. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  125. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  126. config=botocore.client.Config(signature_version='s3v4'),
  127. region_name='cn-northwest-1')
  128. version_list = []
  129. for i in range(2):
  130. if pc_test == '1': # 测试版返回所有版本中的最新版本
  131. app_list = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, is_update=i)
  132. else:
  133. app_list = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_test=pc_test, is_update=i)
  134. # 当前软件不存在强制更新(is_update=1)的版本返回空
  135. if not app_list.exists():
  136. res = {'pc_name': '',
  137. 'new_version': '',
  138. 'is_update': i,
  139. 'explain': '',
  140. 'path': '',
  141. 'response_url': ''}
  142. version_list.append(res)
  143. continue
  144. all_version = app_list.values('pc_version')
  145. v = []
  146. for i in all_version:
  147. v.append(i['pc_version'])
  148. new_version = max(v)
  149. # 当前软件版本为最新时返回空
  150. if pc_version >= new_version:
  151. res = {'pc_name': '',
  152. 'new_version': '',
  153. 'is_update': app_list.filter(pc_version=new_version).values('is_update')[0]['is_update'],
  154. 'explain': '',
  155. 'path': '',
  156. 'response_url': ''}
  157. version_list.append(res)
  158. continue
  159. path = app_list.filter(pc_version=new_version).values('download_link')[0]['download_link']
  160. print('path', path)
  161. response_url = aws_s3_guonei.generate_presigned_url(
  162. ClientMethod='get_object',
  163. Params={'Bucket': 'pc-package', 'Key': path}, ExpiresIn=3600)
  164. res = {'pc_name': pc_name,
  165. 'new_version': new_version,
  166. 'is_update': app_list.filter(pc_version=new_version).values('is_update')[0]['is_update'],
  167. 'explain': app_list.filter(pc_version=new_version).values('explain')[0]['explain'],
  168. 'path': path,
  169. 'response_url': response_url}
  170. version_list.append(res)
  171. return response.json(0, version_list)
  172. def query(self, request_dict, response):
  173. pc_name = request_dict.get('pc_name', None)
  174. bundle_version = request_dict.get('bundle_version', None)
  175. pc_version = request_dict.get('pc_version', None)
  176. pc_test = request_dict.get('pc_test', None)
  177. package = request_dict.get('package', None)
  178. file_type = request_dict.get('file_type', None)
  179. # 根据传的参数筛选,没传时返回全部
  180. queryset = Pc_Info.objects.all()
  181. if package:
  182. queryset = Pc_Info.objects.filter(package=package)
  183. if file_type:
  184. queryset = Pc_Info.objects.filter(file_type=file_type)
  185. if pc_name and file_type:
  186. queryset = Pc_Info.objects.filter(pc_name=pc_name, file_type=file_type)
  187. if file_type and package:
  188. queryset = Pc_Info.objects.filter(file_type=file_type, package=package)
  189. if pc_name and bundle_version and pc_version and pc_test:
  190. queryset = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_version=pc_version, pc_test=pc_test)
  191. count = queryset.count()
  192. res = queryset
  193. send_json = CommonService.qs_to_dict(res)
  194. send_json['count'] = count
  195. return response.json(0, send_json)
  196. def s3addandupload(self, request_dict, response, request):
  197. logger = logging.getLogger('info')
  198. logger.info('s3方式上传参数:')
  199. logger.info(request_dict)
  200. token = request_dict.get('token', None)
  201. tko = TokenObject(token)
  202. response.lang = tko.lang
  203. pc_name = request_dict.get('pc_name', None)
  204. bundle_version = request_dict.get('bundle_version', None)
  205. pc_version = request_dict.get('pc_version', None)
  206. pc_test = request_dict.get('pc_test', None)
  207. lang = request_dict.get('lang', None)
  208. file_name = request_dict.get('file_name', None)
  209. file_type = request_dict.get('file_type', None)
  210. package = request_dict.get('package', None)
  211. explain = request_dict.get('explain', '')
  212. content = request_dict.get('content', '')
  213. authority = request_dict.get('authority', '')
  214. is_update = request_dict.get('is_update', None)
  215. is_open = request_dict.get('is_open', None)
  216. # logger.info('文件名字:')
  217. # logger.info(file_name)
  218. param_flag = CommonService.get_param_flag(
  219. data=[pc_name, bundle_version, pc_version, pc_test, lang, file_name, file_type, package, is_update, is_open])
  220. if param_flag is not True:
  221. return response.json(444)
  222. else:
  223. file = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version,
  224. pc_version=pc_version, pc_test=pc_test)
  225. if file:
  226. return response.json(174)
  227. try:
  228. logger.info('开始上传')
  229. # 把安装包上传到s3
  230. aws_s3_guonei = boto3.client(
  231. 's3',
  232. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  233. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  234. config=botocore.client.Config(signature_version='s3v4'),
  235. region_name='cn-northwest-1'
  236. )
  237. download_link = '{pc_name}/{pc_version}_{bundle_version}_{pc_test}_{file_name}'.format(
  238. pc_name=pc_name, pc_version=pc_version, bundle_version=bundle_version,
  239. pc_test=pc_test, file_name=file_name)
  240. response_url = aws_s3_guonei.generate_presigned_url(
  241. ClientMethod='put_object',
  242. Params={
  243. 'Bucket': 'pc-package',
  244. 'Key': download_link
  245. },
  246. ExpiresIn=3600
  247. )
  248. # 通过上传签名url对文件进行上传
  249. # requests.put(response_url, data=file_name)
  250. # logger.info('上传完成')
  251. add_time = time.time()
  252. create_dict = {
  253. 'pc_name': pc_name,
  254. 'bundle_version': bundle_version,
  255. 'pc_version': pc_version,
  256. 'pc_test': pc_test,
  257. 'lang': lang,
  258. 'download_link': download_link,
  259. 'add_time': add_time,
  260. 'update_time': add_time,
  261. 'file_type': file_type,
  262. 'package': package,
  263. 'explain': explain,
  264. 'content': content,
  265. 'authority': authority,
  266. 'is_update': is_update,
  267. 'is_open': is_open
  268. }
  269. pc_Info = Pc_Info(**create_dict)
  270. pc_Info.save()
  271. except Exception:
  272. errorInfo = traceback.format_exc()
  273. print(errorInfo)
  274. return response.json(500, {'details': errorInfo})
  275. else:
  276. if pc_Info.id:
  277. res = {'id': pc_Info.id,
  278. 'pc_name': pc_Info.pc_name,
  279. 'bundle_version': pc_Info.bundle_version,
  280. 'pc_version': pc_Info.pc_version,
  281. 'pc_test': pc_Info.pc_test,
  282. 'download_link': pc_Info.download_link,
  283. 'lang': pc_Info.lang,
  284. 'add_time': pc_Info.add_time,
  285. 'update_time': pc_Info.update_time,
  286. 'file_type': pc_Info.file_type,
  287. 'package': pc_Info.package,
  288. 'explain': pc_Info.explain,
  289. 'content': pc_Info.content,
  290. 'authority': pc_Info.authority,
  291. 'is_update': pc_Info.is_update,
  292. 'is_open': pc_Info.is_open,
  293. 'upload_url': response_url
  294. }
  295. return response.json(0, res)
  296. else:
  297. return response.json(500)
  298. def s3addanduploadlog(self, request_dict, response, request):
  299. logger = logging.getLogger('info')
  300. logger.info('s3方式上传参数:')
  301. logger.info(request_dict)
  302. token = request_dict.get('token', None)
  303. tko = TokenObject1(token)
  304. response.lang = tko.lang
  305. if tko.code != 0:
  306. return response.json(tko.code)
  307. # 获取访问者的id和岗位
  308. userID = tko.id
  309. datetime = request_dict.get('datetime', None)
  310. file_name = request_dict.get('file_name', None)
  311. pathtype = request_dict.get('pathtype', 'log')
  312. # logger.info('文件名字:')
  313. # logger.info(file_name)
  314. param_flag = CommonService.get_param_flag(
  315. data=[datetime, file_name, pathtype])
  316. if param_flag is not True:
  317. return response.json(444)
  318. logger.info('开始上传')
  319. # 把安装包上传到s3
  320. aws_s3_guonei = boto3.client(
  321. 's3',
  322. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  323. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  324. config=botocore.client.Config(signature_version='s3v4'),
  325. region_name='cn-northwest-1'
  326. )
  327. download_link = '{pathtype}/{datetime}/{file_name}'.format(
  328. pathtype=pathtype, datetime=datetime, file_name=file_name)
  329. response_url = aws_s3_guonei.generate_presigned_url(
  330. ClientMethod='put_object',
  331. Params={
  332. 'Bucket': 'pc-package',
  333. 'Key': download_link
  334. },
  335. ExpiresIn=3600
  336. )
  337. add_time = time.time()
  338. PctestlogModel.objects.create(user_id=userID, content=download_link, addtime=add_time)
  339. return response.json(0, {'upload_url': response_url, 'datetime': datetime})
  340. def s3download(self, request_dict, response):
  341. pc_name = request_dict.get('pc_name', None)
  342. bundle_version = request_dict.get('bundle_version', None)
  343. pc_version = request_dict.get('pc_version', None)
  344. pc_test = request_dict.get('pc_test', None)
  345. param_flag = CommonService.get_param_flag(
  346. data=[pc_name, bundle_version, pc_version, pc_test])
  347. if param_flag is not True:
  348. return response.json(444)
  349. path = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_version=pc_version,
  350. pc_test=pc_test).values('download_link')
  351. if not path:
  352. return response.json(173)
  353. path = path[0]['download_link']
  354. aws_s3_guonei = boto3.client(
  355. 's3',
  356. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  357. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  358. config=botocore.client.Config(signature_version='s3v4'),
  359. region_name='cn-northwest-1'
  360. )
  361. response_url = aws_s3_guonei.generate_presigned_url(
  362. ClientMethod='get_object',
  363. Params={
  364. 'Bucket': 'pc-package',
  365. 'Key': path
  366. },
  367. ExpiresIn=3600
  368. )
  369. res = {'path': path,
  370. 'response_url': response_url
  371. }
  372. return response.json(0, res)
  373. def s3downloadlog(self, request_dict, response):
  374. id = request_dict.get('id', None)
  375. pclog_qs = PctestlogModel.objects.filter(id=id)
  376. if not pclog_qs:
  377. return response.json(173)
  378. path = pclog_qs[0].content
  379. aws_s3_guonei = boto3.client(
  380. 's3',
  381. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  382. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  383. config=botocore.client.Config(signature_version='s3v4'),
  384. region_name='cn-northwest-1'
  385. )
  386. response_url = aws_s3_guonei.generate_presigned_url(
  387. ClientMethod='get_object',
  388. Params={
  389. 'Bucket': 'pc-package',
  390. 'Key': path
  391. },
  392. ExpiresIn=3600
  393. )
  394. res = {'path': path,
  395. 'response_url': response_url
  396. }
  397. return response.json(0, res)
  398. def edit(self, request_dict, response):
  399. id = request_dict.get('id', None)
  400. explain = request_dict.get('explain', None)
  401. content = request_dict.get('content', None)
  402. authority = request_dict.get('authority', None)
  403. is_open = request_dict.get('is_open', None)
  404. param_flag = CommonService.get_param_flag(
  405. data=[id, explain, is_open])
  406. if param_flag is not True:
  407. return response.json(444)
  408. file = Pc_Info.objects.filter(id=id)
  409. if not file.exists():
  410. return response.json(173)
  411. file.update(explain=explain, content=content, authority=authority, is_open=is_open)
  412. return response.json(0)
  413. def s3delete(self, request_dict, response):
  414. global file
  415. token = request_dict.get('token', None)
  416. tko = TokenObject(token)
  417. response.lang = tko.lang
  418. if tko.code != 0:
  419. return response.json(tko.code)
  420. userID = tko.userID
  421. if not userID:
  422. return response.json(104)
  423. id = request_dict.get('id', None)
  424. package = request_dict.get('package', None)
  425. if id and package:
  426. return response.json(444)
  427. elif id and package is None:
  428. file = Pc_Info.objects.filter(id=id)
  429. elif package and id is None:
  430. try:
  431. package = int(package)
  432. file = Pc_Info.objects.filter(package=package)
  433. except Exception as e:
  434. return response.json(176)
  435. if not file.exists():
  436. return response.json(173)
  437. try:
  438. # 删除s3和数据库里的相应数据
  439. file_path = file[0].download_link
  440. aws_s3_guonei = boto3.client(
  441. 's3',
  442. aws_access_key_id=AWS_ACCESS_KEY_ID[0],
  443. aws_secret_access_key=AWS_SECRET_ACCESS_KEY[0],
  444. config=botocore.client.Config(signature_version='s3v4'),
  445. region_name='cn-northwest-1'
  446. )
  447. try:
  448. # 获取存储桶的对象,判断对象是否上传成功
  449. obj = aws_s3_guonei.get_object(Bucket='pc-package', Key=file_path)
  450. except Exception as e:
  451. print(e)
  452. file.delete()
  453. else:
  454. if obj:
  455. aws_s3_guonei.delete_object(Bucket='pc-package', Key=file_path)
  456. file.delete()
  457. except Exception as e:
  458. return response.json(176, repr(e))
  459. else:
  460. return response.json(0)
  461. def queryall(self, request_dict, response):
  462. token = request_dict.get('token', None)
  463. tko = TokenObject(token)
  464. response.lang = tko.lang
  465. if tko.code != 0:
  466. return response.json(tko.code)
  467. userID = tko.userID
  468. if not userID:
  469. return response.json(104)
  470. page = int(request_dict.get('page', None))
  471. line = int(request_dict.get('line', None))
  472. if page is None or line is None:
  473. return response.json(444, 'page,line')
  474. queryset = Pc_Info.objects.all()
  475. if queryset.exists():
  476. count = queryset.count()
  477. res = queryset[(page - 1) * line:page * line]
  478. send_json = CommonService.qs_to_dict(res)
  479. send_json['count'] = count
  480. return response.json(0, send_json)
  481. else:
  482. return response.json(173)
  483. def addandupload(self, request_dict, response, request):
  484. token = request_dict.get('token', None)
  485. tko = TokenObject(token)
  486. response.lang = tko.lang
  487. if tko.code != 0:
  488. return response.json(tko.code)
  489. userID = tko.userID
  490. if not userID:
  491. return response.json(104)
  492. pc_name = request_dict.get('pc_name', None)
  493. bundle_version = request_dict.get('bundle_version', None)
  494. pc_version = request_dict.get('pc_version', None)
  495. pc_test = request_dict.get('pc_test', None)
  496. lang = request_dict.get('lang', None)
  497. file_name = request.FILES.get('file_name', None)
  498. param_flag = CommonService.get_param_flag(
  499. data=[pc_name, bundle_version, pc_version, pc_test, lang, file_name])
  500. if param_flag is not True:
  501. return response.json(444)
  502. else:
  503. file = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version,
  504. pc_version=pc_version, pc_test=pc_test)
  505. if file:
  506. return response.json(174)
  507. try:
  508. # 安装包上传到服务器本地
  509. file_path = 'static/pc/' + pc_name
  510. if not os.path.exists(file_path):
  511. os.makedirs(os.path.join(BASE_DIR, file_path))
  512. a = os.path.splitext(str(file_name))[-1]
  513. if not a:
  514. return response.json(444, "文件无后缀")
  515. name = pc_version + '_' + bundle_version + '_' + pc_test + str(a)
  516. file_path = file_path + '/' + str(name)
  517. upload_path = os.path.join(BASE_DIR, file_path)
  518. print('upload_path:', upload_path)
  519. with open(upload_path, 'wb+') as destination:
  520. for chunk in file_name.chunks():
  521. destination.write(chunk)
  522. add_time = time.time()
  523. create_dict = {
  524. 'pc_name': pc_name,
  525. 'bundle_version': bundle_version,
  526. 'pc_version': pc_version,
  527. 'pc_test': pc_test,
  528. 'lang': lang,
  529. 'download_link': file_path,
  530. 'add_time': add_time,
  531. 'update_time': add_time
  532. }
  533. pc_Info = Pc_Info(**create_dict)
  534. pc_Info.save()
  535. except Exception:
  536. errorInfo = traceback.format_exc()
  537. print(errorInfo)
  538. return response.json(700, {'details': errorInfo})
  539. else:
  540. if pc_Info.id:
  541. res = {'pc_name': pc_Info.pc_name,
  542. 'bundle_version': pc_Info.bundle_version,
  543. 'pc_version': pc_Info.pc_version,
  544. 'pc_test': pc_Info.pc_test,
  545. 'download_link': pc_Info.download_link,
  546. 'lang': pc_Info.lang,
  547. 'add_time': pc_Info.add_time,
  548. 'update_time': pc_Info.update_time
  549. }
  550. return response.json(0, res)
  551. else:
  552. return response.json(500)
  553. def download(self, request_dict, response):
  554. pc_name = request_dict.get('pc_name', None)
  555. bundle_version = request_dict.get('bundle_version', None)
  556. pc_version = request_dict.get('pc_version', None)
  557. pc_test = request_dict.get('pc_test', None)
  558. param_flag = CommonService.get_param_flag(
  559. data=[pc_name, bundle_version, pc_version, pc_test])
  560. if param_flag is not True:
  561. return response.json(444)
  562. path = Pc_Info.objects.filter(pc_name=pc_name, bundle_version=bundle_version, pc_version=pc_version,
  563. pc_test=pc_test).values('download_link')
  564. if not path:
  565. return response.json(173)
  566. filepath = path[0]['download_link']
  567. fullPath = os.path.join(BASE_DIR, filepath)
  568. fullPath.replace('\\', '/')
  569. res = ResponseObject()
  570. print('fullPath:')
  571. print(fullPath)
  572. print(os.path.basename(fullPath))
  573. if fullPath:
  574. if os.path.isfile(fullPath):
  575. try:
  576. wrapper = FileWrapper(open(fullPath, 'rb'))
  577. response = HttpResponse(wrapper, content_type="application/octet-stream")
  578. response['Content-Length'] = os.path.getsize(fullPath)
  579. response['Content-Disposition'] = 'attachment; filename={}'.format(parse.quote_plus(os.path.basename(fullPath), encoding="utf-8"))
  580. response['Content-MD5'] = getMD5orSHA265(fullPath)
  581. # 校验文件md5值
  582. response['Content-SHA265'] = getMD5orSHA265(fullPath, 'SHA265')
  583. response['Content-CRC32'] = getMD5orSHA265(fullPath, 'CRC32')
  584. response['Content-Error'] = res.formal(0)
  585. return response
  586. except Exception as e:
  587. return res.json(906, repr(e))
  588. else:
  589. return res.json(907)
  590. else:
  591. return res.json(444, 'fullPath')
  592. def delete(self, request_dict, response):
  593. token = request_dict.get('token', None)
  594. tko = TokenObject(token)
  595. response.lang = tko.lang
  596. if tko.code != 0:
  597. return response.json(tko.code)
  598. userID = tko.userID
  599. if not userID:
  600. return response.json(104)
  601. id = request_dict.get('id', None)
  602. param_flag = CommonService.get_param_flag(data=[id])
  603. if param_flag is not True:
  604. return response.json(444)
  605. file = Pc_Info.objects.filter(id=id)
  606. if not file.exists():
  607. return response.json(173)
  608. try:
  609. # 删除文件,文件夹和数据库里的相应数据
  610. file_path = file[0].download_link
  611. file_path = os.path.join(BASE_DIR, file_path).replace('\\', '/')
  612. os.remove(file_path)
  613. # file_path = file_path.split("/")
  614. # file_path = [str(i) for i in file_path][:-1]
  615. # file_path = "/".join(file_path)
  616. # shutil.rmtree(file_path)
  617. file.delete()
  618. except Exception as e:
  619. return response.json(176, repr(e))
  620. else:
  621. return response.json(0)
  622. @staticmethod
  623. def check_version(request_dict, response):
  624. """
  625. AVSS检查版本
  626. @param request_dict: 请求数据
  627. @request_dict version: 当前版本
  628. @param response: 响应
  629. @return: response
  630. """
  631. version = request_dict.get('version', None)
  632. if version is None:
  633. return response.json(444)
  634. avss_version_qs = AVSSVersion.objects.filter().values('online_version', 'force_update_version')
  635. if not avss_version_qs.exists():
  636. return response.json(173)
  637. # 比较当前版本和线上版本
  638. online_version = avss_version_qs[0]['online_version']
  639. if version < online_version:
  640. res = {'online_version': online_version}
  641. # 判断是否强制更新
  642. force_update_version = avss_version_qs[0]['force_update_version']
  643. if version < force_update_version:
  644. res['force_update'] = 1
  645. return response.json(0, res)
  646. else:
  647. res['force_update'] = 0
  648. return response.json(0, res)
  649. else:
  650. return response.json(0)
  651. def compareVersion(s1: str, s2: str) -> Union[str, int]:
  652. i, j = 0, 0
  653. while i < len(s1) or j < len(s2):
  654. k1 = i
  655. while k1 < len(s1) and s1[k1] != '.':
  656. k1 += 1
  657. k2 = j
  658. while k2 < len(s2) and s2[k2] != '.':
  659. k2 += 1
  660. a = int(s1[i:k1]) if i != k1 else 0
  661. b = int(s2[j:k2]) if j != k2 else 0
  662. if a > b:
  663. return s1
  664. if a < b:
  665. return s2
  666. i = k1 + 1
  667. j = k2 + 1
  668. return 0
  669. def getMD5orSHA265(fileName, encryptionType='MD5'):
  670. """
  671. :param filePath:
  672. :param encryptionType:
  673. :return:
  674. """
  675. if not os.path.isfile(fileName):
  676. return ''
  677. else:
  678. if encryptionType == 'MD5':
  679. encryption = hashlib.md5()
  680. elif encryptionType == 'SHA265':
  681. encryption = hashlib.sha256()
  682. elif encryptionType == 'CRC32':
  683. f = open(fileName, 'rb')
  684. chunk = f.read()
  685. return crc32(chunk)
  686. f = open(fileName, 'rb')
  687. block_size = 8192 # why is 8192 | 8192 is fast than 2048
  688. while True:
  689. chunk = f.read(block_size)
  690. if not chunk:
  691. break
  692. encryption.update(chunk)
  693. f.close()
  694. return encryption.hexdigest()