DeviceGroupController.py 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. # @Author : Rocky
  2. # @File : DeviceGroupController.py
  3. # @Time : 2025/1/22 9:51
  4. from django.db import transaction
  5. from django.db.models import Q
  6. from django.views import View
  7. from django.db.models import Count, Sum
  8. from Model.models import DeviceGroup, Device_Info
  9. from Service.CommonService import CommonService
  10. class DeviceGroupView(View):
  11. def get(self, request, *args, **kwargs):
  12. request.encoding = 'utf-8'
  13. operation = kwargs.get('operation')
  14. return self.validation(request.GET, request, operation)
  15. def post(self, request, *args, **kwargs):
  16. request.encoding = 'utf-8'
  17. operation = kwargs.get('operation')
  18. return self.validation(request.POST, request, operation)
  19. def validation(self, request_dict, request, operation):
  20. token_code, user_id, response = CommonService.verify_token_get_user_id(request_dict, request)
  21. if token_code != 0:
  22. return response.json(token_code)
  23. if operation == 'queryGroupQuantity': # 查询分组数量
  24. return self.query_group_quantity(request_dict, user_id, response)
  25. elif operation == 'queryGroupDevice': # 查询分组设备
  26. return self.query_group_device(request_dict, user_id, response)
  27. elif operation == 'queryOtherGroupDevice': # 查询其他分组设备
  28. return self.query_other_group_device(request_dict, user_id, response)
  29. elif operation == 'creat': # 创建分组
  30. return self.creat(request_dict, user_id, response)
  31. elif operation == 'update': # 重命名分组
  32. return self.update(request_dict, user_id, response)
  33. elif operation == 'delete': # 删除分组
  34. return self.delete(request_dict, user_id, response)
  35. elif operation == 'transferGroup': # 转移分组
  36. return self.transfer_group(request_dict, user_id, response)
  37. else:
  38. return response.json(414)
  39. @staticmethod
  40. def query_group_quantity(request_dict, user_id, response):
  41. """
  42. 查询分组数量
  43. @param request_dict: 请求参数
  44. @param user_id: 用户ID
  45. @param response: 响应对象
  46. @return: res 包含分组信息和设备总数的响应
  47. """
  48. # 一次查询获取所有分组及对应的设备数量
  49. device_group_qs = DeviceGroup.objects.filter(user_id=user_id) \
  50. .annotate(device_quantity=Count('device_info', distinct=True)) \
  51. .values('id', 'group_name', 'device_quantity')
  52. # 计算设备总数
  53. total_result = device_group_qs.aggregate(total=Sum('device_quantity'))
  54. device_total = total_result['total'] or 0 # 处理没有分组的情况
  55. res = {
  56. 'total': device_total,
  57. 'device_groups': list(device_group_qs) # 直接转换为列表
  58. }
  59. return response.json(0, res)
  60. @staticmethod
  61. def query_group_device(request_dict, user_id, response):
  62. """
  63. 查询分组设备
  64. @param request_dict:
  65. @param user_id:
  66. @param response:
  67. @return: res
  68. """
  69. device_group_id = request_dict.get('device_group_id', None)
  70. if not device_group_id:
  71. return response.json(444)
  72. device_info_qs = Device_Info.objects.filter(device_group_id=device_group_id).values('NickName', 'Type')
  73. if not device_info_qs.exists():
  74. return response.json(0, [])
  75. res = list(device_info_qs)
  76. return response.json(0, res)
  77. @staticmethod
  78. def query_other_group_device(request_dict, user_id, response):
  79. """
  80. 查询其他分组设备
  81. @param request_dict:
  82. @param user_id:
  83. @param response:
  84. @return: res
  85. """
  86. device_group_id = request_dict.get('device_group_id', None)
  87. if not device_group_id:
  88. return response.json(444)
  89. try:
  90. res = []
  91. # 查询全部设备
  92. if device_group_id != '0':
  93. device_info_qs = Device_Info.objects.filter(~Q(device_group_id=device_group_id), userID=user_id). \
  94. values('id', 'NickName', 'Type')
  95. if device_info_qs.exists():
  96. data = {
  97. 'id': 0,
  98. 'group_name': 'all'
  99. }
  100. device_info_list = []
  101. for device_info in device_info_qs:
  102. device_info_list.append(device_info)
  103. data['device_info_list'] = device_info_list
  104. res.append(data)
  105. # 查询设备数量不为0的其他分组
  106. device_group_qs = DeviceGroup.objects.filter(~Q(id=device_group_id), user_id=user_id). \
  107. values('id', 'group_name')
  108. if device_group_qs.exists():
  109. # 查询各组的设备id和昵称
  110. for device_group in device_group_qs:
  111. device_info_list = []
  112. device_info_qs = Device_Info.objects.filter(device_group_id=device_group['id']). \
  113. values('id', 'NickName', 'Type')
  114. for device_info in device_info_qs:
  115. device_info_list.append(device_info)
  116. device_group['device_info_list'] = device_info_list
  117. res.append(device_group)
  118. return response.json(0, res)
  119. except Exception as e:
  120. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  121. @staticmethod
  122. def creat(request_dict, user_id, response):
  123. """
  124. 创建分组
  125. @param request_dict:
  126. @param user_id:
  127. @param response:
  128. @return: res
  129. """
  130. group_name = request_dict.get('group_name', None)
  131. if not group_name:
  132. return response.json(444)
  133. # 该用户已存在该组名的分组
  134. device_group_qs = DeviceGroup.objects.filter(user_id=user_id, group_name=group_name)
  135. if device_group_qs.exists():
  136. return response.json(174)
  137. DeviceGroup.objects.create(user_id=user_id, group_name=group_name)
  138. return response.json(0)
  139. @staticmethod
  140. def update(request_dict, user_id, response):
  141. """
  142. 重命名分组
  143. @param request_dict:
  144. @param user_id:
  145. @param response:
  146. @return: res
  147. """
  148. device_group_id = request_dict.get('device_group_id', None)
  149. group_name = request_dict.get('group_name', None)
  150. if not all([device_group_id, group_name]):
  151. return response.json(444)
  152. # 该用户已存在该组名的分组
  153. device_group_qs = DeviceGroup.objects.filter(user_id=user_id, group_name=group_name)
  154. if device_group_qs.exists():
  155. return response.json(174)
  156. DeviceGroup.objects.filter(id=device_group_id).update(group_name=group_name)
  157. return response.json(0)
  158. @staticmethod
  159. def delete(request_dict, user_id, response):
  160. """
  161. 删除分组
  162. @param request_dict:
  163. @param user_id:
  164. @param response:
  165. @return: res
  166. """
  167. device_group_id = request_dict.get('device_group_id', None)
  168. if not device_group_id:
  169. return response.json(444)
  170. try:
  171. device_group_id = int(device_group_id)
  172. with transaction.atomic():
  173. # 删除设备分组数据,重置设备信息表的分组id
  174. DeviceGroup.objects.filter(id=device_group_id).delete()
  175. Device_Info.objects.filter(device_group_id=device_group_id).update(device_group_id=0)
  176. return response.json(0)
  177. except Exception as e:
  178. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  179. @staticmethod
  180. def transfer_group(request_dict, user_id, response):
  181. """
  182. 转移分组
  183. @param request_dict:
  184. @param user_id:
  185. @param response:
  186. @return: res
  187. """
  188. device_group_id = request_dict.get('device_group_id', None)
  189. device_id_list = request_dict.get('device_id_list', None)
  190. if not all([device_group_id, device_id_list]):
  191. return response.json(444)
  192. try:
  193. device_group_id = int(device_group_id)
  194. device_id_list = device_id_list.split(',')
  195. # 更新设备信息表的分组id
  196. Device_Info.objects.filter(id__in=device_id_list).update(device_group_id=device_group_id)
  197. return response.json(0)
  198. except Exception as e:
  199. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))