SmartSceneController.py 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406
  1. # -*- coding: utf-8 -*-
  2. """
  3. @Author : Rocky
  4. @Time : 2022/6/29 9:31
  5. @File :SmartSceneController.py
  6. """
  7. import time
  8. from django.core.exceptions import ObjectDoesNotExist
  9. from django.db.models import F
  10. from django.views import View
  11. from Model.models import FamilyRoomDevice, GatewaySubDevice, FamilyRoom, SmartScene, EffectiveTime, Device_Info
  12. from Object.ResponseObject import ResponseObject
  13. from Object.TokenObject import TokenObject
  14. from Service.CommonService import CommonService
  15. class SmartSceneView(View):
  16. def get(self, request, *args, **kwargs):
  17. request.encoding = 'utf-8'
  18. operation = kwargs.get('operation')
  19. return self.validation(request.GET, request, operation)
  20. def post(self, request, *args, **kwargs):
  21. request.encoding = 'utf-8'
  22. operation = kwargs.get('operation')
  23. return self.validation(request.POST, request, operation)
  24. def validation(self, request_dict, request, operation):
  25. token_obj = TokenObject(request.META.get('HTTP_AUTHORIZATION'))
  26. lang = request_dict.get('lang', None)
  27. response = ResponseObject(lang if lang else token_obj.lang)
  28. if token_obj.code != 0:
  29. return response.json(token_obj.code)
  30. user_id = token_obj.userID
  31. if operation == 'condition-devices': # 添加条件-查询设备
  32. return self.condition_devices(request_dict, response)
  33. if operation == 'task-devices': # 添加任务-查询设备
  34. return self.task_devices(request_dict, response)
  35. elif operation == 'create': # 创建智能场景
  36. return self.create_smart_scene(request_dict, user_id, response)
  37. elif operation == 'scene-list': # 查询智能场景列表
  38. return self.scene_list(request_dict, user_id, response)
  39. elif operation == 'update-status': # 更新智能场景状态
  40. return self.update_status(request_dict, response)
  41. elif operation == 'detail': # 查询智能场景详情
  42. return self.scene_detail(request_dict, response)
  43. elif operation == 'edit': # 编辑智能场景
  44. return self.edit_smart_scene(request_dict, response)
  45. elif operation == 'delete': # 删除智能场景
  46. return self.delete_smart_scene(request_dict, response)
  47. else:
  48. return response.json(414)
  49. @staticmethod
  50. def condition_devices(request_dict, response):
  51. """
  52. 添加条件-查询设备
  53. @param request_dict: 请求参数
  54. @request_dict deviceId: 网关设备id
  55. @request_dict subDeviceId: 子设备id
  56. @param response: 响应对象
  57. @return: response
  58. """
  59. device_id = request_dict.get('deviceId', None)
  60. sub_device_id = request_dict.get('subDeviceId', None)
  61. if not any([device_id, sub_device_id]):
  62. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  63. try:
  64. if sub_device_id:
  65. device_id = GatewaySubDevice.objects.get(id=sub_device_id).device_id
  66. gateway_sub_device_qs = GatewaySubDevice.objects.filter(device_id=device_id)
  67. if not gateway_sub_device_qs.exists():
  68. return response.json(173)
  69. gateway_sub_device_qs = gateway_sub_device_qs.annotate(gatewaySubId=F('id'), deviceType=F('device_type'),
  70. deviceNickName=F('nickname')).\
  71. values('gatewaySubId', 'deviceType', 'deviceNickName', 'status')
  72. sub_device_list = []
  73. for gateway_sub_device in gateway_sub_device_qs:
  74. family_room_device_qs = FamilyRoomDevice.objects.filter(sub_device=gateway_sub_device['gatewaySubId']).\
  75. values('room_id')
  76. if not family_room_device_qs.exists():
  77. gateway_sub_device['roomName'] = ''
  78. else:
  79. room_id = family_room_device_qs[0]['room_id']
  80. try:
  81. gateway_sub_device['roomName'] = FamilyRoom.objects.get(id=room_id).name
  82. except ObjectDoesNotExist:
  83. gateway_sub_device['roomName'] = ''
  84. sub_device_list.append(gateway_sub_device)
  85. return response.json(0, sub_device_list)
  86. except Exception as e:
  87. return response.json(500, repr(e))
  88. @classmethod
  89. def task_devices(cls, request_dict, response):
  90. """
  91. 添加任务-查询设备
  92. @param request_dict: 请求参数
  93. @request_dict deviceId: 网关设备id
  94. @param response: 响应对象
  95. @return: response
  96. """
  97. sub_device_id = request_dict.get('subDeviceId', None)
  98. device_id = request_dict.get('deviceId', None)
  99. if not any([device_id, sub_device_id]):
  100. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  101. try:
  102. if device_id:
  103. res = cls.get_gateway_data(device_id)
  104. else:
  105. device_id_qs = GatewaySubDevice.objects.filter(id=sub_device_id).values('device_id', 'device_type')
  106. device_id = device_id_qs[0]['device_id']
  107. device_type = device_id_qs[0]['device_type']
  108. if device_type != 216:
  109. res = cls.get_gateway_data(device_id)
  110. else:
  111. sub_device_list = []
  112. gateway_data = cls.get_gateway_data(device_id)
  113. sub_device_list.append(gateway_data)
  114. gate_way = GatewaySubDevice.objects.filter(device_id=device_id).values('id', 'nickname', 'status',
  115. 'device_type')
  116. for gateway_sub_device in gate_way:
  117. device_type = gateway_sub_device['device_type']
  118. if device_type == 216:
  119. pass
  120. else:
  121. sub_device_id = gateway_sub_device['id']
  122. room_qs = FamilyRoomDevice.objects.filter(sub_device=sub_device_id).values('room_id')
  123. room_qs.exists()
  124. room_qs = room_qs.first()
  125. room_id = room_qs['room_id']
  126. room_id_qs = FamilyRoom.objects.filter(id=room_id).values('name')
  127. room_name = room_id_qs.first()['name'] if room_id_qs.exists() else ''
  128. try:
  129. if gate_way.exists():
  130. gateway_sub_device['room_name'] = FamilyRoom.objects.get(id=room_id).name
  131. except ObjectDoesNotExist:
  132. gateway_sub_device['room_name'] = room_name
  133. gateway_sub_device.pop('id')
  134. sub_device_list.append(gateway_sub_device)
  135. res = {'sub_device_list': sub_device_list}
  136. return response.json(0, res)
  137. except Exception as e:
  138. return response.json(500, repr(e))
  139. @staticmethod
  140. def get_gateway_data(device_id):
  141. """
  142. 获取网关数据
  143. @param device_id: 网关设备id
  144. @return: res
  145. """
  146. device_info_qs = Device_Info.objects.filter(id=device_id).values('NickName', 'Type')
  147. nickname = device_info_qs[0]['NickName']
  148. device_type = device_info_qs[0]['Type']
  149. room_id = FamilyRoomDevice.objects.filter(device_id=device_id).values('room_id')[0]['room_id']
  150. room_id_qs = FamilyRoom.objects.filter(id=room_id).values('name')
  151. room_name = room_id_qs.first()['name'] if room_id_qs.exists() else ''
  152. res = {
  153. 'deviceNickName': nickname,
  154. 'deviceType': device_type,
  155. 'roomName': room_name,
  156. 'status': 1,
  157. }
  158. return res
  159. @staticmethod
  160. def create_smart_scene(request_dict, user_id, response):
  161. """
  162. 创建智能场景
  163. @param request_dict: 请求参数
  164. @param user_id: 用户id
  165. @request_dict deviceId: 网关设备id
  166. @request_dict subDeviceId: 子设备id
  167. @request_dict sceneName: 场景名称
  168. @request_dict conditions: 条件
  169. @request_dict tasks: 任务
  170. @request_dict isAllDay: 是否全天执行
  171. @request_dict startTime: 开始时间
  172. @request_dict endTime: 结束时间
  173. @request_dict repeat: 重复周期
  174. @param response: 响应对象
  175. @return: response
  176. """
  177. device_id = request_dict.get('deviceId', None)
  178. sub_device_id = request_dict.get('subDeviceId', None)
  179. scene_name = request_dict.get('sceneName', None)
  180. conditions = request_dict.get('conditions', None)
  181. tasks = request_dict.get('tasks', None)
  182. is_all_day = request_dict.get('isAllDay', None)
  183. if not any([device_id, sub_device_id]):
  184. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  185. if not all([conditions, tasks]):
  186. return response.json(444, {'error param': 'conditions and tasks'})
  187. now_time = int(time.time())
  188. try:
  189. # 判断是否已存在该场景名
  190. smart_scene_qs = SmartScene.objects.filter(user_id=user_id, scene_name=scene_name)
  191. if smart_scene_qs.exists():
  192. return response.json(174)
  193. smart_scene_dict = {
  194. 'user_id': user_id,
  195. 'scene_name': scene_name,
  196. 'conditions': conditions,
  197. 'tasks': tasks,
  198. 'created_time': now_time,
  199. 'updated_time': now_time,
  200. }
  201. # 处理传网关设备id和子设备id的情况
  202. if device_id:
  203. smart_scene_dict['device_id'] = device_id
  204. device_info_qs = Device_Info.objects.filter(id=device_id).values('serial_number')
  205. if not device_info_qs.exists():
  206. return response.json(173)
  207. serial_number = device_info_qs[0]['serial_number']
  208. else:
  209. smart_scene_dict['sub_device_id'] = sub_device_id
  210. sub_device_qs = GatewaySubDevice.objects.filter(id=sub_device_id).values('device__serial_number')
  211. if not sub_device_qs.exists():
  212. return response.json(173)
  213. serial_number = sub_device_qs[0]['device__serial_number']
  214. if not is_all_day: # 没传时间
  215. SmartScene.objects.create(**smart_scene_dict)
  216. else:
  217. if is_all_day == '0':
  218. effective_time_qs = EffectiveTime.objects.filter(is_all_day=True).values('id')
  219. if effective_time_qs.exists():
  220. effective_time_id = effective_time_qs[0]['id']
  221. else:
  222. effective_time_id = EffectiveTime.objects.create(is_all_day=True).id
  223. smart_scene_dict['effective_time_id'] = effective_time_id
  224. SmartScene.objects.create(**smart_scene_dict)
  225. else:
  226. start_time = int(request_dict.get('startTime', None))
  227. end_time = int(request_dict.get('endTime', None))
  228. repeat = int(request_dict.get('repeat', None))
  229. if not all([start_time, end_time, repeat]):
  230. return response.json(444, {'error param': 'startTime and endTime and repeat'})
  231. effective_time_qs = EffectiveTime.objects.filter(start_time=start_time, end_time=end_time,
  232. repeat=repeat).values('id')
  233. if effective_time_qs.exists():
  234. effective_time_id = effective_time_qs[0]['id']
  235. else:
  236. effective_time_id = EffectiveTime.objects.create(start_time=start_time, end_time=end_time,
  237. repeat=repeat).id
  238. smart_scene_dict['effective_time_id'] = effective_time_id
  239. SmartScene.objects.create(**smart_scene_dict)
  240. # 发布MQTT消息通知网关设备
  241. thing_name = serial_number
  242. topic_name = 'loocam/gateway_sensor/{}/smart_scene'.format(serial_number)
  243. msg = ''
  244. success = CommonService.req_publish_mqtt_msg(thing_name, topic_name, msg)
  245. if not success:
  246. return response.json(10044)
  247. return response.json(0)
  248. except Exception as e:
  249. return response.json(500, repr(e))
  250. @staticmethod
  251. def scene_list(request_dict, user_id, response):
  252. """
  253. 查询智能场景列表
  254. @param request_dict: 请求参数
  255. @param user_id: 用户id
  256. @request_dict deviceId: 网关设备id
  257. @request_dict subDeviceId: 子设备id
  258. @param response: 响应对象
  259. @return: response
  260. """
  261. device_id = request_dict.get('deviceId', None)
  262. sub_device_id = request_dict.get('subDeviceId', None)
  263. if not any([device_id, sub_device_id]):
  264. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  265. try:
  266. if device_id:
  267. smart_scene_qs = SmartScene.objects.filter(user_id=user_id, device_id=device_id)
  268. else:
  269. smart_scene_qs = SmartScene.objects.filter(user_id=user_id, sub_device_id=sub_device_id)
  270. if not smart_scene_qs.exists():
  271. return response.json(173)
  272. smart_scene_qs = smart_scene_qs.values('id', 'scene_name', 'is_enable')
  273. return response.json(0, list(smart_scene_qs))
  274. except Exception as e:
  275. return response.json(500, repr(e))
  276. @staticmethod
  277. def update_status(request_dict, response):
  278. """
  279. 更新智能场景状态
  280. @param request_dict: 请求参数
  281. @request_dict smartSceneId: 智能场景id
  282. @request_dict isEnable: 状态,True or False
  283. @param response: 响应对象
  284. @return: response
  285. """
  286. smart_scene_id = request_dict.get('smartSceneId', None)
  287. is_enable = request_dict.get('isEnable', None)
  288. if not all([smart_scene_id, is_enable]):
  289. return response.json(444, {'error param': 'smartSceneId and status'})
  290. try:
  291. SmartScene.objects.filter(id=smart_scene_id).update(is_enable=is_enable)
  292. return response.json(0)
  293. except Exception as e:
  294. return response.json(500, repr(e))
  295. @staticmethod
  296. def scene_detail(request_dict, response):
  297. """
  298. 查询智能场景详情
  299. @param request_dict: 请求参数
  300. @request_dict smartSceneId: 智能场景id
  301. @param response: 响应对象
  302. @return: response
  303. """
  304. smart_scene_id = request_dict.get('smartSceneId', None)
  305. if not smart_scene_id:
  306. return response.json(444, {'error param': 'smartSceneId'})
  307. try:
  308. smart_scene_qs = SmartScene.objects.filter(id=smart_scene_id).values('id', 'scene_name', 'conditions',
  309. 'tasks', 'effective_time_id')
  310. if not smart_scene_qs.exists():
  311. return response.json(173)
  312. res = {
  313. 'scene_name': smart_scene_qs[0]['scene_name'],
  314. 'condition': eval(smart_scene_qs[0]['conditions']),
  315. 'task': eval(smart_scene_qs[0]['tasks']),
  316. }
  317. # 如果存在关联的时间数据,组织时间数据
  318. try:
  319. effective_time_qs = EffectiveTime.objects.get(id=smart_scene_qs[0]['effective_time_id'])
  320. except ObjectDoesNotExist:
  321. return response.json(0, res)
  322. if effective_time_qs.is_all_day: # 全天
  323. time_dict = {'all_day': 1}
  324. else:
  325. time_dict = {
  326. 'start_time': effective_time_qs.start_time,
  327. 'end_time': effective_time_qs.end_time,
  328. 'repeat': effective_time_qs.repeat,
  329. }
  330. res['time'] = time_dict
  331. return response.json(0, res)
  332. except Exception as e:
  333. return response.json(500, repr(e))
  334. @staticmethod
  335. def edit_smart_scene(request_dict, response):
  336. """
  337. 编辑智能场景
  338. @param request_dict: 请求参数
  339. @request_dict smartSceneId: 智能场景id
  340. @param response: 响应对象
  341. @return: response
  342. """
  343. smart_scene_id = request_dict.get('smartSceneId', None)
  344. if not smart_scene_id:
  345. return response.json(444, {'error param': 'smartSceneId'})
  346. try:
  347. smart_scene_qs = SmartScene.objects.filter(id=smart_scene_id).values('id', 'scene_name', 'conditions',
  348. 'tasks', 'effective_time_id')
  349. if not smart_scene_qs.exists():
  350. return response.json(173)
  351. return response.json(0, list(smart_scene_qs))
  352. except Exception as e:
  353. return response.json(500, repr(e))
  354. @staticmethod
  355. def delete_smart_scene(request_dict, response):
  356. """
  357. 删除智能场景
  358. @param request_dict: 请求参数
  359. @request_dict smartSceneId: 智能场景id
  360. @param response: 响应对象
  361. @return: response
  362. """
  363. smart_scene_id = request_dict.get('smartSceneId', None)
  364. if not smart_scene_id:
  365. return response.json(444, {'error param': 'smartSceneId'})
  366. try:
  367. SmartScene.objects.filter(id=smart_scene_id).delete()
  368. return response.json(0)
  369. except Exception as e:
  370. return response.json(500, repr(e))