SmartSceneController.py 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689
  1. # -*- coding: utf-8 -*-
  2. """
  3. @Author : Rocky
  4. @Time : 2022/6/29 9:31
  5. @File :SmartSceneController.py
  6. """
  7. import json
  8. import time
  9. from django.core.exceptions import ObjectDoesNotExist
  10. from django.db import transaction
  11. from django.db.models import F, Q
  12. from django.views import View
  13. from Model.models import FamilyRoomDevice, GatewaySubDevice, FamilyRoom, SmartScene, EffectiveTime, Device_Info, \
  14. SceneLog
  15. from Service.CommonService import CommonService
  16. class SmartSceneView(View):
  17. def get(self, request, *args, **kwargs):
  18. request.encoding = 'utf-8'
  19. operation = kwargs.get('operation')
  20. return self.validation(request.GET, request, operation)
  21. def post(self, request, *args, **kwargs):
  22. request.encoding = 'utf-8'
  23. operation = kwargs.get('operation')
  24. return self.validation(request.POST, request, operation)
  25. def validation(self, request_dict, request, operation):
  26. token_code, user_id, response = CommonService.verify_token_get_user_id(request_dict, request)
  27. if token_code != 0:
  28. return response.json(token_code)
  29. if operation == 'condition-devices': # 添加条件-查询设备
  30. return self.condition_devices(request_dict, response)
  31. elif operation == 'task-devices': # 添加任务-查询设备
  32. return self.task_devices(request_dict, response)
  33. elif operation == 'create': # 创建智能场景
  34. return self.create_smart_scene(request_dict, user_id, response)
  35. elif operation == 'scene-list': # 查询智能场景列表
  36. return self.scene_list(request_dict, user_id, response)
  37. elif operation == 'smart-button-scene-list': # 查询智能按钮场景列表
  38. return self.smart_button_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, user_id, response)
  45. elif operation == 'delete': # 删除智能场景
  46. return self.delete_smart_scene(request_dict, response)
  47. elif operation == 'log': # 查询智能场景日志
  48. return self.scene_log(request_dict, response)
  49. else:
  50. return response.json(414)
  51. @classmethod
  52. def condition_devices(cls, request_dict, response):
  53. """
  54. 添加条件-查询设备
  55. @param request_dict: 请求参数
  56. @request_dict deviceId: 网关设备id
  57. @request_dict subDeviceId: 子设备id
  58. @param response: 响应对象
  59. @return: response
  60. """
  61. device_id = request_dict.get('deviceId', None)
  62. sub_device_id = request_dict.get('subDeviceId', None)
  63. if not any([device_id, sub_device_id]):
  64. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  65. try:
  66. if sub_device_id:
  67. device_id = GatewaySubDevice.objects.get(id=sub_device_id).device_id
  68. gateway_sub_device_qs = GatewaySubDevice.objects.filter(device_id=device_id)
  69. if not gateway_sub_device_qs.exists():
  70. return response.json(173)
  71. res = cls.get_sub_device_room_name(gateway_sub_device_qs)
  72. return response.json(0, res)
  73. except Exception as e:
  74. return response.json(500, repr(e))
  75. @classmethod
  76. def task_devices(cls, request_dict, response):
  77. """
  78. 添加任务-查询设备
  79. @param request_dict: 请求参数
  80. @request_dict deviceId: 网关设备id
  81. @param response: 响应对象
  82. @return: response
  83. """
  84. sub_device_id = request_dict.get('subDeviceId', None)
  85. device_id = request_dict.get('deviceId', None)
  86. if not any([device_id, sub_device_id]):
  87. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  88. try:
  89. if device_id:
  90. res = [cls.get_gateway_data(device_id)]
  91. else:
  92. sub_device_qs = GatewaySubDevice.objects.filter(id=sub_device_id).values('device_id', 'device_type')
  93. device_id = sub_device_qs[0]['device_id']
  94. device_type = sub_device_qs[0]['device_type']
  95. if device_type != 216: # 非智能按钮只返回网关
  96. res = [cls.get_gateway_data(device_id)]
  97. else:
  98. gateway_data = cls.get_gateway_data(device_id)
  99. sub_device_qs = GatewaySubDevice.objects.filter(
  100. Q(device_id=device_id) & Q(device_type=215) | Q(device_type=219)).values('id', 'nickname',
  101. 'status',
  102. 'device_type')
  103. if not sub_device_qs.exists():
  104. return response.json(173)
  105. res = cls.get_sub_device_room_name(sub_device_qs, gateway_data)
  106. return response.json(0, res)
  107. except Exception as e:
  108. return response.json(500, repr(e))
  109. @staticmethod
  110. def get_sub_device_room_name(sub_device_qs, gateway_data=None):
  111. """
  112. 获取房间名称
  113. @param sub_device_qs: 子设备信息
  114. @param gateway_data: 网关参数
  115. @return: sub_device_list
  116. """
  117. sub_device_list = []
  118. if gateway_data:
  119. sub_device_list.append(gateway_data)
  120. sub_device_qs = sub_device_qs.annotate(gatewaySubId=F('id'),
  121. deviceType=F('device_type'),
  122. deviceNickName=F('nickname')). \
  123. values('gatewaySubId', 'deviceType', 'deviceNickName', 'status')
  124. for sub_device in sub_device_qs:
  125. family_room_device_qs = FamilyRoomDevice.objects.filter(sub_device=sub_device['gatewaySubId']). \
  126. values('room_id')
  127. if not family_room_device_qs.exists():
  128. sub_device['roomName'] = ''
  129. else:
  130. room_id = family_room_device_qs[0]['room_id']
  131. try:
  132. sub_device['roomName'] = FamilyRoom.objects.get(id=room_id).name
  133. except ObjectDoesNotExist:
  134. sub_device['roomName'] = ''
  135. sub_device_list.append(sub_device)
  136. return sub_device_list
  137. @staticmethod
  138. def get_gateway_data(device_id):
  139. """
  140. 获取网关数据
  141. @param device_id: 网关设备id
  142. @return: res
  143. """
  144. device_info_qs = Device_Info.objects.filter(id=device_id).values('NickName', 'Type')
  145. nickname = device_info_qs[0]['NickName']
  146. device_type = device_info_qs[0]['Type']
  147. room_id = FamilyRoomDevice.objects.filter(device_id=device_id).values('room_id')[0]['room_id']
  148. room_id_qs = FamilyRoom.objects.filter(id=room_id).values('name')
  149. room_name = room_id_qs.first()['name'] if room_id_qs.exists() else ''
  150. res = {
  151. 'deviceNickName': nickname,
  152. 'deviceType': device_type,
  153. 'roomName': room_name,
  154. 'status': 1,
  155. }
  156. return res
  157. @staticmethod
  158. def create_smart_scene(request_dict, user_id, response):
  159. """
  160. 创建智能场景
  161. @param request_dict: 请求参数
  162. @param user_id: 用户id
  163. @request_dict deviceId: 网关设备id
  164. @request_dict subDeviceId: 子设备id
  165. @request_dict sceneName: 场景名称
  166. @request_dict conditions: 条件
  167. @request_dict tasks: 任务
  168. @request_dict isAllDay: 是否全天执行
  169. @request_dict startTime: 开始时间
  170. @request_dict endTime: 结束时间
  171. @request_dict repeat: 重复周期
  172. @param response: 响应对象
  173. @return: response
  174. """
  175. device_id = request_dict.get('deviceId', None)
  176. sub_device_id = request_dict.get('subDeviceId', None)
  177. scene_name = request_dict.get('sceneName', None)
  178. conditions = request_dict.get('conditions', None)
  179. tasks = request_dict.get('tasks', None)
  180. is_all_day = request_dict.get('isAllDay', None)
  181. if not all([scene_name, conditions, tasks]):
  182. return response.json(444, {'error param': 'scene_name and conditions and tasks'})
  183. now_time = int(time.time())
  184. conditions_dict = eval(conditions)
  185. tasks_list = eval(tasks)
  186. try:
  187. # 判断是否已存在该场景名
  188. smart_scene_qs = SmartScene.objects.filter(user_id=user_id, scene_name=scene_name)
  189. if smart_scene_qs.exists():
  190. return response.json(179)
  191. smart_scene_dict = {
  192. 'user_id': user_id,
  193. 'scene_name': scene_name,
  194. 'conditions': conditions,
  195. 'tasks': tasks,
  196. 'created_time': now_time,
  197. 'updated_time': now_time,
  198. }
  199. msg = {
  200. 'scene_status': 1
  201. }
  202. # 处理设置时间
  203. if is_all_day is not None:
  204. is_all_day = int(is_all_day)
  205. smart_scene_dict['is_all_day'] = is_all_day
  206. # 处理传网关设备id和子设备id的情况
  207. if conditions_dict['type'] == 1: # 网关设置时间
  208. if not device_id:
  209. return response.json(444, {'error param': 'deviceId'})
  210. smart_scene_dict['device_id'] = device_id
  211. device_info_qs = Device_Info.objects.filter(id=device_id).values('serial_number')
  212. if not device_info_qs.exists():
  213. return response.json(173)
  214. serial_number = device_info_qs[0]['serial_number']
  215. else: # 子设备设置场景
  216. if not sub_device_id:
  217. return response.json(444, {'error param': 'subDeviceId'})
  218. # 智能按钮不能创建触发条件相同的场景
  219. device_type = conditions_dict['sensor']['device_type']
  220. if device_type == '216':
  221. event_type = conditions_dict['sensor']['eventValues'][0]['event_type']
  222. smart_scene_qs = SmartScene.objects.filter(sub_device_id=sub_device_id,
  223. conditions__contains=event_type)
  224. if smart_scene_qs.exists():
  225. return response.json(180)
  226. smart_scene_dict['sub_device_id'] = sub_device_id
  227. sub_device_qs = GatewaySubDevice.objects.filter(id=sub_device_id).values('device__serial_number',
  228. 'src_addr')
  229. if not sub_device_qs.exists():
  230. return response.json(173)
  231. serial_number = sub_device_qs[0]['device__serial_number']
  232. msg['sensor_type'] = int(conditions_dict['sensor']['device_type'])
  233. msg['sensor_src'] = int(sub_device_qs[0]['src_addr'], 16)
  234. msg['sensor_status'] = int(conditions_dict['sensor']['eventValues'][0]['event_type'])
  235. with transaction.atomic():
  236. if is_all_day is None: # 不设置时间
  237. smart_scene_qs = SmartScene.objects.create(**smart_scene_dict)
  238. # 设备的time数据,分钟转为秒
  239. time_dict = {
  240. 'start_time': conditions_dict['time']['minutes'] * 60,
  241. 'repeat': conditions_dict['time']['repeat']
  242. }
  243. elif is_all_day == 1: # 全天
  244. smart_scene_qs = SmartScene.objects.create(**smart_scene_dict)
  245. # 设备的time数据
  246. time_dict = {
  247. 'is_all_day': is_all_day
  248. }
  249. elif is_all_day == 2: # 非全天
  250. start_time = int(request_dict.get('startTime', None))
  251. end_time = int(request_dict.get('endTime', None))
  252. repeat = int(request_dict.get('repeat', None))
  253. effective_time_qs = EffectiveTime.objects.filter(start_time=start_time, end_time=end_time,
  254. repeat=repeat).values('id')
  255. if effective_time_qs.exists():
  256. effective_time_id = effective_time_qs[0]['id']
  257. else:
  258. effective_time_id = EffectiveTime.objects.create(start_time=start_time, end_time=end_time,
  259. repeat=repeat).id
  260. smart_scene_dict['effective_time_id'] = effective_time_id
  261. smart_scene_qs = SmartScene.objects.create(**smart_scene_dict)
  262. # 设备的time数据,分钟转为秒
  263. time_dict = {
  264. 'is_all_day': is_all_day,
  265. 'start_time': start_time * 60,
  266. 'end_time': end_time * 60,
  267. 'repeat': repeat
  268. }
  269. else:
  270. return response.json(444, {'error param': 'invalid isAllDay'})
  271. msg['time'] = time_dict
  272. msg['smart_scene_id'] = smart_scene_qs.id
  273. task_list = []
  274. for task in tasks_list:
  275. task_temp = {
  276. 'sensor_type': int(task['device_type']),
  277. 'sensor_action': int(task['event_type'])
  278. }
  279. sub_device_id = task.get('subDeviceId', None)
  280. if sub_device_id:
  281. sub_device_qs = GatewaySubDevice.objects.filter(id=sub_device_id).values('src_addr').first()
  282. task_temp['sensor_src'] = int(sub_device_qs['src_addr'], 16)
  283. task_list.append(task_temp)
  284. msg['task'] = task_list
  285. smart_scene_qs.device_data = json.dumps(msg)
  286. smart_scene_qs.save()
  287. # 发布MQTT消息通知网关设备
  288. thing_name = serial_number
  289. topic_name = 'loocam/gateway_sensor/smart_scene/{}'.format(serial_number)
  290. success = CommonService.req_publish_mqtt_msg(thing_name, topic_name, msg)
  291. try:
  292. assert success
  293. except AssertionError:
  294. return response.json(10044)
  295. return response.json(0)
  296. except Exception as e:
  297. return response.json(500, repr(e))
  298. @staticmethod
  299. def scene_list(request_dict, user_id, response):
  300. """
  301. 查询智能场景列表
  302. @param request_dict: 请求参数
  303. @param user_id: 用户id
  304. @request_dict deviceId: 网关设备id
  305. @request_dict subDeviceId: 子设备id
  306. @param response: 响应对象
  307. @return: response
  308. """
  309. device_id = request_dict.get('deviceId', None)
  310. sub_device_id = request_dict.get('subDeviceId', None)
  311. if not any([device_id, sub_device_id]):
  312. return response.json(444, {'error param': 'deviceId or subDeviceId'})
  313. try:
  314. if device_id:
  315. sub_device_id = GatewaySubDevice.objects.filter(device_id=device_id).values('id')
  316. smart_scene_qs = SmartScene.objects.filter(
  317. Q(user_id=user_id) & Q(device_id=device_id) | Q(sub_device_id__in=sub_device_id))
  318. else:
  319. smart_scene_qs = SmartScene.objects.filter(user_id=user_id, sub_device_id=sub_device_id)
  320. if not smart_scene_qs.exists():
  321. return response.json(173)
  322. smart_scene_qs = smart_scene_qs.values('id', 'scene_name', 'is_enable')
  323. return response.json(0, list(smart_scene_qs))
  324. except Exception as e:
  325. return response.json(500, repr(e))
  326. @staticmethod
  327. def smart_button_scene_list(request_dict, user_id, response):
  328. """
  329. 查询智能按钮场景列表
  330. @param request_dict: 请求参数
  331. @param user_id: 用户id
  332. @request_dict subDeviceId: 子设备id
  333. @param response: 响应对象
  334. @return: response
  335. """
  336. sub_device_id = request_dict.get('subDeviceId', None)
  337. if not sub_device_id:
  338. return response.json(444, {'error param': 'subDeviceId'})
  339. try:
  340. click_scene_qs = SmartScene.objects.filter(user_id=user_id, sub_device_id=sub_device_id,
  341. conditions__contains='2161').values('id', 'scene_name',
  342. 'is_enable')
  343. double_click_scene_qs = SmartScene.objects.filter(user_id=user_id, sub_device_id=sub_device_id,
  344. conditions__contains='2162').values('id', 'scene_name',
  345. 'is_enable')
  346. press_scene_qs = SmartScene.objects.filter(user_id=user_id, sub_device_id=sub_device_id,
  347. conditions__contains='2163').values('id', 'scene_name',
  348. 'is_enable')
  349. scene_list = []
  350. if click_scene_qs.exists():
  351. scene_list.append({
  352. 'trigger_type': 1,
  353. 'id': click_scene_qs[0]['id'],
  354. 'scene_name': click_scene_qs[0]['scene_name'],
  355. 'is_enable': click_scene_qs[0]['is_enable']
  356. })
  357. if double_click_scene_qs.exists():
  358. scene_list.append({
  359. 'trigger_type': 2,
  360. 'id': double_click_scene_qs[0]['id'],
  361. 'scene_name': double_click_scene_qs[0]['scene_name'],
  362. 'is_enable': double_click_scene_qs[0]['is_enable']
  363. })
  364. if press_scene_qs.exists():
  365. scene_list.append({
  366. 'trigger_type': 3,
  367. 'id': press_scene_qs[0]['id'],
  368. 'scene_name': press_scene_qs[0]['scene_name'],
  369. 'is_enable': press_scene_qs[0]['is_enable']
  370. })
  371. return response.json(0, scene_list)
  372. except Exception as e:
  373. return response.json(500, repr(e))
  374. @staticmethod
  375. def update_status(request_dict, response):
  376. """
  377. 更新智能场景状态
  378. @param request_dict: 请求参数
  379. @request_dict smartSceneId: 智能场景id
  380. @request_dict isEnable: 状态,True or False
  381. @param response: 响应对象
  382. @return: response
  383. """
  384. smart_scene_id = request_dict.get('smartSceneId', None)
  385. is_enable = request_dict.get('isEnable', None)
  386. if not all([smart_scene_id, is_enable]):
  387. return response.json(444, {'error param': 'smartSceneId and status'})
  388. try:
  389. SmartScene.objects.filter(id=smart_scene_id).update(is_enable=is_enable)
  390. return response.json(0)
  391. except Exception as e:
  392. return response.json(500, repr(e))
  393. @staticmethod
  394. def scene_detail(request_dict, response):
  395. """
  396. 查询智能场景详情
  397. @param request_dict: 请求参数
  398. @request_dict smartSceneId: 智能场景id
  399. @param response: 响应对象
  400. @return: response
  401. """
  402. smart_scene_id = request_dict.get('smartSceneId', None)
  403. if not smart_scene_id:
  404. return response.json(444, {'error param': 'smartSceneId'})
  405. try:
  406. smart_scene_qs = SmartScene.objects.filter(id=smart_scene_id).values('id', 'scene_name', 'conditions',
  407. 'tasks', 'effective_time_id',
  408. 'is_all_day')
  409. if not smart_scene_qs.exists():
  410. return response.json(173)
  411. res = {
  412. 'scene_name': smart_scene_qs[0]['scene_name'],
  413. 'condition': eval(smart_scene_qs[0]['conditions']),
  414. 'task': eval(smart_scene_qs[0]['tasks']),
  415. }
  416. # 如果存在关联的时间数据,组织时间数据
  417. is_all_day = smart_scene_qs[0]['is_all_day']
  418. effectiveTime = {}
  419. if is_all_day != 0:
  420. effectiveTime['isAllDay'] = is_all_day
  421. if is_all_day == 2:
  422. try:
  423. effective_time_qs = EffectiveTime.objects.get(id=smart_scene_qs[0]['effective_time_id'])
  424. effectiveTime['startTime'] = effective_time_qs.start_time
  425. effectiveTime['endTime'] = effective_time_qs.end_time
  426. effectiveTime['repeat'] = effective_time_qs.repeat
  427. except ObjectDoesNotExist:
  428. return response.json(0, res)
  429. res['effectiveTime'] = effectiveTime
  430. return response.json(0, res)
  431. except Exception as e:
  432. return response.json(500, repr(e))
  433. @staticmethod
  434. def edit_smart_scene(request_dict, user_id, response):
  435. """
  436. 编辑智能场景
  437. @param request_dict: 请求参数
  438. @param user_id: 用户id
  439. @request_dict smartSceneId: 智能场景id
  440. @param response: 响应对象
  441. @return: response
  442. """
  443. smart_scene_id = request_dict.get('smartSceneId', None)
  444. device_id = request_dict.get('deviceId', None)
  445. sub_device_id = request_dict.get('subDeviceId', None)
  446. scene_name = request_dict.get('sceneName', None)
  447. conditions = request_dict.get('conditions', None)
  448. tasks = request_dict.get('tasks', None)
  449. is_all_day = request_dict.get('isAllDay', None)
  450. conditions_dict = eval(conditions)
  451. tasks_list = eval(tasks)
  452. now_time = int(time.time())
  453. smart_scene_qs = SmartScene.objects.filter(user_id=user_id, scene_name=scene_name).filter(~Q(id=smart_scene_id))
  454. if smart_scene_qs.exists():
  455. return response.json(179)
  456. res = {
  457. 'scene_name': scene_name,
  458. 'conditions': conditions_dict,
  459. 'tasks': tasks_list
  460. }
  461. effective_time = {}
  462. if is_all_day:
  463. is_all_day = int(is_all_day)
  464. effective_time['is_all_day'] = is_all_day
  465. if not all([smart_scene_id, scene_name, conditions, tasks]):
  466. return response.json(444, {'error param': 'smartSceneId,sceneName,conditions or tasks'})
  467. try:
  468. smart_scene_qs = SmartScene.objects.filter(id=smart_scene_id)
  469. if not smart_scene_qs.exists():
  470. return response.json(173)
  471. msg = {}
  472. if conditions_dict['type'] == 2: # 条件为选择子设备
  473. if not sub_device_id:
  474. return response.json(444, {'error param': 'subDeviceId'})
  475. # 智能按钮不能创建触发条件相同的场景
  476. device_type = conditions_dict['sensor']['device_type']
  477. if device_type == '216':
  478. event_type = conditions_dict['sensor']['eventValues'][0]['event_type']
  479. smart_scene_qs = SmartScene.objects.filter(sub_device_id=sub_device_id,
  480. conditions__contains=event_type)
  481. if smart_scene_qs.exists():
  482. return response.json(180)
  483. device_id = ''
  484. sub_device_qs = GatewaySubDevice.objects.filter(id=sub_device_id).values('src_addr',
  485. 'device__serial_number')
  486. if not sub_device_qs.exists():
  487. return response.json(173)
  488. serial_number = sub_device_qs[0]['device__serial_number']
  489. msg['smart_scene_id'] = smart_scene_id
  490. msg['scene_status'] = 1
  491. msg['sensor_type'] = conditions_dict['sensor']['device_type']
  492. msg['sensor_src'] = int(sub_device_qs[0]['src_addr'], 16)
  493. msg['sensor_status'] = int(conditions_dict['sensor']['eventValues'][0]['event_type'])
  494. else:
  495. if not device_id:
  496. return response.json(444, {'error param': 'deviceId'})
  497. sub_device_id = 0
  498. device_qs = Device_Info.objects.filter(id=device_id).value('serial_number')
  499. if not device_qs.exists():
  500. return response.json(173)
  501. serial_number = device_qs[0]['serial_number']
  502. task_list = []
  503. for task in tasks_list:
  504. task_temp = {
  505. 'sensor_type': int(task['device_type']),
  506. 'sensor_action': int(task['event_type'])
  507. }
  508. task_sub_device_id = task.get('subDeviceId', None)
  509. if task_sub_device_id:
  510. sub_device_qs = GatewaySubDevice.objects.filter(id=task_sub_device_id).values('src_addr').first()
  511. task_temp['sensor_src'] = int(sub_device_qs['src_addr'], 16)
  512. task_list.append(task_temp)
  513. msg['task'] = task_list
  514. with transaction.atomic():
  515. smart_scene_qs.update(scene_name=scene_name, conditions=conditions, tasks=tasks,
  516. device_data=json.dumps(msg), updated_time=now_time, device_id=device_id,
  517. sub_device_id=sub_device_id)
  518. if is_all_day is None: # 不设置时间或全天
  519. smart_scene_qs.update(effective_time_id=0, is_all_day=0)
  520. time_dict = {
  521. 'start_time': conditions_dict['time']['minutes'] * 60,
  522. 'repeat': conditions_dict['time']['repeat']
  523. }
  524. elif is_all_day == 1:
  525. smart_scene_qs.update(effective_time_id=0, is_all_day=is_all_day)
  526. time_dict = {
  527. 'is_all_day': is_all_day
  528. }
  529. else:
  530. start_time = int(request_dict.get('startTime', None))
  531. end_time = int(request_dict.get('endTime', None))
  532. repeat = int(request_dict.get('repeat', None))
  533. effective_time_qs = EffectiveTime.objects.filter(start_time=start_time, end_time=end_time,
  534. repeat=repeat).values('id')
  535. if effective_time_qs.exists():
  536. effective_time_id = effective_time_qs[0]['id']
  537. else:
  538. effective_time_id = EffectiveTime.objects.create(start_time=start_time, end_time=end_time,
  539. repeat=repeat).id
  540. smart_scene_qs.update(effective_time_id=effective_time_id, is_all_day=is_all_day)
  541. time_dict = {
  542. 'is_all_day': is_all_day,
  543. 'start_time': start_time * 60,
  544. 'end_time': end_time * 60,
  545. 'repeat': repeat
  546. }
  547. effective_time = {
  548. 'isAllDay': is_all_day,
  549. 'startTime': start_time,
  550. 'endTime': end_time,
  551. 'repeat': repeat
  552. }
  553. msg['time'] = time_dict
  554. # 通过mqtt发送设备数据
  555. thing_name = serial_number
  556. topic_name = 'loocam/gateway_sensor/smart_scene/{}'.format(serial_number)
  557. success = CommonService.req_publish_mqtt_msg(thing_name, topic_name, msg)
  558. res['effectiveTime'] = effective_time
  559. return response.json(0, res)
  560. except Exception as e:
  561. return response.json(500, repr(e))
  562. @staticmethod
  563. def delete_smart_scene(request_dict, response):
  564. """
  565. 删除智能场景
  566. @param request_dict: 请求参数
  567. @request_dict smartSceneIds: 智能场景id
  568. @param response: 响应对象
  569. @return: response
  570. """
  571. smart_scene_ids = request_dict.get('smartSceneIds', None)
  572. if not smart_scene_ids:
  573. return response.json(444, {'error param': 'smartSceneIds'})
  574. try:
  575. SmartScene.objects.filter(id__in=smart_scene_ids.split(',')).delete()
  576. except Exception as e:
  577. return response.json(500, repr(e))
  578. else:
  579. return response.json(0)
  580. @staticmethod
  581. def scene_log(request_dict, response):
  582. """
  583. 查询场景日志
  584. @param request_dict: 请求参数
  585. @request_dict deviceId: 网关id
  586. @request_dict subDeviceId: 子设备id
  587. @request_dict page: 页数
  588. @request_dict size: 条数
  589. @request_dict startTime: 开始时间
  590. @request_dict endTime: 结束时间
  591. @param response: 响应对象
  592. @return: response
  593. """
  594. device_id = request_dict.get('deviceId', None)
  595. sub_device_id = request_dict.get('subDeviceId', None)
  596. page = request_dict.get('page', None)
  597. size = request_dict.get('size', None)
  598. start_time = request_dict.get('startTime', None)
  599. end_time = request_dict.get('endTime', None)
  600. if not any([device_id, sub_device_id]):
  601. return response.json(444, {'error param': 'deviceId and subDeviceId'})
  602. if not all([page, size]):
  603. return response.json(444, {'error param': 'page or size'})
  604. device_dict = {}
  605. if device_id:
  606. device_dict['device_id'] = device_id
  607. else:
  608. device_dict['sub_device_id'] = sub_device_id
  609. try:
  610. page, size = int(page), int(size)
  611. if start_time and end_time:
  612. scene_log_qs = SceneLog.objects.filter(**device_dict, created_time__range=(start_time, end_time)). \
  613. values('scene_id', 'scene_log', 'status', 'created_time').order_by(
  614. '-created_time')[(page - 1) * size:page * size]
  615. else:
  616. scene_log_qs = SceneLog.objects.filter(**device_dict).values('scene_id', 'scene_log', 'status',
  617. 'created_time').order_by(
  618. '-created_time')[(page - 1) * size:page * size]
  619. if not scene_log_qs.exists():
  620. return response.json(0, [])
  621. for item in scene_log_qs:
  622. scene_id = item['scene_id']
  623. scene_name = SmartScene.objects.filter(id=scene_id)[0].scene_name
  624. item['scene_name'] = scene_name
  625. return response.json(0, list(scene_log_qs))
  626. except Exception as e:
  627. print(repr(e))
  628. return response.json(500, repr(e))