DeviceManagementController.py 23 KB

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