|
@@ -27,20 +27,19 @@ class GatewaySubDeviceView(View):
|
|
return self.validation(request.POST, request, operation)
|
|
return self.validation(request.POST, request, operation)
|
|
|
|
|
|
def validation(self, request_dict, request, operation):
|
|
def validation(self, request_dict, request, operation):
|
|
- token = TokenObject(request.META.get('HTTP_AUTHORIZATION'))
|
|
|
|
|
|
+ token_obj = TokenObject(request.META.get('HTTP_AUTHORIZATION'))
|
|
lang = request_dict.get('lang', None)
|
|
lang = request_dict.get('lang', None)
|
|
- response = ResponseObject(lang) if lang else ResponseObject(token.lang)
|
|
|
|
|
|
+ response = ResponseObject(lang if lang else token_obj.lang)
|
|
|
|
|
|
- # if token.code != 0:
|
|
|
|
- # return response.json(token.code)
|
|
|
|
- # user_id = token.userID
|
|
|
|
- user_id = '154700384179113800138000'
|
|
|
|
|
|
+ if token_obj.code != 0:
|
|
|
|
+ return response.json(token_obj.code)
|
|
|
|
+ user_id = token_obj.userID
|
|
if operation == 'add': # 添加子设备
|
|
if operation == 'add': # 添加子设备
|
|
return self.add(request_dict, user_id, response)
|
|
return self.add(request_dict, user_id, response)
|
|
elif operation == 'query': # 查询子设备
|
|
elif operation == 'query': # 查询子设备
|
|
return self.query(request_dict, user_id, response)
|
|
return self.query(request_dict, user_id, response)
|
|
elif operation == 'update': # 更新子设备信息
|
|
elif operation == 'update': # 更新子设备信息
|
|
- return self.update(request_dict, user_id, response)
|
|
|
|
|
|
+ return self.sensor_update(user_id, request_dict, response)
|
|
elif operation == 'delete': # 删除子设备
|
|
elif operation == 'delete': # 删除子设备
|
|
return self.delete(request_dict, user_id, response)
|
|
return self.delete(request_dict, user_id, response)
|
|
else:
|
|
else:
|
|
@@ -64,6 +63,7 @@ class GatewaySubDeviceView(View):
|
|
serial_number = request_dict.get('serial_number', None)
|
|
serial_number = request_dict.get('serial_number', None)
|
|
device_type = int(request_dict.get('device_type', None))
|
|
device_type = int(request_dict.get('device_type', None))
|
|
nickname = request_dict.get('nickname', None)
|
|
nickname = request_dict.get('nickname', None)
|
|
|
|
+ request_dict.get('ieee_addr', None)
|
|
src_addr = request_dict.get('src_addr', None)
|
|
src_addr = request_dict.get('src_addr', None)
|
|
family_id = request_dict.get('family_id', None)
|
|
family_id = request_dict.get('family_id', None)
|
|
room_id = request_dict.get('room_id', None)
|
|
room_id = request_dict.get('room_id', None)
|
|
@@ -118,39 +118,41 @@ class GatewaySubDeviceView(View):
|
|
except Exception as e:
|
|
except Exception as e:
|
|
return response.json(500, repr(e))
|
|
return response.json(500, repr(e))
|
|
|
|
|
|
- @staticmethod
|
|
|
|
- def update(request_dict, user_id, response):
|
|
|
|
|
|
+ @classmethod
|
|
|
|
+ def sensor_update(cls, user_id, request_dict, response):
|
|
"""
|
|
"""
|
|
- 更新子设备信息
|
|
|
|
|
|
+ 传感器修改
|
|
|
|
+ @param user_id: 登录用户id
|
|
@param request_dict: 请求参数
|
|
@param request_dict: 请求参数
|
|
- @request_dict serial_number: 序列号
|
|
|
|
- @request_dict sub_device_id: 子设备id
|
|
|
|
- @param user_id: 用户id
|
|
|
|
- @param response: 响应对象
|
|
|
|
- @return: response
|
|
|
|
|
|
+ @param response: 响应结果
|
|
|
|
+ @return: list
|
|
"""
|
|
"""
|
|
- serial_number = request_dict.get('serial_number', None)
|
|
|
|
- sub_device_id = request_dict.get('sub_device_id', None)
|
|
|
|
- nickname = request_dict.get('nickname', None)
|
|
|
|
- src_addr = request_dict.get('src_addr', None)
|
|
|
|
- status = int(request_dict.get('status', None))
|
|
|
|
- family_id = request_dict.get('family_id', None)
|
|
|
|
- room_id = request_dict.get('room_id', None)
|
|
|
|
-
|
|
|
|
- if not all([serial_number]):
|
|
|
|
|
|
+ serial_number = request_dict.get('serialNumber', None)
|
|
|
|
+ nickName = request_dict.get('nickName', None)
|
|
|
|
+ gateway_sub_id = request_dict.get('gatewaySubId', None)
|
|
|
|
+ family_id = request_dict.get('familyId', None)
|
|
|
|
+ room_id = request_dict.get('roomId', None)
|
|
|
|
+ if not all([serial_number, gateway_sub_id]):
|
|
return response.json(444)
|
|
return response.json(444)
|
|
try:
|
|
try:
|
|
|
|
+ gateway_sub_id = int(gateway_sub_id)
|
|
device_info_qs = Device_Info.objects.filter(userID_id=user_id, serial_number=serial_number).values('id')
|
|
device_info_qs = Device_Info.objects.filter(userID_id=user_id, serial_number=serial_number).values('id')
|
|
if not device_info_qs.exists():
|
|
if not device_info_qs.exists():
|
|
return response.json(14)
|
|
return response.json(14)
|
|
- update_data = {
|
|
|
|
- 'nickname': nickname,
|
|
|
|
- 'src_addr': src_addr,
|
|
|
|
- 'status': status,
|
|
|
|
- }
|
|
|
|
- GatewaySubDevice.objects.filter(id=sub_device_id).update(**update_data)
|
|
|
|
|
|
+ gateway_sub_qs = GatewaySubDevice.objects.filter(id=gateway_sub_id)
|
|
|
|
+ if not gateway_sub_qs.exists():
|
|
|
|
+ return response.json(173)
|
|
|
|
+ if nickName:
|
|
|
|
+ gateway_sub_qs.update(nickname=nickName)
|
|
|
|
+ return response.json(0)
|
|
|
|
+ elif all([family_id, room_id]):
|
|
|
|
+ device_id = device_info_qs.first()['id']
|
|
|
|
+ room_id = int(room_id)
|
|
|
|
+ FamilyRoomDevice.objects.filter(device_id=device_id, sub_device=gateway_sub_id) \
|
|
|
|
+ .update(room_id=room_id)
|
|
return response.json(0)
|
|
return response.json(0)
|
|
except Exception as e:
|
|
except Exception as e:
|
|
|
|
+ print(e.args)
|
|
return response.json(500, repr(e))
|
|
return response.json(500, repr(e))
|
|
|
|
|
|
@staticmethod
|
|
@staticmethod
|
|
@@ -172,4 +174,3 @@ class GatewaySubDeviceView(View):
|
|
return response.json(0)
|
|
return response.json(0)
|
|
except Exception as e:
|
|
except Exception as e:
|
|
return response.json(500, repr(e))
|
|
return response.json(500, repr(e))
|
|
-
|
|
|