DeviceGroupController.py 8.3 KB

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