GatewayFamilyRoomController.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308
  1. # -*- encoding: utf-8 -*-
  2. """
  3. @File : GatewayFamilyRoomController.py
  4. @Time : 2022/5/24 19:43
  5. @Author : stephen
  6. @Email : zhangdongming@asj6.wecom.work
  7. @Software: PyCharm
  8. """
  9. from django.db import transaction
  10. from django.db.models import Q, Count, F
  11. from django.views.generic.base import View
  12. from Controller.SensorGateway.EquipmentFamilyController import EquipmentFamilyView
  13. from Model.models import FamilyRoomDevice, FamilyRoom, GatewaySubDevice, Device_Info
  14. from Object.ResponseObject import ResponseObject
  15. from Object.TokenObject import TokenObject
  16. # 家庭房间管理
  17. class GatewayFamilyRoomView(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. token = request.META.get('HTTP_AUTHORIZATION')
  28. token = TokenObject(token)
  29. lang = request_dict.get('lang', token.lang)
  30. response = ResponseObject(lang)
  31. if token.code != 0:
  32. return response.json(token.code)
  33. app_user_id = token.userID
  34. # 添加设备关联房间
  35. if operation == 'device-changes':
  36. return self.room_device_save(app_user_id, request_dict, response)
  37. # 房间排序
  38. elif operation == 'sort':
  39. return self.room_sort_save(request_dict, response)
  40. # 房间删除
  41. elif operation == 'del':
  42. return self.room_del(app_user_id, request_dict, response)
  43. # 房间详情
  44. elif operation == 'details':
  45. return self.get_room_details(app_user_id, request_dict, response)
  46. elif operation == 'all-devices': # 家庭所有设备
  47. return self.all_devices(request_dict, response)
  48. elif operation == 'devices-sort': # 家庭设备排序
  49. return self.devices_sort(request_dict, response)
  50. else:
  51. return response.json(414)
  52. @classmethod
  53. def room_device_save(cls, app_user_id, request_dict, response):
  54. """
  55. 房间加入设备or移除设备
  56. @param app_user_id:
  57. @param request_dict:
  58. @param response:
  59. @return:
  60. """
  61. family_id = request_dict.get('familyId', None)
  62. device_ids = request_dict.get('deviceIds', None)
  63. room_id = request_dict.get('roomId', None)
  64. if not all([family_id, room_id]):
  65. return response.json(444)
  66. family_id = int(family_id)
  67. room_id = int(room_id)
  68. is_owner = EquipmentFamilyView.get_family_owner(app_user_id, family_id)
  69. if not is_owner:
  70. return response.json(404)
  71. try:
  72. with transaction.atomic():
  73. room_qs = FamilyRoom.objects.filter(family_id=family_id, id=room_id)
  74. if not room_qs.exists():
  75. return response.json(173)
  76. qs = FamilyRoomDevice.objects.filter(family_id=family_id, room_id=room_id)
  77. if qs.exists():
  78. qs.update(room_id=0, sort=0)
  79. if device_ids:
  80. device_ids = eval(device_ids)
  81. for i, item in enumerate(device_ids):
  82. device_id = item['id']
  83. device_type = item['type']
  84. device_qs = Device_Info.objects.filter(id=device_id, Type=device_type)
  85. if device_qs.exists():
  86. room_device_qs = FamilyRoomDevice.objects.filter(device_id=device_id)
  87. else:
  88. room_device_qs = FamilyRoomDevice.objects.filter(sub_device=device_id)
  89. if room_device_qs.exists():
  90. room_device_qs.update(room_id=room_id, sort=i)
  91. return response.json(0)
  92. except Exception as e:
  93. print(e)
  94. return response.json(177, repr(e))
  95. @classmethod
  96. def room_del(cls, user_id, request_dict, response):
  97. """
  98. 房间多选删除
  99. @param user_id: 当前登录用户id
  100. @param request_dict: 请求参数
  101. @param response: 响应参数
  102. @return:
  103. """
  104. ids = request_dict.get('roomIds', None)
  105. if not ids:
  106. return response.json(444)
  107. ids = ids.split(',')
  108. room_id = ids[0]
  109. room_info = FamilyRoom.objects.filter(id=room_id)
  110. if not room_info.exists():
  111. return response.json(173)
  112. is_owner = EquipmentFamilyView.get_family_owner(user_id, room_info.first().family_id)
  113. if not is_owner:
  114. return response.json(404)
  115. try:
  116. with transaction.atomic():
  117. for item in ids:
  118. room_id = int(item)
  119. room_device = FamilyRoomDevice.objects.filter(room_id=room_id)
  120. if room_device.exists():
  121. room_device.update(room_id=0)
  122. FamilyRoom.objects.filter(id=room_id).delete()
  123. return response.json(0)
  124. except Exception as e:
  125. print(e)
  126. return response.json(177, repr(e))
  127. @classmethod
  128. def room_sort_save(cls, request_dict, response):
  129. """
  130. 房间排序
  131. @param request_dict: 请求参数
  132. @param response: 响应参数
  133. @return:
  134. """
  135. ids = request_dict.get('ids', None)
  136. if not ids:
  137. return response.json(444)
  138. items = ids.split(',')
  139. for item in items:
  140. item = item.split('-')
  141. room_id, sort = item[0], item[1]
  142. family_room = FamilyRoom.objects.filter(id=int(room_id))
  143. if family_room.exists():
  144. family_room.update(sort=int(sort))
  145. return response.json(0)
  146. @classmethod
  147. def get_room_details(cls, app_user_id, request_dict, response):
  148. """
  149. 房间设备详情(所在当前房间下,和所在家庭不在当前房间下的主设备)
  150. @param app_user_id:
  151. @param request_dict:
  152. @param response:
  153. @return:
  154. """
  155. family_id = request_dict.get('familyId', None)
  156. room_id = request_dict.get('roomId', None)
  157. if not all([family_id, room_id]):
  158. return response.json(444)
  159. is_owner = EquipmentFamilyView.get_family_owner(app_user_id, family_id)
  160. if not is_owner:
  161. return response.json(404)
  162. family_id = int(family_id)
  163. room_id = int(room_id)
  164. room_device_qs = FamilyRoomDevice.objects.filter(family_id=family_id, room_id=room_id).order_by('sort').values(
  165. 'device_id', 'device__Type', 'device__NickName', 'sub_device')
  166. device_room = []
  167. if room_device_qs.exists():
  168. room_name = FamilyRoom.objects.filter(id=room_id)
  169. for item in room_device_qs:
  170. if not item['sub_device']:
  171. device_dict = {
  172. 'deviceId': item['device_id'],
  173. 'deviceType': item['device__Type'],
  174. 'nickName': item['device__NickName'],
  175. 'roomName': room_name.first().name if room_name.exists() else '',
  176. }
  177. else:
  178. sub_device_qs = GatewaySubDevice.objects.filter(id=item['sub_device']).values('id',
  179. 'device_type',
  180. 'nickname')
  181. device_dict = {
  182. 'deviceId': sub_device_qs[0]['id'],
  183. 'deviceType': sub_device_qs[0]['device_type'],
  184. 'nickName': sub_device_qs[0]['nickname'],
  185. 'roomName': room_name.first().name if room_name.exists() else '',
  186. }
  187. device_room.append(device_dict)
  188. device_not_room = []
  189. device_not_room_qs = FamilyRoomDevice.objects.filter(family_id=family_id)
  190. device_not_room_qs = device_not_room_qs.filter(~Q(room_id=room_id)).values('device_id').annotate(
  191. count=Count('device_id')).values('room_id', 'device_id', 'device__Type', 'device__NickName')
  192. if device_not_room_qs.exists():
  193. for item in device_not_room_qs:
  194. name = ''
  195. if room_device_qs.exists():
  196. family_room_qs = FamilyRoom.objects.filter(id=item['room_id'])
  197. if family_room_qs.exists():
  198. name = family_room_qs.first().name
  199. device_not_room.append({
  200. 'deviceId': item['device_id'],
  201. 'deviceType': item['device__Type'],
  202. 'nickName': item['device__NickName'],
  203. 'roomName': name
  204. })
  205. return response.json(0, {'deviceRooms': device_room, 'deviceNotRooms': device_not_room})
  206. @staticmethod
  207. def all_devices(request_dict, response):
  208. """
  209. 家庭所有设备(网关和摄像头设备)
  210. @param request_dict: 请求参数
  211. @request_dict familyId: 家庭id
  212. @param response: 响应参数
  213. @return:
  214. """
  215. family_id = request_dict.get('familyId', None)
  216. if not family_id:
  217. return response.json(444)
  218. try:
  219. family_room_device_qs = FamilyRoomDevice.objects.filter(family_id=family_id).values('device_id',
  220. 'device__Type',
  221. 'device__NickName',
  222. 'room_id',
  223. 'sub_device').order_by(
  224. 'sort')
  225. if not family_room_device_qs.exists():
  226. return response.json(0, [])
  227. gateways = []
  228. cameras = []
  229. # 查询房间名称
  230. for device in family_room_device_qs:
  231. room_id = device['room_id']
  232. device_type = device['device__Type']
  233. room_name = FamilyRoom.objects.filter(id=room_id)
  234. if device_type == 200: # 网关设备
  235. if not device['sub_device']:
  236. device_dict = {
  237. 'deviceId': device['device_id'],
  238. 'deviceType': device_type,
  239. 'nickName': device['device__NickName'],
  240. 'roomName': room_name.first().name if room_name.exists() else '',
  241. }
  242. else:
  243. sub_device_qs = GatewaySubDevice.objects.filter(id=device['sub_device']).values('device_type',
  244. 'nickname')
  245. device_dict = {
  246. 'deviceId': device['sub_device'],
  247. 'deviceType': sub_device_qs[0]['device_type'],
  248. 'nickName': sub_device_qs[0]['nickname'],
  249. 'roomName': room_name.first().name if room_name.exists() else '',
  250. }
  251. gateways.append(device_dict)
  252. else: # 摄像头设备
  253. cameras.append({
  254. 'deviceId': device['device_id'],
  255. 'deviceType': device_type,
  256. 'nickName': device['device__NickName'],
  257. 'roomName': room_name.first().name if room_name.exists() else '',
  258. })
  259. device_room = {
  260. 'gateways': gateways,
  261. 'cameras': cameras
  262. }
  263. return response.json(0, device_room)
  264. except Exception as e:
  265. return response.json(500, repr(e))
  266. @staticmethod
  267. def devices_sort(request_dict, response):
  268. """
  269. 家庭设备排序
  270. @param request_dict: 请求参数
  271. @request_dict 设备id: deviceIds
  272. @param response: 响应参数
  273. @return:
  274. """
  275. device_ids = request_dict.get('deviceIds', None)
  276. if not device_ids:
  277. return response.json(444)
  278. try:
  279. device_ids = eval(device_ids)
  280. with transaction.atomic():
  281. for i, item in enumerate(device_ids):
  282. device_id = item['id']
  283. device_type = item['type']
  284. device_qs = Device_Info.objects.filter(id=device_id, Type=device_type)
  285. if device_qs.exists(): # 更新主设备排序
  286. FamilyRoomDevice.objects.filter(device_id=device_id).update(sort=i)
  287. else: # 更新子设备排序
  288. FamilyRoomDevice.objects.filter(sub_device=device_id).update(sort=i)
  289. return response.json(0)
  290. except Exception as e:
  291. return response.json(500, repr(e))