123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 |
- # -*- encoding: utf-8 -*-
- """
- @File : GatewayFamilyRoomController.py
- @Time : 2022/5/24 19:43
- @Author : stephen
- @Email : zhangdongming@asj6.wecom.work
- @Software: PyCharm
- """
- from django.db import transaction
- from django.db.models import Q, Count
- from django.views.generic.base import View
- from Controller.SensorGateway.EquipmentFamilyController import EquipmentFamilyView
- from Model.models import FamilyRoomDevice, FamilyRoom, GatewaySubDevice, Device_Info
- from Object.ResponseObject import ResponseObject
- from Object.TokenObject import TokenObject
- # 家庭房间管理
- class GatewayFamilyRoomView(View):
- def get(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.GET, request, operation)
- def post(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.POST, request, operation)
- def validation(self, request_dict, request, operation):
- token = request.META.get('HTTP_AUTHORIZATION')
- token = TokenObject(token)
- lang = request_dict.get('lang', token.lang)
- response = ResponseObject(lang)
- if token.code != 0:
- return response.json(token.code)
- app_user_id = token.userID
- # 添加设备关联房间
- if operation == 'device-changes':
- return self.room_device_save(app_user_id, request_dict, response)
- # 房间排序
- elif operation == 'sort':
- return self.room_sort_save(request_dict, response)
- # 房间删除
- elif operation == 'del':
- return self.room_del(app_user_id, request_dict, response)
- # 房间详情
- elif operation == 'details':
- return self.get_room_details(app_user_id, request_dict, response)
- elif operation == 'all-devices': # 家庭所有设备
- return self.all_devices(request_dict, response)
- elif operation == 'devices-sort': # 家庭设备排序
- return self.devices_sort(request_dict, response)
- elif operation == 'device-category': # 获取设备类别
- return self.device_category(request_dict, response)
- elif operation == 'category-sort': # 设备类别排序
- return self.category_sort(request_dict, response)
- else:
- return response.json(414)
- @classmethod
- def room_device_save(cls, app_user_id, request_dict, response):
- """
- 房间加入设备or移除设备
- @param app_user_id:
- @param request_dict:
- @param response:
- @return:
- """
- family_id = request_dict.get('familyId', None)
- device_ids = request_dict.get('deviceIds', None)
- room_id = request_dict.get('roomId', None)
- if not all([family_id, room_id]):
- return response.json(444)
- family_id = int(family_id)
- room_id = int(room_id)
- is_owner = EquipmentFamilyView.get_family_owner(app_user_id, family_id)
- if not is_owner:
- return response.json(404)
- try:
- with transaction.atomic():
- room_qs = FamilyRoom.objects.filter(family_id=family_id, id=room_id)
- if not room_qs.exists():
- return response.json(173)
- qs = FamilyRoomDevice.objects.filter(family_id=family_id, room_id=room_id)
- if qs.exists():
- qs.update(room_id=0, sort=0)
- if device_ids:
- device_ids = eval(device_ids)
- for i, item in enumerate(device_ids):
- device_id = item['id']
- device_type = item['type']
- device_qs = Device_Info.objects.filter(id=device_id, Type=device_type)
- if device_qs.exists():
- room_device_qs = FamilyRoomDevice.objects.filter(device_id=device_id)
- else:
- room_device_qs = FamilyRoomDevice.objects.filter(sub_device=device_id)
- if room_device_qs.exists():
- room_device_qs.update(room_id=room_id, sort=i)
- return response.json(0)
- except Exception as e:
- print(e)
- return response.json(177, repr(e))
- @classmethod
- def room_del(cls, user_id, request_dict, response):
- """
- 房间多选删除
- @param user_id: 当前登录用户id
- @param request_dict: 请求参数
- @param response: 响应参数
- @return:
- """
- ids = request_dict.get('roomIds', None)
- if not ids:
- return response.json(444)
- ids = ids.split(',')
- room_id = ids[0]
- room_info = FamilyRoom.objects.filter(id=room_id)
- if not room_info.exists():
- return response.json(173)
- is_owner = EquipmentFamilyView.get_family_owner(user_id, room_info.first().family_id)
- if not is_owner:
- return response.json(404)
- try:
- with transaction.atomic():
- for item in ids:
- room_id = int(item)
- room_device = FamilyRoomDevice.objects.filter(room_id=room_id)
- if room_device.exists():
- room_device.update(room_id=0)
- FamilyRoom.objects.filter(id=room_id).delete()
- return response.json(0)
- except Exception as e:
- print(e)
- return response.json(177, repr(e))
- @classmethod
- def room_sort_save(cls, request_dict, response):
- """
- 房间排序
- @param request_dict: 请求参数
- @param response: 响应参数
- @return:
- """
- ids = request_dict.get('ids', None)
- if not ids:
- return response.json(444)
- items = ids.split(',')
- for item in items:
- item = item.split('-')
- room_id, sort = item[0], item[1]
- family_room = FamilyRoom.objects.filter(id=int(room_id))
- if family_room.exists():
- family_room.update(sort=int(sort))
- return response.json(0)
- @classmethod
- def get_room_details(cls, app_user_id, request_dict, response):
- """
- 房间设备详情(所在当前房间下,和所在家庭不在当前房间下的主设备)
- @param app_user_id:
- @param request_dict:
- @param response:
- @return:
- """
- family_id = request_dict.get('familyId', None)
- room_id = request_dict.get('roomId', None)
- if not all([family_id, room_id]):
- return response.json(444)
- is_owner = EquipmentFamilyView.get_family_owner(app_user_id, family_id)
- if not is_owner:
- return response.json(404)
- family_id = int(family_id)
- room_id = int(room_id)
- room_device_qs = FamilyRoomDevice.objects.filter(family_id=family_id, room_id=room_id).values(
- 'device_id', 'device__Type', 'device__NickName', 'sub_device').order_by('sort', '-device__data_joined')
- device_room = []
- if room_device_qs.exists():
- room_name = FamilyRoom.objects.filter(id=room_id)
- for item in room_device_qs:
- if not item['sub_device']:
- device_dict = {
- 'deviceId': item['device_id'],
- 'deviceType': item['device__Type'],
- 'nickName': item['device__NickName'],
- 'roomName': room_name.first().name if room_name.exists() else '',
- }
- else:
- sub_device_qs = GatewaySubDevice.objects.filter(id=item['sub_device']).values('id',
- 'device_type',
- 'nickname')
- if not sub_device_qs.exists():
- continue
- device_dict = {
- 'deviceId': sub_device_qs[0]['id'],
- 'deviceType': sub_device_qs[0]['device_type'],
- 'nickName': sub_device_qs[0]['nickname'],
- 'roomName': room_name.first().name if room_name.exists() else '',
- }
- device_room.append(device_dict)
- device_not_room = []
- device_not_room_qs = FamilyRoomDevice.objects.filter(family_id=family_id)
- device_not_room_qs = device_not_room_qs.filter(~Q(room_id=room_id)).values('room_id', 'device_id',
- 'device__Type', 'device__NickName',
- 'sub_device').order_by('sort',
- '-device__data_joined')
- if device_not_room_qs.exists():
- for item in device_not_room_qs:
- name = ''
- family_room_qs = FamilyRoom.objects.filter(id=item['room_id'])
- if family_room_qs.exists():
- name = family_room_qs.first().name
- if not item['sub_device']:
- device_not_room.append({
- 'deviceId': item['device_id'],
- 'deviceType': item['device__Type'],
- 'nickName': item['device__NickName'],
- 'roomName': name
- })
- else:
- sub_device_qs = GatewaySubDevice.objects.filter(id=item['sub_device']).values('id',
- 'device_type',
- 'nickname')
- if not sub_device_qs.exists():
- continue
- device_not_room.append({
- 'deviceId': sub_device_qs[0]['id'],
- 'deviceType': sub_device_qs[0]['device_type'],
- 'nickName': sub_device_qs[0]['nickname'],
- 'roomName': name
- })
- return response.json(0, {'deviceRooms': device_room, 'deviceNotRooms': device_not_room})
- @staticmethod
- def all_devices(request_dict, response):
- """
- 家庭所有设备(网关和摄像头设备)
- @param request_dict: 请求参数
- @request_dict familyId: 家庭id
- @param response: 响应参数
- @return:
- """
- family_id = request_dict.get('familyId', None)
- if not family_id:
- return response.json(444)
- device_room = {
- 'gateways': [],
- 'cameras': [],
- 'sort': []
- }
- try:
- family_room_device_qs = FamilyRoomDevice.objects.filter(family_id=family_id)
- family_room_device_qs = family_room_device_qs.filter(~Q(device__isExist=2)) \
- .values('device_id', 'device__Type', 'device__NickName', 'room_id',
- 'sub_device', 'category', ).order_by('sort', '-device__data_joined')
- if not family_room_device_qs.exists():
- return response.json(0, device_room)
- sort = FamilyRoomDevice.objects.filter(family_id=family_id).values('category').annotate(
- count=Count('category')).values('category', 'category_sort').order_by('category_sort')
- for item in sort:
- if item['category'] == 0:
- item['category_name'] = '网关子设备类'
- else:
- item['category_name'] = '摄像头类'
- gateways = []
- cameras = []
- # 查询房间名称
- for device in family_room_device_qs:
- room_id = device['room_id']
- device_type = device['device__Type']
- category = device['category']
- room_name = FamilyRoom.objects.filter(id=room_id)
- if category == 0: # 网关子设备
- if not device['sub_device']:
- device_dict = {
- 'deviceId': device['device_id'],
- 'deviceType': device_type,
- 'nickName': device['device__NickName'],
- 'roomName': room_name.first().name if room_name.exists() else '',
- }
- else:
- sub_device_qs = GatewaySubDevice.objects.filter(id=device['sub_device']).values('device_type',
- 'nickname')
- if not sub_device_qs.exists():
- continue
- device_dict = {
- 'deviceId': device['sub_device'],
- 'deviceType': sub_device_qs[0]['device_type'],
- 'nickName': sub_device_qs[0]['nickname'],
- 'roomName': room_name.first().name if room_name.exists() else '',
- }
- gateways.append(device_dict)
- else: # 摄像头设备
- cameras.append({
- 'deviceId': device['device_id'],
- 'deviceType': device_type,
- 'nickName': device['device__NickName'],
- 'roomName': room_name.first().name if room_name.exists() else '',
- })
- device_room['gateways'] = gateways
- device_room['cameras'] = cameras
- device_room['sort'] = list(sort)
- return response.json(0, device_room)
- except Exception as e:
- return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
- @staticmethod
- def devices_sort(request_dict, response):
- """
- 家庭设备排序
- @param request_dict: 请求参数
- @request_dict 设备id: deviceIds
- @param response: 响应参数
- @return:
- """
- device_ids = request_dict.get('deviceIds', None)
- if not device_ids:
- return response.json(444)
- try:
- device_ids = eval(device_ids)
- with transaction.atomic():
- for i, item in enumerate(device_ids):
- device_id = item['id']
- device_type = item['type']
- device_qs = Device_Info.objects.filter(id=device_id, Type=device_type)
- if device_qs.exists(): # 更新主设备排序
- FamilyRoomDevice.objects.filter(device_id=device_id).update(sort=i)
- else: # 更新子设备排序
- FamilyRoomDevice.objects.filter(sub_device=device_id).update(sort=i)
- return response.json(0)
- except Exception as e:
- return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
- @staticmethod
- def device_category(request_dict, response):
- """
- 获取设备类别排序
- @param request_dict: 请求参数
- @request_dict 家庭id: family_id
- @param response: 响应参数
- @return:
- """
- family_id = request_dict.get('familyId', None)
- if not family_id:
- return response.json(444)
- try:
- family_room_device_qs = FamilyRoomDevice.objects.filter(family_id=family_id).values('category').annotate(
- count=Count('category')).values('category', 'category_sort').order_by('category_sort')
- for item in family_room_device_qs:
- if item['category'] == 0:
- item['category_name'] = '网关子设备类'
- else:
- item['category_name'] = '摄像头类'
- return response.json(0, list(family_room_device_qs))
- except Exception as e:
- return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
- @staticmethod
- def category_sort(request_dict, response):
- """
- 家庭设备排序
- @param request_dict: 请求参数
- @request_dict 家庭id: family_id
- @request_dict 排序列表: category_sort
- @param response: 响应参数
- @return:
- """
- family_id = request_dict.get('familyId', None)
- category_sort = request_dict.get('categorySort', None)
- if not all([family_id, category_sort]):
- return response.json(444)
- try:
- category_sort_list = eval(category_sort)
- family_room_device_qs = FamilyRoomDevice.objects.filter(family_id=family_id)
- if family_room_device_qs.exists():
- with transaction.atomic():
- for item in category_sort_list:
- category = item['category']
- category_sort = item['category_sort']
- family_room_device_qs.filter(category=category).update(category_sort=category_sort)
- return response.json(0)
- except Exception as e:
- return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
|