DeviceManagementController.py 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import json
  4. import operator
  5. import time
  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, UNUSED_SERIAL_REDIS_LIST
  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, UIDCompanySerialModel, UIDModel, \
  15. CompanySerialModel, UidPushModel
  16. from Object.AWS.AmazonS3Util import AmazonS3Util
  17. from Object.RedisObject import RedisObject
  18. from Object.ResponseObject import ResponseObject
  19. from Object.TokenObject import TokenObject
  20. from Service.CommonService import CommonService
  21. from Service.EquipmentInfoService import EquipmentInfoService
  22. from Service.ModelService import ModelService
  23. from Service.VodHlsService import SplitVodHlsObject
  24. class DeviceManagement(View):
  25. def get(self, request, *args, **kwargs):
  26. request.encoding = 'utf-8'
  27. operation = kwargs.get('operation')
  28. return self.validation(request.GET, request, operation)
  29. def post(self, request, *args, **kwargs):
  30. request.encoding = 'utf-8'
  31. operation = kwargs.get('operation')
  32. return self.validation(request.POST, request, operation)
  33. def validation(self, request_dict, request, operation):
  34. language = request_dict.get('language', 'en')
  35. response = ResponseObject(language, 'pc')
  36. if operation == 'addDeviceType':
  37. return self.addDeviceType(request, request_dict, response)
  38. elif operation == 'delDeviceData': # 删除设备数据
  39. return self.del_device_data(request_dict, response)
  40. elif operation == 'getDeviceIcon': # app获取设备图标
  41. response = ResponseObject(language)
  42. return self.get_device_icon(request_dict, response)
  43. elif operation == 'addAppDeviceType': # 添加app设备类型数据并上传图标
  44. return self.add_app_device_type(request_dict, response, request)
  45. else:
  46. tko = TokenObject(
  47. request.META.get('HTTP_AUTHORIZATION'),
  48. returntpye='pc')
  49. if tko.code != 0:
  50. return response.json(tko.code)
  51. response.lang = tko.lang
  52. userID = tko.userID
  53. if not userID:
  54. return response.json(444, 'userID')
  55. if operation == 'getDeviceInfoList': # 获取设备信息数据
  56. return self.get_device_info_list(request_dict, response)
  57. elif operation == 'deleteDevice':
  58. return self.deleteDevice(request_dict, response)
  59. elif operation == 'resetVod': # 重置云存
  60. return self.resetVod(request, request_dict, response)
  61. elif operation == 'resetAi': # 重置AI
  62. return self.reset_ai(request, request_dict, response)
  63. elif operation == 'resetPrimaryUser':
  64. return self.resetPrimaryUser(request, request_dict, response)
  65. elif operation == 'getDeviceTypeList':
  66. return self.getDeviceTypeList(request_dict, response)
  67. elif operation == 'deleteDeviceType':
  68. return self.deleteDeviceType(request_dict, response)
  69. elif operation == 'getAppDeviceTypeList': # 获取app设备类型数据
  70. return self.get_app_device_type_list(request_dict, response)
  71. elif operation == 'getAppBundleIdList': # 获取app包id数据
  72. return self.get_app_bundle_id_list(response)
  73. elif operation == 'editAppDeviceType': # 编辑app设备类型数据
  74. return self.edit_app_device_type(request_dict, response)
  75. elif operation == 'deleteAppDeviceType': # 删除app设备类型数据
  76. return self.delete_app_device_type(request_dict, response)
  77. elif operation == 'getAppBundle': # 获取app版本包
  78. return self.get_app_bundle(response)
  79. elif operation == 'resetAll': # 重置设备主用户/云存/AI
  80. return self.reset_all(request, request_dict, response)
  81. else:
  82. return response.json(444, 'operation')
  83. @classmethod
  84. def get_app_bundle(cls, response):
  85. """
  86. 获取app版本id
  87. """
  88. app_bundle_qs = AppBundle.objects.all().values('id', 'app_bundle_id')
  89. if not app_bundle_qs.exists():
  90. return response.json(0)
  91. app_bundle_list = []
  92. for app_bundle in app_bundle_qs:
  93. app_bundle_qs.exists()
  94. app_bundle_list.append(app_bundle)
  95. return response.json(0, app_bundle_list)
  96. @classmethod
  97. def get_device_info_list(cls, request_dict, response):
  98. pageNo = request_dict.get('pageNo', None)
  99. pageSize = request_dict.get('pageSize', None)
  100. UID = request_dict.get('UID', None)
  101. serialNumber = request_dict.get('serialNumber', None)
  102. NickName = request_dict.get('NickName', None)
  103. username = request_dict.get('username', None)
  104. version = request_dict.get('version', None)
  105. if not all([pageNo, pageSize]):
  106. return response.json(444)
  107. page = int(pageNo)
  108. line = int(pageSize)
  109. try:
  110. if any([UID, serialNumber, NickName, username, version]): # 条件查询
  111. if UID:
  112. device_info_qs = Device_Info.objects.filter(UID__icontains=UID)
  113. if serialNumber:
  114. device_info_qs = Device_Info.objects.filter(serial_number__icontains=serialNumber[:9])
  115. if NickName:
  116. device_info_qs = Device_Info.objects.filter(NickName__icontains=NickName)
  117. if username:
  118. device_info_qs = Device_Info.objects.filter(Q(userID__username__icontains=username) |
  119. Q(userID__userEmail__icontains=username) |
  120. Q(userID__phone__icontains=username))
  121. if version:
  122. uid_list = UidSetModel.objects.filter(version__icontains=version).values_list('uid', flat=True)
  123. device_info_qs = Device_Info.objects.filter(UID__in=uid_list)
  124. total = device_info_qs.count()
  125. if not total:
  126. return response.json(0, {'list': {}, 'total': 0})
  127. device_info_qs = device_info_qs[(page - 1) * line:page * line]
  128. else: # 查询全部
  129. total = Device_Info.objects.filter().count()
  130. device_info_qs = Device_Info.objects.filter()[(page - 1) * line:page * line]
  131. if not device_info_qs.exists():
  132. return response.json(0, {'list': {}, 'total': 0})
  133. device_info_list = CommonService.qs_to_dict(device_info_qs)
  134. for k, v in enumerate(device_info_list["datas"]):
  135. for device_info in device_info_qs:
  136. if v['pk'] == device_info.id:
  137. # 设备的用户名和主用户
  138. username = ModelService.get_user_name(device_info_list["datas"][k]['fields']['userID'])
  139. device_info_list["datas"][k]['fields']['username'] = username
  140. device_info_list["datas"][k]['fields']['vodPrimaryMaster'] = \
  141. device_info_list["datas"][k]['fields']['vodPrimaryMaster']
  142. # 是否支持移动侦测
  143. iSNotification = '开' if device_info_list["datas"][k]['fields']['iSNotification'] == 1 else '关'
  144. device_info_list["datas"][k]['fields']['iSNotification'] = iSNotification
  145. # 设备类型,是否支持Alexa和ip
  146. type = device_info_list["datas"][k]['fields']['Type']
  147. device_type_qs = DeviceTypeModel.objects.filter(type=type).values('name')
  148. if device_type_qs.exists():
  149. device_info_list["datas"][k]['fields']['Type'] = device_type_qs[0]['name']
  150. uid_set_qs = UidSetModel.objects.filter(
  151. uid=device_info_list["datas"][k]['fields']['UID']).values('is_alexa', 'ip', 'version',
  152. 'is_ai', 'is_human', 'cloud_vod',
  153. 'ucode', 'device_type')
  154. if uid_set_qs.exists():
  155. isAlexa = '是' if uid_set_qs[0]['is_alexa'] else '否'
  156. isHuman = '是' if uid_set_qs[0]['is_human'] else '否'
  157. cloud_vod = CommonService.is_cloud_device(uid_set_qs[0]['ucode'],
  158. uid_set_qs[0]['device_type'])
  159. if cloud_vod:
  160. cloud_vod = '支持'
  161. else:
  162. cloud_vod = '不支持'
  163. if uid_set_qs[0]['is_ai'] == 2:
  164. isAI = '不支持'
  165. elif uid_set_qs[0]['is_ai'] == 1:
  166. isAI = '开启'
  167. else:
  168. isAI = '关闭'
  169. device_info_list["datas"][k]['fields']['isHuman'] = isHuman
  170. device_info_list["datas"][k]['fields']['isAI'] = isAI
  171. device_info_list["datas"][k]['fields']['isAlexa'] = isAlexa
  172. device_info_list["datas"][k]['fields']['cloudVod'] = cloud_vod
  173. device_info_list["datas"][k]['fields']['ip'] = uid_set_qs[0]['ip']
  174. device_info_list["datas"][k]['fields']['version'] = uid_set_qs[0]['version']
  175. uid_bucket_qs = UID_Bucket.objects.filter(
  176. uid=device_info_list["datas"][k]['fields']['UID']).values('status')
  177. # 0是关闭,1是开启
  178. if uid_bucket_qs.exists():
  179. res = []
  180. for uid_bucket in uid_bucket_qs:
  181. status = uid_bucket['status']
  182. res.append(status)
  183. if 1 in res:
  184. device_info_list["datas"][k]['fields']['status'] = 1
  185. else:
  186. device_info_list["datas"][k]['fields']['status'] = 0
  187. else:
  188. device_info_list["datas"][k]['fields']['status'] = 0
  189. return response.json(0, {'list': device_info_list, 'total': total})
  190. except Exception as e:
  191. print(e)
  192. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  193. # 根据id删除设备
  194. def deleteDevice(self, request_dict, response):
  195. deviceID = request_dict.get('deviceID', None)
  196. userID = request_dict.get('userID', None)
  197. uid = request_dict.get('uid', None)
  198. if not all([deviceID, userID, uid]):
  199. return response.json(444)
  200. try:
  201. with transaction.atomic():
  202. Device_Info.objects.filter(id=deviceID).delete()
  203. UidPushModel.objects.filter(uid_set__uid=uid).delete()
  204. # 删除推送消息
  205. for val in range(1, 8):
  206. EquipmentInfoService.get_equipment_info_model('', val). \
  207. filter(device_user_id=userID, device_uid=uid).delete()
  208. return response.json(0)
  209. except Exception as e:
  210. print(e)
  211. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  212. # 重置设备主用户
  213. def resetPrimaryUser(self, request, request_dict, response):
  214. uid = request_dict.get('uid', None)
  215. if not uid:
  216. return response.json(404)
  217. try:
  218. # 记录操作日志
  219. ip = CommonService.get_ip_address(request)
  220. content = json.loads(json.dumps(request_dict))
  221. log = {
  222. 'ip': ip,
  223. 'user_id': 2,
  224. 'status': 200,
  225. 'time': int(time.time()),
  226. 'url': 'deviceManagement/resetPrimaryUser',
  227. 'content': json.dumps(content),
  228. 'operation': '{}重置设备主用户'.format(uid),
  229. }
  230. LogModel.objects.create(**log)
  231. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  232. return response.json(0)
  233. except Exception as e:
  234. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  235. # 重置设备云存
  236. def resetVod(self, request, request_dict, response):
  237. uid = request_dict.get('uid', None)
  238. if not uid:
  239. return response.json(444)
  240. try:
  241. # 记录操作日志
  242. ip = CommonService.get_ip_address(request)
  243. content = json.loads(json.dumps(request_dict))
  244. log = {
  245. 'ip': ip,
  246. 'user_id': 2,
  247. 'status': 200,
  248. 'time': int(time.time()),
  249. 'url': 'deviceManagement/resetVod',
  250. 'content': json.dumps(content),
  251. 'operation': '{}重置云存'.format(uid),
  252. }
  253. with transaction.atomic():
  254. LogModel.objects.create(**log)
  255. # 删除和更新设备云存相关数据
  256. UID_Bucket.objects.filter(uid=uid).delete()
  257. Unused_Uid_Meal.objects.filter(uid=uid).delete()
  258. AiService.objects.filter(uid=uid).delete()
  259. Order_Model.objects.filter(UID=uid, order_type=0).delete()
  260. Order_Model.objects.filter(UID=uid, order_type=1).delete()
  261. StsCrdModel.objects.filter(uid=uid).delete()
  262. VodHlsModel.objects.filter(uid=uid).delete()
  263. # 删除vod_hls分表数据
  264. split_vod_hls_obj = SplitVodHlsObject()
  265. split_vod_hls_obj.del_vod_hls_data(uid=uid)
  266. ExperienceContextModel.objects.filter(uid=uid).delete()
  267. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  268. return response.json(0)
  269. except Exception as e:
  270. print(e)
  271. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  272. @staticmethod
  273. def reset_ai(request, request_dict, response):
  274. uid = request_dict.get('uid', None)
  275. if not uid:
  276. return response.json(444)
  277. try:
  278. # 记录操作日志
  279. ip = CommonService.get_ip_address(request)
  280. content = json.loads(json.dumps(request_dict))
  281. log = {
  282. 'ip': ip,
  283. 'user_id': 2,
  284. 'status': 200,
  285. 'time': int(time.time()),
  286. 'url': 'deviceManagement/resetAi',
  287. 'content': json.dumps(content),
  288. 'operation': '{}重置AI'.format(uid),
  289. }
  290. with transaction.atomic():
  291. LogModel.objects.create(**log)
  292. # 删除和更新设备AI相关数据
  293. ExperienceAiModel.objects.filter(uid=uid).delete()
  294. AiService.objects.filter(uid=uid).delete()
  295. return response.json(0)
  296. except Exception as e:
  297. print(e)
  298. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  299. # 获取设备类型数据
  300. def getDeviceTypeList(self, request_dict, response):
  301. name = request_dict.get('name', None)
  302. pageNo = request_dict.get('pageNo', None)
  303. pageSize = request_dict.get('pageSize', None)
  304. if not all([pageNo, pageSize]):
  305. return response.json(444)
  306. page = int(pageNo)
  307. line = int(pageSize)
  308. try:
  309. if name:
  310. device_type_qs = DeviceTypeModel.objects.filter(name__contains=name).values()
  311. total = len(device_type_qs)
  312. else:
  313. device_type_qs = DeviceTypeModel.objects.filter().values()[(page - 1) * line:page * line]
  314. total = DeviceTypeModel.objects.filter().count()
  315. if not device_type_qs.exists():
  316. return response.json(173)
  317. device_type_list = []
  318. for device_type in device_type_qs:
  319. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  320. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
  321. icon = device_type['icon']
  322. url = 'device_type/' + icon
  323. device_type['icon'] = bucket.sign_url('GET', url, 3600)
  324. device_type_list.append(device_type)
  325. return response.json(0, {'list': device_type_list, 'total': total})
  326. except Exception as e:
  327. print(e)
  328. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  329. # 删除设备类型
  330. def deleteDeviceType(self, request_dict, response):
  331. deviceTypeID = request_dict.get('deviceTypeID', None)
  332. if not deviceTypeID:
  333. return response.json(444)
  334. try:
  335. DeviceTypeModel.objects.filter(id=deviceTypeID).delete()
  336. return response.json(0)
  337. except Exception as e:
  338. print(e)
  339. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  340. # 添加设备类型
  341. def addDeviceType(self, request, request_dict, response):
  342. iconFile = request.FILES.get('iconFile', None)
  343. name = request_dict.get('name', None)
  344. model = request_dict.get('model', None)
  345. type = request_dict.get('type', None)
  346. ptz_type = request_dict.get('ptz_type', None)
  347. if not all([iconFile, name, model, type, ptz_type]):
  348. return response.json(444)
  349. try:
  350. model = int(model)
  351. ptz_type = int(ptz_type)
  352. icon = iconFile.name
  353. now_time = int(time.time())
  354. # 上传文件到阿里云OSS
  355. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  356. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
  357. key = 'device_type/' + icon # 图片文件存放于 device_type 目录下
  358. # https://oss.console.aliyun.com/bucket/oss-cn-shenzhen/ansjer-static-resources/object?path=device_type%2F
  359. bucket.put_object(key=key, data=iconFile)
  360. DeviceTypeModel.objects.create(name=name, model=model, type=type, ptz_type=ptz_type, icon=icon,
  361. add_time=now_time, update_time=now_time)
  362. return response.json(0)
  363. except Exception as e:
  364. print(e)
  365. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  366. @staticmethod
  367. def del_device_data(request_dict, response):
  368. uidList = request_dict.get('uidList', None)
  369. delDataOptions = request_dict.get('delDataOptions', None)
  370. serialNumberList = request_dict.get('serialNumberList', None)
  371. if not all([uidList or serialNumberList, delDataOptions]):
  372. return response.json(444)
  373. try:
  374. with transaction.atomic():
  375. if uidList:
  376. # uid
  377. uidList = uidList.splitlines() # 按行('\r', '\r\n', \n')切割字符串返回列表
  378. else:
  379. # 序列号
  380. serialNumberList = serialNumberList.splitlines() # 按行('\r', '\r\n', \n')切割字符串返回列表
  381. serial_number_list = []
  382. for serial_number in serialNumberList:
  383. serial_number_list.append(serial_number[0:6])
  384. uid_company_serial_qs = UIDCompanySerialModel.objects.filter(
  385. company_serial__serial_number__in=serial_number_list).values('uid__uid')
  386. uidList = [item[key] for item in uid_company_serial_qs for key in item]
  387. # 根据删除项删除相关数据
  388. if '设备信息数据' in delDataOptions:
  389. Device_Info.objects.filter(UID__in=uidList).delete()
  390. UidPushModel.objects.filter(uid_set__uid__in=uidList).delete()
  391. if '设备配置数据' in delDataOptions:
  392. UidSetModel.objects.filter(uid__in=uidList).delete()
  393. if '设备推送数据' in delDataOptions:
  394. Equipment_Info.objects.filter(devUid__in=uidList).delete()
  395. if '设备AP信息数据' in delDataOptions:
  396. UidUserModel.objects.filter(UID__in=uidList).delete()
  397. if '设备AI数据' in delDataOptions:
  398. ExperienceAiModel.objects.filter(uid__in=uidList).delete()
  399. Order_Model.objects.filter(UID__in=uidList, order_type=1).delete()
  400. if '设备云存数据' in delDataOptions:
  401. UID_Bucket.objects.filter(uid__in=uidList).delete()
  402. StsCrdModel.objects.filter(uid__in=uidList).delete()
  403. VodHlsModel.objects.filter(uid__in=uidList).delete()
  404. # 删除vod_hls分表数据
  405. split_vod_hls_obj = SplitVodHlsObject()
  406. split_vod_hls_obj.del_vod_hls_data(uid__in=uidList)
  407. Unused_Uid_Meal.objects.filter(uid__in=uidList).delete()
  408. ExperienceContextModel.objects.filter(uid__in=uidList).delete()
  409. Order_Model.objects.filter(UID__in=uidList, order_type=0).delete()
  410. Device_Info.objects.filter(UID__in=uidList).update(vodPrimaryUserID='', vodPrimaryMaster='')
  411. # 上传序列号文件且选中序列号解绑uid
  412. if serialNumberList is not None and '序列号解绑uid' in delDataOptions:
  413. # 解绑uid数据
  414. UIDModel.objects.filter(uid__in=uidList).update(status=0)
  415. UIDCompanySerialModel.objects.filter(uid__uid__in=uidList).delete()
  416. CompanySerialModel.objects.filter(serial_number__in=serial_number_list).update(status=1)
  417. UidPushModel.objects.filter(uid_set__uid__in=uidList).delete()
  418. # 序列号加入重置状态redis列表
  419. redis_obj = RedisObject()
  420. for serial in serial_number_list:
  421. redis_obj.rpush(UNUSED_SERIAL_REDIS_LIST, serial)
  422. # 记录日志
  423. content = json.loads(json.dumps(request_dict))
  424. device_list = uidList if serialNumberList is None else serial_number_list
  425. log = {
  426. 'user_id': 2,
  427. 'status': 200,
  428. 'time': int(time.time()),
  429. 'url': 'deviceManagement/delDeviceData',
  430. 'content': json.dumps(content),
  431. 'operation': '删除数据的设备列表:{}'.format(device_list),
  432. }
  433. LogModel.objects.create(**log)
  434. return response.json(0)
  435. except Exception as e:
  436. print(e)
  437. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  438. @staticmethod
  439. def get_app_device_type_list(request_dict, response):
  440. app_bundle_id = request_dict.get('app_bundle_id', None)
  441. lang = request_dict.get('lang', 'cn')
  442. model = request_dict.get('model', None)
  443. type = request_dict.get('type', None)
  444. name = request_dict.get('name', None)
  445. pageNo = request_dict.get('pageNo', None)
  446. pageSize = request_dict.get('pageSize', None)
  447. if not all([pageNo, pageSize]):
  448. return response.json(444)
  449. page = int(pageNo)
  450. line = int(pageSize)
  451. try:
  452. if not app_bundle_id:
  453. app_bundle_id = 'com.ansjer.zccloud'
  454. app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id)
  455. if lang:
  456. app_bundle_qs = app_bundle_qs.filter(app_device_type__devicenamelanguage__lang=lang)
  457. app_bundle_qs = app_bundle_qs.annotate(
  458. model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
  459. lang=F('app_device_type__devicenamelanguage__lang'),
  460. name=F('app_device_type__devicenamelanguage__name'),
  461. sort=F('app_device_type__devicenamelanguage__sort')).values('id', 'app_device_type__id', 'model',
  462. 'type', 'icon',
  463. 'app_device_type__devicenamelanguage__id',
  464. 'lang', 'name', 'sort').order_by(
  465. 'app_device_type__devicenamelanguage__sort')
  466. if not app_bundle_qs.exists():
  467. return response.json(0)
  468. app_bundle_qs = app_bundle_qs.all()
  469. if name:
  470. app_bundle_qs = app_bundle_qs.filter(name=name)
  471. if model:
  472. app_bundle_qs = app_bundle_qs.filter(model=model)
  473. if type:
  474. app_bundle_qs = app_bundle_qs.filter(type=type)
  475. total = app_bundle_qs.count()
  476. app_bundle_qs = app_bundle_qs[(page - 1) * line:page * line]
  477. app_device_type_list = [app_bundle for app_bundle in app_bundle_qs]
  478. return response.json(0, {'list': app_device_type_list, 'total': total})
  479. except Exception as e:
  480. print(e)
  481. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  482. @staticmethod
  483. def get_app_bundle_id_list(response):
  484. try:
  485. app_info_qs = App_Info.objects.filter().values('id', 'appBundleId', 'appName')
  486. appBundleIdList = list(app_info_qs)
  487. return response.json(0, {'list': appBundleIdList})
  488. except Exception as e:
  489. print(e)
  490. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  491. @staticmethod
  492. def edit_app_device_type(request_dict, response):
  493. # app_device_type表数据
  494. app_device_type_id = request_dict.get('app_device_type__id', None)
  495. model = request_dict.get('model', None)
  496. type = request_dict.get('type', None)
  497. icon = request_dict.get('icon', None)
  498. # device_name_language表数据
  499. device_name_language_id = request_dict.get('app_device_type__devicenamelanguage__id', None)
  500. lang = request_dict.get('lang', None)
  501. name = request_dict.get('name', None)
  502. sort = request_dict.get('sort', None)
  503. if not all([app_device_type_id, model, type, icon, device_name_language_id, lang, name, sort]):
  504. return response.json(444)
  505. try:
  506. with transaction.atomic():
  507. AppDeviceType.objects.filter(id=app_device_type_id).update(model=model, type=type, icon=icon)
  508. DeviceNameLanguage.objects.filter(id=device_name_language_id).update(lang=lang, name=name, sort=sort)
  509. return response.json(0)
  510. except Exception as e:
  511. print(e)
  512. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  513. @staticmethod
  514. def delete_app_device_type(request_dict, response):
  515. app_bundle_id = request_dict.get('appBundleId', None)
  516. app_device_type_id = request_dict.get('appDeviceTypeId', None)
  517. if not all([app_bundle_id, app_device_type_id]):
  518. return response.json(444)
  519. try:
  520. app_bundle_qs = AppBundle.objects.get(id=app_bundle_id)
  521. app_device_type_qs = AppDeviceType.objects.filter(id=app_device_type_id)
  522. app_bundle_qs.app_device_type.remove(*app_device_type_qs)
  523. return response.json(0)
  524. except Exception as e:
  525. print(e)
  526. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  527. @staticmethod
  528. def reset_all(request, request_dict, response):
  529. uid = request_dict.get('uid', None)
  530. if not uid:
  531. return response.json(444)
  532. try:
  533. # 记录操作日志
  534. ip = CommonService.get_ip_address(request)
  535. content = json.loads(json.dumps(request_dict))
  536. with transaction.atomic():
  537. # 删除主用户
  538. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  539. # 删除云存
  540. UID_Bucket.objects.filter(uid=uid).delete()
  541. Unused_Uid_Meal.objects.filter(uid=uid).delete()
  542. Order_Model.objects.filter(UID=uid, order_type=0).delete()
  543. Order_Model.objects.filter(UID=uid, order_type=1).delete()
  544. StsCrdModel.objects.filter(uid=uid).delete()
  545. VodHlsModel.objects.filter(uid=uid).delete()
  546. # 删除vod_hls分表数据
  547. split_vod_hls_obj = SplitVodHlsObject()
  548. split_vod_hls_obj.del_vod_hls_data(uid=uid)
  549. ExperienceContextModel.objects.filter(uid=uid).delete()
  550. # 删除AI
  551. ExperienceAiModel.objects.filter(uid=uid).delete()
  552. AiService.objects.filter(uid=uid).delete()
  553. log = {
  554. 'ip': ip,
  555. 'user_id': 2,
  556. 'status': 200,
  557. 'time': int(time.time()),
  558. 'url': 'deviceManagement/resetAll',
  559. 'content': json.dumps(content),
  560. 'operation': '{}重置所有'.format(uid),
  561. }
  562. LogModel.objects.create(**log)
  563. return response.json(0)
  564. except Exception as e:
  565. print(e)
  566. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  567. @staticmethod
  568. def add_app_device_type(request_dict, response, request):
  569. """
  570. 添加app设备类型数据并上传图标
  571. @param request_dict: 请求参数
  572. @request_dict lang: 语言
  573. @request_dict app_bundle_id: app包id
  574. @request_dict version_number: app版本号
  575. @request_dict model: 设备类型
  576. @request_dict type: 设备型号
  577. @request_dict name: 设备名称
  578. @request_dict sort: 升序排序
  579. @request_dict file: 文件
  580. @param response: 响应对象
  581. @return:
  582. """
  583. # 添加APP设备类型
  584. app_bundle_id = request_dict.get(
  585. 'app_bundle_id', '')[
  586. 1:-1].split(',') # '[1,2]' -> ['1','2']
  587. # 版本号
  588. version_number = request_dict.get('version_number', None)
  589. # app_device_type表数据
  590. model = request_dict.get('model', None)
  591. type = request_dict.get('type', None)
  592. # device_name_language表数据
  593. lang = request_dict.get('lang', None)
  594. name = request_dict.get('name', None)
  595. sort = request_dict.get('sort', None)
  596. # 上传图标
  597. file = request.FILES.get('iconFile', None)
  598. fileName = file.name
  599. if not all([model, type, lang, name, sort, version_number]):
  600. return response.json(444, 'model, type, lang, name, sort, version_number')
  601. type = int(type)
  602. try:
  603. with transaction.atomic():
  604. app_bundle_qs = AppBundle.objects.filter(id__in=app_bundle_id,
  605. app_device_type__devicenamelanguage__lang=lang,
  606. app_device_type__app_version_number_id=version_number,
  607. app_device_type__type=type,
  608. app_device_type__model=model)
  609. # 数据是否重复
  610. if app_bundle_qs.exists():
  611. return response.json(174)
  612. # 是否存在相同的url
  613. response_url = 'https://ansjerfilemanager.s3.amazonaws.com/app/device_type_images/' + format(fileName)
  614. app_bundle_qs = AppDeviceType.objects.filter(appbundle__id__in=app_bundle_id, type=type, model=model)
  615. if not app_bundle_qs.exists():
  616. # 上传设备图标至存储桶
  617. bucket_name = 'ansjerfilemanager'
  618. file_key = 'app/device_type_images/{}'.format(fileName)
  619. s3 = AmazonS3Util(AWS_ACCESS_KEY_ID[1], AWS_SECRET_ACCESS_KEY[1], AWS_SES_ACCESS_REGION)
  620. # 地址:https://ansjerfilemanager.s3.amazonaws.com/app/device_type_images/camera_c190.png
  621. s3.upload_file_obj(
  622. bucket_name,
  623. file_key,
  624. file,
  625. {'ContentType': file.content_type, 'ACL': 'public-read'})
  626. # 创建
  627. for app_id in app_bundle_id:
  628. app_bundle_qs = AppBundle.objects.filter(id=app_id).values('id')
  629. app_device_type_qs = AppDeviceType.objects.create(model=model, type=type, icon=response_url,
  630. app_version_number_id=version_number)
  631. DeviceNameLanguage.objects.create(lang=lang, name=name, sort=sort,
  632. app_device_type_id=app_device_type_qs.id)
  633. # 关联app包
  634. app_device_type_qs.appbundle_set.add(app_bundle_qs[0]['id'])
  635. return response.json(0)
  636. except Exception as e:
  637. print(e)
  638. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  639. def get_device_icon(self, request_dict, response):
  640. """
  641. 查询设备信息图标
  642. @param request_dict: 请求参数
  643. @request_dict lang: 语言
  644. @request_dict app_bundle_id: app版本id
  645. @request_dict version_number: app版本号
  646. @param response: 响应对象
  647. @return:
  648. """
  649. lang = request_dict.get('lang', 'en')
  650. app_bundle_id = request_dict.get('appBundleId', None)
  651. version_number = request_dict.get('versionNumber', None)
  652. if not all([lang, app_bundle_id, version_number]):
  653. return response.json(444)
  654. try:
  655. version_number = list(map(int, version_number.split('.')))
  656. app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id).values(
  657. 'app_device_type__app_version_number_id').distinct().order_by('app_device_type__app_version_number_id')
  658. # 判断版本是否存在, 不存在则获取输入版本范围内最接近的输入版本
  659. version_number_list = []
  660. app_bundle_list = []
  661. id_list = []
  662. for version in app_bundle_qs:
  663. version = version['app_device_type__app_version_number_id']
  664. # 必须是版本号
  665. if len(version) > 3:
  666. version_parts = list(map(int, version.split('.')))
  667. if version_parts <= version_number:
  668. version_number_list.append(version)
  669. else:
  670. id_list.append(int(version))
  671. # app_device_type__app_version_number_id为AppVersionNumber的主键时
  672. version_list = []
  673. if len(version_number_list) == 0:
  674. version_qs = AppVersionNumber.objects.filter(
  675. id__in=id_list).values('version_number').distinct()
  676. for version in version_qs:
  677. version_qs = AppVersionNumber.objects.filter(version_number=version['version_number'],
  678. app_bundle__app_bundle_id=app_bundle_id).values('id')
  679. if not version_qs.exists():
  680. continue
  681. version_number_data = {
  682. version_qs[0]['id']: version['version_number']
  683. }
  684. version_list.append(version_number_data)
  685. for version in version_list:
  686. for k, v in version.items():
  687. version_parts = list(map(int, v.split('.')))
  688. if version_parts <= version_number:
  689. version_number_list.append(k)
  690. # 版本号对应的设备信息图标
  691. for version_number in version_number_list:
  692. app_bundle_qs = AppBundle.objects.filter(app_bundle_id=app_bundle_id,
  693. app_device_type__devicenamelanguage__lang=lang,
  694. app_device_type__app_version_number_id=version_number). \
  695. annotate(
  696. model=F('app_device_type__model'), type=F('app_device_type__type'), icon=F('app_device_type__icon'),
  697. name=F('app_device_type__devicenamelanguage__name'),
  698. sort=F('app_device_type__devicenamelanguage__sort'),
  699. app_version_number_id=F('app_device_type__app_version_number_id')).values('model', 'type', 'icon',
  700. 'name', 'sort',
  701. 'app_device_type__app_version_number_id')
  702. for app_bundle in app_bundle_qs:
  703. device_type = any(item['type'] == app_bundle['type'] for item in app_bundle_list)
  704. if device_type:
  705. break
  706. else:
  707. app_bundle_list.append({
  708. 'model': app_bundle['model'],
  709. 'type': app_bundle['type'],
  710. 'icon': app_bundle['icon'],
  711. 'name': app_bundle['name'],
  712. 'sort': app_bundle['sort'],
  713. 'app_device_type__app_version_number_id': app_bundle[
  714. 'app_device_type__app_version_number_id'],
  715. })
  716. # 去重
  717. dvr_list = [app_bundle for app_bundle in app_bundle_list if app_bundle['model'] == 1]
  718. ipc_list = [app_bundle for app_bundle in app_bundle_list if app_bundle['model'] == 2]
  719. res = {
  720. 'deviceDvr': sorted(dvr_list, key=operator.itemgetter('sort')),
  721. 'deviceIpc': sorted(ipc_list, key=operator.itemgetter('sort')),
  722. }
  723. return response.json(0, res)
  724. except Exception as e:
  725. print(e)
  726. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))