DeviceManagementController.py 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import json
  4. import time
  5. from bisect import bisect_left
  6. import oss2
  7. from django.db import transaction
  8. from django.db.models import Q, F
  9. from django.views.generic.base import View
  10. from Ansjer.config import OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET, AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY, \
  11. AWS_SES_ACCESS_REGION
  12. from Model.models import Device_Info, UidSetModel, LogModel, UID_Bucket, Unused_Uid_Meal, Order_Model, StsCrdModel, \
  13. VodHlsModel, ExperienceContextModel, DeviceTypeModel, Equipment_Info, UidUserModel, ExperienceAiModel, AiService, \
  14. AppBundle, App_Info, AppDeviceType, DeviceNameLanguage, AppVersionNumber
  15. from Object.AWS.AmazonS3Util import AmazonS3Util
  16. from Object.ResponseObject import ResponseObject
  17. from Object.TokenObject import TokenObject
  18. from Service.CommonService import CommonService
  19. from Service.EquipmentInfoService import EquipmentInfoService
  20. from Service.ModelService import ModelService
  21. class DeviceManagement(View):
  22. def get(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. operation = kwargs.get('operation')
  25. return self.validation(request.GET, request, operation)
  26. def post(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. operation = kwargs.get('operation')
  29. return self.validation(request.POST, request, operation)
  30. def validation(self, request_dict, request, operation):
  31. language = request_dict.get('language', 'en')
  32. response = ResponseObject(language, 'pc')
  33. if operation == 'addDeviceType':
  34. return self.addDeviceType(request, request_dict, response)
  35. elif operation == 'delDeviceData': # 删除设备数据
  36. return self.del_device_data(request_dict, response)
  37. elif operation == 'getDeviceIcon': # app获取设备图标
  38. response = ResponseObject(language)
  39. return self.get_device_icon(request_dict, response)
  40. elif operation == 'addAppDeviceType': # 添加app设备类型数据并上传图标
  41. return self.add_app_device_type(request_dict, response, request)
  42. else:
  43. tko = TokenObject(
  44. request.META.get('HTTP_AUTHORIZATION'),
  45. returntpye='pc')
  46. if tko.code != 0:
  47. return response.json(tko.code)
  48. response.lang = tko.lang
  49. userID = tko.userID
  50. if not userID:
  51. return response.json(444, 'userID')
  52. if operation == 'getDeviceInfoList': # 获取设备信息数据
  53. return self.get_device_info_list(request_dict, response)
  54. elif operation == 'deleteDevice':
  55. return self.deleteDevice(request_dict, response)
  56. elif operation == 'resetVod': # 重置云存
  57. return self.resetVod(request, request_dict, response)
  58. elif operation == 'resetAi': # 重置AI
  59. return self.reset_ai(request, request_dict, response)
  60. elif operation == 'resetPrimaryUser':
  61. return self.resetPrimaryUser(request, request_dict, response)
  62. elif operation == 'getDeviceTypeList':
  63. return self.getDeviceTypeList(request_dict, response)
  64. elif operation == 'deleteDeviceType':
  65. return self.deleteDeviceType(request_dict, response)
  66. elif operation == 'getAppDeviceTypeList': # 获取app设备类型数据
  67. return self.get_app_device_type_list(request_dict, response)
  68. elif operation == 'getAppBundleIdList': # 获取app包id数据
  69. return self.get_app_bundle_id_list(response)
  70. elif operation == 'editAppDeviceType': # 编辑app设备类型数据
  71. return self.edit_app_device_type(request_dict, response)
  72. elif operation == 'deleteAppDeviceType': # 删除app设备类型数据
  73. return self.delete_app_device_type(request_dict, response)
  74. elif operation == 'getAppBundle': # 获取app版本包
  75. return self.get_app_bundle(response)
  76. else:
  77. return response.json(444, 'operation')
  78. @classmethod
  79. def get_app_bundle(cls, response):
  80. app_bundle_qs = AppBundle.objects.all().values('id', 'app_bundle_id')
  81. if not app_bundle_qs.exists():
  82. return response.json(444)
  83. try:
  84. app_bundle_list = []
  85. for app_bundle in app_bundle_qs:
  86. app_bundle_qs.exists()
  87. app_bundle_list.append(app_bundle)
  88. return response.json(0, app_bundle_list)
  89. except Exception as e:
  90. return response.json(500, e)
  91. @staticmethod
  92. def add_app_device_type(request_dict, response, request):
  93. # 添加APP设备类型
  94. app_bundle_name = request_dict.get(
  95. 'appbundleName', '')[
  96. 1:-1].split(',') # '[1,2]' -> ['1','2']
  97. app_bundle_id = request_dict.get(
  98. 'app_bundle_id', '')[
  99. 1:-1].split(',') # '[1,2]' -> ['1','2']
  100. # app_device_type表数据
  101. model = request_dict.get('model', None)
  102. type = request_dict.get('type', None)
  103. # device_name_language表数据
  104. lang = request_dict.get('lang', None)
  105. name = request_dict.get('name', None)
  106. sort = request_dict.get('sort', None)
  107. # 上传图标
  108. file = request.FILES.get('iconFile', None)
  109. fileName = file.name
  110. if not all([model, type, lang, name, sort]):
  111. return response.json(444)
  112. type = int(type)
  113. try:
  114. with transaction.atomic():
  115. # 判断包是否存在,并创建
  116. new_bundle_list = []
  117. for bundle_name in app_bundle_name:
  118. if not bundle_name == '':
  119. app_bundle_name_qs = AppBundle.objects.filter(app_bundle_id=bundle_name).values('id')
  120. if not app_bundle_name_qs.exists():
  121. app_bundle_name_qs.create(app_bundle_id=bundle_name)
  122. app_bundle_qs = AppBundle.objects.filter(app_bundle_id=bundle_name).values('id')
  123. id = app_bundle_qs[0]['id']
  124. new_bundle_list.append(id)
  125. for app_id in app_bundle_id:
  126. if not app_id == '':
  127. app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
  128. if not app_bundle_qs.exists():
  129. AppBundle.objects.create(app_bundle_id=app_bundle_name, id=app_id)
  130. # 判断数据是否存在,是否上传
  131. # app_device_type_qs = AppDeviceType.objects.filter(type=type).values()
  132. # if app_device_type_qs.exists():
  133. # return response.json(174)
  134. # S3下文件夹路径+文件名 组成对象key
  135. file_key = 'app/device_type_images/{}'.format(fileName)
  136. s3 = AmazonS3Util(AWS_ACCESS_KEY_ID[1], AWS_SECRET_ACCESS_KEY[1], AWS_SES_ACCESS_REGION)
  137. # 存储桶
  138. bucket = 'ansjerfilemanager'
  139. # 地址:https://ansjerfilemanager.s3.amazonaws.com/app/device_type_images/camera_c190.png
  140. s3.upload_file_obj(bucket, file_key, file,
  141. {'ContentType': file.content_type, 'ACL': 'public-read'})
  142. response_url = 'https://ansjerfilemanager.s3.amazonaws.com/app/device_type_images/' + format(fileName)
  143. app_device_type_qs = AppDeviceType.objects.create(model=model, type=type, icon=response_url)
  144. DeviceNameLanguage.objects.create(lang=lang, name=name, sort=sort,
  145. app_device_type_id=app_device_type_qs.id)
  146. # 关联包
  147. for app_id in app_bundle_id:
  148. if app_id == '':
  149. for app_id in new_bundle_list:
  150. app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
  151. app_bundle_qs = app_bundle_qs[0]['id']
  152. app_device_type_qs.appbundle_set.add(app_bundle_qs)
  153. return response.json(0)
  154. app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
  155. app_bundle_qs = app_bundle_qs[0]['id']
  156. app_device_type_qs.appbundle_set.add(app_bundle_qs)
  157. return response.json(0)
  158. except Exception as e:
  159. print(e)
  160. return response.json(500, repr(e))
  161. @staticmethod
  162. def get_device_info_list(request_dict, response):
  163. pageNo = request_dict.get('pageNo', None)
  164. pageSize = request_dict.get('pageSize', None)
  165. UID = request_dict.get('UID', None)
  166. serialNumber = request_dict.get('serialNumber', None)
  167. NickName = request_dict.get('NickName', None)
  168. username = request_dict.get('username', None)
  169. if not all([pageNo, pageSize]):
  170. return response.json(444)
  171. page = int(pageNo)
  172. line = int(pageSize)
  173. try:
  174. if UID or serialNumber or NickName or username: # 条件查询
  175. if UID:
  176. device_info_qs = Device_Info.objects.filter(UID__icontains=UID)
  177. if serialNumber:
  178. device_info_qs = Device_Info.objects.filter(serial_number__icontains=serialNumber)
  179. if NickName:
  180. device_info_qs = Device_Info.objects.filter(NickName__icontains=NickName)
  181. if username:
  182. device_info_qs = Device_Info.objects.filter(Q(userID__username__icontains=username) |
  183. Q(userID__userEmail__icontains=username) |
  184. Q(userID__phone__icontains=username))
  185. total = device_info_qs.count()
  186. if not total:
  187. return response.json(0, {'list': {}, 'total': 0})
  188. device_info_qs = device_info_qs[(page - 1) * line:page * line]
  189. else: # 查询全部
  190. total = Device_Info.objects.filter().count()
  191. device_info_qs = Device_Info.objects.filter()[(page - 1) * line:page * line]
  192. if not device_info_qs.exists():
  193. return response.json(0, {'list': {}, 'total': 0})
  194. device_info_list = CommonService.qs_to_dict(device_info_qs)
  195. for k, v in enumerate(device_info_list["datas"]):
  196. for device_info in device_info_qs:
  197. if v['pk'] == device_info.id:
  198. # 设备的用户名和主用户
  199. username = ModelService.get_user_name(device_info_list["datas"][k]['fields']['userID'])
  200. device_info_list["datas"][k]['fields']['username'] = username
  201. device_info_list["datas"][k]['fields']['vodPrimaryMaster'] = \
  202. device_info_list["datas"][k]['fields']['vodPrimaryMaster']
  203. # 设备类型,是否支持Alexa和ip
  204. type = device_info_list["datas"][k]['fields']['Type']
  205. device_type_qs = DeviceTypeModel.objects.filter(type=type).values('name')
  206. if device_type_qs.exists():
  207. device_info_list["datas"][k]['fields']['Type'] = device_type_qs[0]['name']
  208. uid_set_qs = UidSetModel.objects.filter(
  209. uid=device_info_list["datas"][k]['fields']['UID']).values('is_alexa', 'ip', 'version')
  210. if uid_set_qs.exists():
  211. isAlexa = '是' if uid_set_qs[0]['is_alexa'] else '否'
  212. device_info_list["datas"][k]['fields']['isAlexa'] = isAlexa
  213. device_info_list["datas"][k]['fields']['ip'] = uid_set_qs[0]['ip']
  214. device_info_list["datas"][k]['fields']['version'] = uid_set_qs[0]['version']
  215. return response.json(0, {'list': device_info_list, 'total': total})
  216. except Exception as e:
  217. print(e)
  218. return response.json(500, repr(e))
  219. # 根据id删除设备
  220. def deleteDevice(self, request_dict, response):
  221. deviceID = request_dict.get('deviceID', None)
  222. userID = request_dict.get('userID', None)
  223. uid = request_dict.get('uid', None)
  224. if not all([deviceID, userID, uid]):
  225. return response.json(444)
  226. try:
  227. with transaction.atomic():
  228. Device_Info.objects.filter(id=deviceID).delete()
  229. # 删除推送消息
  230. for val in range(1, 8):
  231. EquipmentInfoService.get_equipment_info_model('', val). \
  232. filter(device_user_id=userID, device_uid=uid).delete()
  233. return response.json(0)
  234. except Exception as e:
  235. print(e)
  236. return response.json(500, repr(e))
  237. # 重置设备主用户
  238. def resetPrimaryUser(self, request, request_dict, response):
  239. uid = request_dict.get('uid', None)
  240. if not uid:
  241. return response.json(404)
  242. try:
  243. # 记录操作日志
  244. ip = CommonService.get_ip_address(request)
  245. content = json.loads(json.dumps(request_dict))
  246. log = {
  247. 'ip': ip,
  248. 'user_id': 2,
  249. 'status': 200,
  250. 'time': int(time.time()),
  251. 'url': 'deviceManagement/resetPrimaryUser',
  252. 'content': json.dumps(content),
  253. 'operation': '{}重置设备主用户'.format(uid),
  254. }
  255. LogModel.objects.create(**log)
  256. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  257. return response.json(0)
  258. except Exception as e:
  259. return response.json(500, repr(e))
  260. # 重置设备云存
  261. def resetVod(self, request, request_dict, response):
  262. uid = request_dict.get('uid', None)
  263. if not uid:
  264. return response.json(444)
  265. try:
  266. # 记录操作日志
  267. ip = CommonService.get_ip_address(request)
  268. content = json.loads(json.dumps(request_dict))
  269. log = {
  270. 'ip': ip,
  271. 'user_id': 2,
  272. 'status': 200,
  273. 'time': int(time.time()),
  274. 'url': 'deviceManagement/resetVod',
  275. 'content': json.dumps(content),
  276. 'operation': '{}重置云存'.format(uid),
  277. }
  278. with transaction.atomic():
  279. LogModel.objects.create(**log)
  280. # 删除和更新设备云存相关数据
  281. UID_Bucket.objects.filter(uid=uid).delete()
  282. Unused_Uid_Meal.objects.filter(uid=uid).delete()
  283. Order_Model.objects.filter(UID=uid, order_type=0).delete()
  284. StsCrdModel.objects.filter(uid=uid).delete()
  285. VodHlsModel.objects.filter(uid=uid).delete()
  286. ExperienceContextModel.objects.filter(uid=uid).delete()
  287. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  288. return response.json(0)
  289. except Exception as e:
  290. print(e)
  291. return response.json(500, repr(e))
  292. @staticmethod
  293. def reset_ai(request, request_dict, response):
  294. uid = request_dict.get('uid', None)
  295. if not uid:
  296. return response.json(444)
  297. try:
  298. # 记录操作日志
  299. ip = CommonService.get_ip_address(request)
  300. content = json.loads(json.dumps(request_dict))
  301. log = {
  302. 'ip': ip,
  303. 'user_id': 2,
  304. 'status': 200,
  305. 'time': int(time.time()),
  306. 'url': 'deviceManagement/resetAi',
  307. 'content': json.dumps(content),
  308. 'operation': '{}重置AI'.format(uid),
  309. }
  310. with transaction.atomic():
  311. LogModel.objects.create(**log)
  312. # 删除和更新设备AI相关数据
  313. ExperienceAiModel.objects.filter(uid=uid).delete()
  314. AiService.objects.filter(uid=uid).delete()
  315. return response.json(0)
  316. except Exception as e:
  317. print(e)
  318. return response.json(500, repr(e))
  319. # 获取设备类型数据
  320. def getDeviceTypeList(self, request_dict, response):
  321. name = request_dict.get('name', None)
  322. pageNo = request_dict.get('pageNo', None)
  323. pageSize = request_dict.get('pageSize', None)
  324. if not all([pageNo, pageSize]):
  325. return response.json(444)
  326. page = int(pageNo)
  327. line = int(pageSize)
  328. try:
  329. if name:
  330. device_type_qs = DeviceTypeModel.objects.filter(name__contains=name).values()
  331. total = len(device_type_qs)
  332. else:
  333. device_type_qs = DeviceTypeModel.objects.filter().values()[(page - 1) * line:page * line]
  334. total = DeviceTypeModel.objects.filter().count()
  335. if not device_type_qs.exists():
  336. return response.json(173)
  337. device_type_list = []
  338. for device_type in device_type_qs:
  339. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  340. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
  341. icon = device_type['icon']
  342. url = 'device_type/' + icon
  343. device_type['icon'] = bucket.sign_url('GET', url, 3600)
  344. device_type_list.append(device_type)
  345. return response.json(0, {'list': device_type_list, 'total': total})
  346. except Exception as e:
  347. print(e)
  348. return response.json(500, repr(e))
  349. # 删除设备类型
  350. def deleteDeviceType(self, request_dict, response):
  351. deviceTypeID = request_dict.get('deviceTypeID', None)
  352. if not deviceTypeID:
  353. return response.json(444)
  354. try:
  355. DeviceTypeModel.objects.filter(id=deviceTypeID).delete()
  356. return response.json(0)
  357. except Exception as e:
  358. print(e)
  359. return response.json(500, repr(e))
  360. # 添加设备类型
  361. def addDeviceType(self, request, request_dict, response):
  362. iconFile = request.FILES.get('iconFile', None)
  363. name = request_dict.get('name', None)
  364. model = request_dict.get('model', None)
  365. type = request_dict.get('type', None)
  366. ptz_type = request_dict.get('ptz_type', None)
  367. if not all([iconFile, name, model, type, ptz_type]):
  368. return response.json(444)
  369. try:
  370. model = int(model)
  371. ptz_type = int(ptz_type)
  372. icon = iconFile.name
  373. now_time = int(time.time())
  374. # 上传文件到阿里云OSS
  375. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  376. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
  377. key = 'device_type/' + icon # 图片文件存放于 device_type 目录下
  378. # https://oss.console.aliyun.com/bucket/oss-cn-shenzhen/ansjer-static-resources/object?path=device_type%2F
  379. bucket.put_object(key=key, data=iconFile)
  380. DeviceTypeModel.objects.create(name=name, model=model, type=type, ptz_type=ptz_type, icon=icon,
  381. add_time=now_time, update_time=now_time)
  382. return response.json(0)
  383. except Exception as e:
  384. print(e)
  385. return response.json(500, repr(e))
  386. @staticmethod
  387. def del_device_data(request_dict, response):
  388. uidList = request_dict.get('uidList', None)
  389. delDataOptions = request_dict.get('delDataOptions', None)
  390. if not all([uidList, delDataOptions]):
  391. return response.json(444)
  392. try:
  393. with transaction.atomic():
  394. uidList = uidList.splitlines() # 按行('\r', '\r\n', \n')切割字符串返回列表
  395. # 根据删除项删除相关数据
  396. if '设备信息数据' in delDataOptions:
  397. Device_Info.objects.filter(UID__in=uidList).delete()
  398. if '设备配置数据' in delDataOptions:
  399. UidSetModel.objects.filter(uid__in=uidList).delete()
  400. if '设备推送数据' in delDataOptions:
  401. Equipment_Info.objects.filter(devUid__in=uidList).delete()
  402. if '设备AP信息数据' in delDataOptions:
  403. UidUserModel.objects.filter(UID__in=uidList).delete()
  404. if '设备AI数据' in delDataOptions:
  405. ExperienceAiModel.objects.filter(uid__in=uidList).delete()
  406. Order_Model.objects.filter(UID__in=uidList, order_type=1).delete()
  407. if '设备云存数据' in delDataOptions:
  408. UID_Bucket.objects.filter(uid__in=uidList).delete()
  409. StsCrdModel.objects.filter(uid__in=uidList).delete()
  410. VodHlsModel.objects.filter(uid__in=uidList).delete()
  411. Unused_Uid_Meal.objects.filter(uid__in=uidList).delete()
  412. ExperienceContextModel.objects.filter(uid__in=uidList).delete()
  413. Order_Model.objects.filter(UID__in=uidList, order_type=0).delete()
  414. Device_Info.objects.filter(UID__in=uidList).update(vodPrimaryUserID='', vodPrimaryMaster='')
  415. return response.json(0)
  416. except Exception as e:
  417. print(e)
  418. return response.json(500, repr(e))
  419. @staticmethod
  420. def get_device_icon(request_dict, response):
  421. lang = request_dict.get('lang', None)
  422. app_bundle_id = request_dict.get('appBundleId', None)
  423. version_number = request_dict.get('versionNumber', None)
  424. if not all([lang, app_bundle_id, version_number]):
  425. return response.json(444)
  426. version_number_qs = AppVersionNumber.objects.filter(version_number=version_number)
  427. if not version_number_qs.exists():
  428. version_number_qs = AppVersionNumber.objects.values('version_number')
  429. test_list = [item[key] for item in version_number_qs for key in item]
  430. if (version_number > test_list[-1] or version_number < test_list[0]):
  431. version_number_qs = AppVersionNumber.objects.filter().values('id').order_by('id')
  432. total_list = [item[key] for item in version_number_qs for key in item]
  433. version_number_id = total_list[-1]
  434. else:
  435. pos = bisect_left(test_list, version_number)
  436. if pos == 0:
  437. return test_list[0]
  438. if pos == len(test_list):
  439. return test_list[-1]
  440. before = test_list[pos - 1]
  441. version_number_qs = AppVersionNumber.objects.filter(version_number=before).values('id')
  442. version_number_id = version_number_qs[0]['id']
  443. else:
  444. version_number_qs = AppVersionNumber.objects.filter(version_number=version_number).values('id')
  445. version_number_id = version_number_qs[0]['id']
  446. try:
  447. app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id,
  448. app_device_type__devicenamelanguage__lang=lang,
  449. app_device_type__app_version_number_id=version_number_id). \
  450. annotate(
  451. model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
  452. name=F('app_device_type__devicenamelanguage__name'),
  453. sort=F('app_device_type__devicenamelanguage__sort'),
  454. app_version_number_id=F('app_device_type__app_version_number_id')).order_by(
  455. 'app_device_type__devicenamelanguage__sort').values('model', 'type', 'icon', 'name', 'sort',
  456. 'app_device_type__app_version_number_id')
  457. dvr_list = [app_bundle for app_bundle in app_bundle_qs if app_bundle['model'] == 1]
  458. ipc_list = [app_bundle for app_bundle in app_bundle_qs if app_bundle['model'] == 2]
  459. print(dvr_list, ipc_list)
  460. res = {
  461. 'deviceDvr': dvr_list,
  462. 'deviceIpc': ipc_list,
  463. }
  464. return response.json(0, res)
  465. except Exception as e:
  466. print(e)
  467. return response.json(500, repr(e))
  468. @staticmethod
  469. def get_app_device_type_list(request_dict, response):
  470. app_bundle_id = request_dict.get('app_bundle_id', None)
  471. lang = request_dict.get('lang', 'cn')
  472. model = request_dict.get('model', None)
  473. type = request_dict.get('type', None)
  474. name = request_dict.get('name', None)
  475. pageNo = request_dict.get('pageNo', None)
  476. pageSize = request_dict.get('pageSize', None)
  477. if not all([pageNo, pageSize]):
  478. return response.json(444)
  479. page = int(pageNo)
  480. line = int(pageSize)
  481. try:
  482. if not app_bundle_id:
  483. app_bundle_id = 'com.ansjer.zccloud'
  484. app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id)
  485. if lang:
  486. app_bundle_qs = app_bundle_qs.filter(app_device_type__devicenamelanguage__lang=lang)
  487. app_bundle_qs = app_bundle_qs.annotate(
  488. model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
  489. lang=F('app_device_type__devicenamelanguage__lang'),
  490. name=F('app_device_type__devicenamelanguage__name'),
  491. sort=F('app_device_type__devicenamelanguage__sort')).values('id', 'app_device_type__id', 'model',
  492. 'type', 'icon',
  493. 'app_device_type__devicenamelanguage__id',
  494. 'lang', 'name', 'sort').order_by(
  495. 'app_device_type__devicenamelanguage__sort')
  496. if not app_bundle_qs.exists():
  497. return response.json(0)
  498. app_bundle_qs = app_bundle_qs.all()
  499. if name:
  500. app_bundle_qs = app_bundle_qs.filter(name=name)
  501. if model:
  502. app_bundle_qs = app_bundle_qs.filter(model=model)
  503. if type:
  504. app_bundle_qs = app_bundle_qs.filter(type=type)
  505. total = app_bundle_qs.count()
  506. app_bundle_qs = app_bundle_qs[(page - 1) * line:page * line]
  507. app_device_type_list = [app_bundle for app_bundle in app_bundle_qs]
  508. return response.json(0, {'list': app_device_type_list, 'total': total})
  509. except Exception as e:
  510. print(e)
  511. return response.json(500, repr(e))
  512. @staticmethod
  513. def get_app_bundle_id_list(response):
  514. try:
  515. app_info_qs = App_Info.objects.filter().values('id', 'appBundleId', 'appName')
  516. appBundleIdList = list(app_info_qs)
  517. return response.json(0, {'list': appBundleIdList})
  518. except Exception as e:
  519. print(e)
  520. return response.json(500, repr(e))
  521. @staticmethod
  522. def edit_app_device_type(request_dict, response):
  523. # app_device_type表数据
  524. app_device_type_id = request_dict.get('app_device_type__id', None)
  525. model = request_dict.get('model', None)
  526. type = request_dict.get('type', None)
  527. icon = request_dict.get('icon', None)
  528. # device_name_language表数据
  529. device_name_language_id = request_dict.get('app_device_type__devicenamelanguage__id', None)
  530. lang = request_dict.get('lang', None)
  531. name = request_dict.get('name', None)
  532. sort = request_dict.get('sort', None)
  533. if not all([app_device_type_id, model, type, icon, device_name_language_id, lang, name, sort]):
  534. return response.json(444)
  535. try:
  536. with transaction.atomic():
  537. AppDeviceType.objects.filter(id=app_device_type_id).update(model=model, type=type, icon=icon)
  538. DeviceNameLanguage.objects.filter(id=device_name_language_id).update(lang=lang, name=name, sort=sort)
  539. return response.json(0)
  540. except Exception as e:
  541. print(e)
  542. return response.json(500, repr(e))
  543. @staticmethod
  544. def delete_app_device_type(request_dict, response):
  545. app_bundle_id = request_dict.get('appBundleId', None)
  546. app_device_type_id = request_dict.get('appDeviceTypeId', None)
  547. if not all([app_bundle_id, app_device_type_id]):
  548. return response.json(444)
  549. try:
  550. app_bundle_qs = AppBundle.objects.get(id=app_bundle_id)
  551. app_device_type_qs = AppDeviceType.objects.filter(id=app_device_type_id)
  552. app_bundle_qs.app_device_type.remove(*app_device_type_qs)
  553. return response.json(0)
  554. except Exception as e:
  555. print(e)
  556. return response.json(500, repr(e))