DeviceManagementController.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306
  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
  8. from Ansjer.config import OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET
  9. from Object.ResponseObject import ResponseObject
  10. from Object.TokenObject import TokenObject
  11. from django.views.generic.base import View
  12. from Service.EquipmentInfoService import EquipmentInfoService
  13. from Service.ModelService import ModelService
  14. from Service.CommonService import CommonService
  15. from Model.models import Device_Info, UidSetModel, LogModel, UID_Bucket, Unused_Uid_Meal, Order_Model, StsCrdModel, \
  16. VodHlsModel, ExperienceContextModel, DeviceTypeModel, Equipment_Info, UidUserModel
  17. class DeviceManagement(View):
  18. def get(self, request, *args, **kwargs):
  19. request.encoding = 'utf-8'
  20. operation = kwargs.get('operation')
  21. return self.validation(request.GET, request, operation)
  22. def post(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. operation = kwargs.get('operation')
  25. return self.validation(request.POST, request, operation)
  26. def validation(self, request_dict, request, operation):
  27. language = request_dict.get('language', 'en')
  28. response = ResponseObject(language, 'pc')
  29. if operation == 'addDeviceType':
  30. return self.addDeviceType(request, request_dict, response)
  31. elif operation == 'delDeviceData':
  32. return self.delDeviceData(request_dict, response)
  33. else:
  34. tko = TokenObject(
  35. request.META.get('HTTP_AUTHORIZATION'),
  36. returntpye='pc')
  37. if tko.code != 0:
  38. return response.json(tko.code)
  39. response.lang = tko.lang
  40. userID = tko.userID
  41. if not userID:
  42. return response.json(444, 'userID')
  43. if operation == 'getDeviceInfoList':
  44. return self.getDeviceInfoList(request_dict, response)
  45. elif operation == 'deleteDevice':
  46. return self.deleteDevice(request_dict, response)
  47. elif operation == 'resetVod':
  48. return self.resetVod(request, request_dict, response)
  49. elif operation == 'resetPrimaryUser':
  50. return self.resetPrimaryUser(request, request_dict, response)
  51. elif operation == 'getDeviceTypeList':
  52. return self.getDeviceTypeList(request_dict, response)
  53. elif operation == 'deleteDeviceType':
  54. return self.deleteDeviceType(request_dict, response)
  55. else:
  56. return response.json(444, 'operation')
  57. # 获取设备信息数据
  58. def getDeviceInfoList(self, request_dict, response):
  59. pageNo = request_dict.get('pageNo', None)
  60. pageSize = request_dict.get('pageSize', None)
  61. UID = request_dict.get('UID', None)
  62. serialNumber = request_dict.get('serialNumber', None)
  63. NickName = request_dict.get('NickName', None)
  64. username = request_dict.get('username', None)
  65. if not all([pageNo, pageSize]):
  66. return response.json(444)
  67. page = int(pageNo)
  68. line = int(pageSize)
  69. try:
  70. if UID or serialNumber or NickName or username: # 条件查询
  71. if UID:
  72. device_info_qs = Device_Info.objects.filter(UID__contains=UID)
  73. if serialNumber:
  74. device_info_qs = Device_Info.objects.filter(serial_number__contains=serialNumber)
  75. if NickName:
  76. device_info_qs = Device_Info.objects.filter(NickName__contains=NickName)
  77. if username:
  78. device_info_qs = Device_Info.objects.filter(Q(userID__username__contains=username) |
  79. Q(userID__userEmail__contains=username) |
  80. Q(userID__phone__contains=username))
  81. total = len(device_info_qs)
  82. if not total:
  83. return response.json(0, {'list': {}, 'total': 0})
  84. device_info_qs = device_info_qs[(page - 1) * line:page * line]
  85. else: # 查询全部
  86. total = Device_Info.objects.filter().count()
  87. device_info_qs = Device_Info.objects.filter()[(page - 1) * line:page * line]
  88. if not device_info_qs.exists():
  89. return response.json(0, {'list': {}, 'total': 0})
  90. device_info_list = CommonService.qs_to_dict(device_info_qs)
  91. for k, v in enumerate(device_info_list["datas"]):
  92. for device_info in device_info_qs:
  93. if v['pk'] == device_info.id:
  94. # 设备的用户名和主用户
  95. username = ModelService.get_user_name(device_info_list["datas"][k]['fields']['userID'])
  96. device_info_list["datas"][k]['fields']['username'] = username
  97. device_info_list["datas"][k]['fields']['vodPrimaryMaster'] = device_info_list["datas"][k]['fields']['vodPrimaryMaster']
  98. # 设备类型,是否支持Alexa和ip
  99. type = device_info_list["datas"][k]['fields']['Type']
  100. device_type_qs = DeviceTypeModel.objects.filter(type=type).values('name')
  101. if device_type_qs.exists():
  102. device_info_list["datas"][k]['fields']['Type'] = device_type_qs[0]['name']
  103. uid_set_qs = UidSetModel.objects.filter(uid=device_info_list["datas"][k]['fields']['UID']).values('is_alexa', 'ip')
  104. if uid_set_qs.exists():
  105. isAlexa = '是' if uid_set_qs[0]['is_alexa'] else '否'
  106. device_info_list["datas"][k]['fields']['isAlexa'] = isAlexa
  107. device_info_list["datas"][k]['fields']['ip'] = uid_set_qs[0]['ip']
  108. return response.json(0, {'list': device_info_list, 'total': total})
  109. except Exception as e:
  110. print(e)
  111. return response.json(500, repr(e))
  112. # 根据id删除设备
  113. def deleteDevice(self, request_dict, response):
  114. deviceID = request_dict.get('deviceID', None)
  115. userID = request_dict.get('userID', None)
  116. uid = request_dict.get('uid', None)
  117. if not all([deviceID, userID, uid]):
  118. return response.json(444)
  119. try:
  120. with transaction.atomic():
  121. Device_Info.objects.filter(id=deviceID).delete()
  122. # 删除推送消息
  123. for val in range(1, 8):
  124. EquipmentInfoService.get_equipment_info_model('', val).\
  125. filter(device_user_id=userID, device_uid=uid).delete()
  126. return response.json(0)
  127. except Exception as e:
  128. print(e)
  129. return response.json(500, repr(e))
  130. # 重置设备主用户
  131. def resetPrimaryUser(self, request, request_dict, response):
  132. uid = request_dict.get('uid', None)
  133. if not uid:
  134. return response.json(404)
  135. try:
  136. # 记录操作日志
  137. ip = CommonService.get_ip_address(request)
  138. content = json.loads(json.dumps(request_dict))
  139. log = {
  140. 'ip': ip,
  141. 'user_id': 2,
  142. 'status': 200,
  143. 'time': int(time.time()),
  144. 'url': 'deviceManagement/resetPrimaryUser',
  145. 'content': json.dumps(content),
  146. 'operation': '{}重置设备主用户'.format(uid),
  147. }
  148. LogModel.objects.create(**log)
  149. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  150. return response.json(0)
  151. except Exception as e:
  152. return response.json(500, repr(e))
  153. # 重置设备云存
  154. def resetVod(self, request, request_dict, response):
  155. uid = request_dict.get('uid', None)
  156. if not uid:
  157. return response.json(444)
  158. try:
  159. # 记录操作日志
  160. ip = CommonService.get_ip_address(request)
  161. content = json.loads(json.dumps(request_dict))
  162. log = {
  163. 'ip': ip,
  164. 'user_id': 2,
  165. 'status': 200,
  166. 'time': int(time.time()),
  167. 'url': 'deviceManagement/resetVod',
  168. 'content': json.dumps(content),
  169. 'operation': '{}重置设备云存'.format(uid),
  170. }
  171. with transaction.atomic():
  172. LogModel.objects.create(**log)
  173. # 删除和更新设备云存相关数据
  174. UID_Bucket.objects.filter(uid=uid).delete()
  175. Unused_Uid_Meal.objects.filter(uid=uid).delete()
  176. Order_Model.objects.filter(UID=uid).delete()
  177. StsCrdModel.objects.filter(uid=uid).delete()
  178. VodHlsModel.objects.filter(uid=uid).delete()
  179. ExperienceContextModel.objects.filter(uid=uid).delete()
  180. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  181. return response.json(0)
  182. except Exception as e:
  183. print(e)
  184. return response.json(500, repr(e))
  185. # 获取设备类型数据
  186. def getDeviceTypeList(self, request_dict, response):
  187. name = request_dict.get('name', None)
  188. pageNo = request_dict.get('pageNo', None)
  189. pageSize = request_dict.get('pageSize', None)
  190. if not all([pageNo, pageSize]):
  191. return response.json(444)
  192. page = int(pageNo)
  193. line = int(pageSize)
  194. try:
  195. if name:
  196. device_type_qs = DeviceTypeModel.objects.filter(name__contains=name).values()
  197. total = len(device_type_qs)
  198. else:
  199. device_type_qs = DeviceTypeModel.objects.filter().values()[(page - 1) * line:page * line]
  200. total = DeviceTypeModel.objects.filter().count()
  201. if not device_type_qs.exists():
  202. return response.json(173)
  203. device_type_list = []
  204. for device_type in device_type_qs:
  205. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  206. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
  207. icon = device_type['icon']
  208. url = 'device_type/' + icon
  209. device_type['icon'] = bucket.sign_url('GET', url, 3600)
  210. device_type_list.append(device_type)
  211. return response.json(0, {'list': device_type_list, 'total': total})
  212. except Exception as e:
  213. print(e)
  214. return response.json(500, repr(e))
  215. # 删除设备类型
  216. def deleteDeviceType(self, request_dict, response):
  217. deviceTypeID = request_dict.get('deviceTypeID', None)
  218. if not deviceTypeID:
  219. return response.json(444)
  220. try:
  221. DeviceTypeModel.objects.filter(id=deviceTypeID).delete()
  222. return response.json(0)
  223. except Exception as e:
  224. print(e)
  225. return response.json(500, repr(e))
  226. # 添加设备类型
  227. def addDeviceType(self, request, request_dict, response):
  228. iconFile = request.FILES.get('iconFile', None)
  229. name = request_dict.get('name', None)
  230. model = request_dict.get('model', None)
  231. type = request_dict.get('type', None)
  232. ptz_type = request_dict.get('ptz_type', None)
  233. if not all([iconFile, name, model, type, ptz_type]):
  234. return response.json(444)
  235. try:
  236. model = int(model)
  237. ptz_type = int(ptz_type)
  238. icon = iconFile.name
  239. now_time = int(time.time())
  240. # 上传文件到阿里云OSS
  241. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  242. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'ansjer-static-resources')
  243. key = 'device_type/' + icon # 图片文件存放于 device_type 目录下
  244. # https://oss.console.aliyun.com/bucket/oss-cn-shenzhen/ansjer-static-resources/object?path=device_type%2F
  245. bucket.put_object(key=key, data=iconFile)
  246. DeviceTypeModel.objects.create(name=name, model=model, type=type, ptz_type=ptz_type, icon=icon,
  247. add_time=now_time, update_time=now_time)
  248. return response.json(0)
  249. except Exception as e:
  250. print(e)
  251. return response.json(500, repr(e))
  252. # 删除设备数据
  253. def delDeviceData(self, request_dict, response):
  254. uidList = request_dict.get('uidList', None)
  255. delDataOptions = request_dict.get('delDataOptions', None)
  256. if not all([uidList, delDataOptions]):
  257. return response.json(444)
  258. try:
  259. with transaction.atomic():
  260. uidList = uidList.splitlines() # 按行('\r', '\r\n', \n')切割字符串返回列表
  261. # 根据删除项删除相关数据
  262. if '设备信息数据' in delDataOptions:
  263. Device_Info.objects.filter(UID__in=uidList).delete()
  264. if '设备配置数据' in delDataOptions:
  265. UidSetModel.objects.filter(uid__in=uidList).delete()
  266. if '设备推送数据' in delDataOptions:
  267. Equipment_Info.objects.filter(devUid__in=uidList).delete()
  268. if '设备AP信息数据' in delDataOptions:
  269. UidUserModel.objects.filter(UID__in=uidList).delete()
  270. if '设备云存数据' in delDataOptions:
  271. UID_Bucket.objects.filter(uid__in=uidList).delete()
  272. Unused_Uid_Meal.objects.filter(uid__in=uidList).delete()
  273. Order_Model.objects.filter(UID__in=uidList).delete()
  274. StsCrdModel.objects.filter(uid__in=uidList).delete()
  275. VodHlsModel.objects.filter(uid__in=uidList).delete()
  276. ExperienceContextModel.objects.filter(uid__in=uidList).delete()
  277. Device_Info.objects.filter(UID__in=uidList).update(vodPrimaryUserID='', vodPrimaryMaster='')
  278. return response.json(0)
  279. except Exception as e:
  280. print(e)
  281. return response.json(500, repr(e))