SmartSceneController.py 18 KB

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