SmartSocketController.py 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591
  1. # -*- encoding: utf-8 -*-
  2. """
  3. @File : SmartSocketController.py
  4. @Time : 2023/3/17 11:52
  5. @Author : stephen
  6. @Email : zhangdongming@asj6.wecom.work
  7. @Software: PyCharm
  8. """
  9. import datetime
  10. import logging
  11. import time
  12. from decimal import Decimal
  13. from django.db import transaction
  14. from django.http import QueryDict
  15. from django.views import View
  16. from Model.models import SocketInfo, SocketSchedule, Device_Info, UidSetModel, SocketPowerStatistics
  17. from Object.ResponseObject import ResponseObject
  18. from Object.utils import LocalDateTimeUtil
  19. from Service.CommonService import CommonService
  20. LOGGER = logging.getLogger('info')
  21. SOCKET_TOPIC_NAME = 'loocam/smart-socket/{}' # 插座发布消息主题(因设备当前版本只能订阅一个主题)
  22. class SmartSocketView(View):
  23. def get(self, request, *args, **kwargs):
  24. request.encoding = 'utf-8'
  25. operation = kwargs.get('operation')
  26. return self.validation(request.GET, request, operation)
  27. def post(self, request, *args, **kwargs):
  28. request.encoding = 'utf-8'
  29. operation = kwargs.get('operation')
  30. return self.validation(request.POST, request, operation)
  31. def delete(self, request, *args, **kwargs):
  32. request.encoding = 'utf-8'
  33. operation = kwargs.get('operation')
  34. delete = QueryDict(request.body)
  35. if not delete:
  36. delete = request.GET
  37. return self.validation(delete, request, operation)
  38. def put(self, request, *args, **kwargs):
  39. request.encoding = 'utf-8'
  40. operation = kwargs.get('operation')
  41. put = QueryDict(request.body)
  42. return self.validation(put, request, operation)
  43. def validation(self, request_dict, request, operation):
  44. ResponseObject('cn')
  45. if operation == 'savePowerStatistics': # 保存电量上报统计
  46. return self.save_power_statistics(request_dict, ResponseObject('cn'))
  47. token_code, user_id, response = CommonService \
  48. .verify_token_get_user_id(request_dict, request)
  49. if token_code != 0:
  50. return response.json(token_code)
  51. if operation == 'saveSwitch': # 添加插座开关
  52. return self.save_switch(request_dict, response)
  53. elif operation == 'saveCountDown': # 添加插座倒计时
  54. return self.save_count_down(request_dict, response)
  55. elif operation == 'saveSchedule': # 添加插座排程
  56. return self.save_socket_schedule(request_dict, response)
  57. elif operation == 'get-today-scene': # 查询当天插座电量
  58. return self.get_today_scene(request_dict, response)
  59. elif operation == 'get-all-scene': # 统计智能插座电量
  60. return self.get_all_scene(request_dict, response)
  61. elif operation == 'get-socket-schedule': # 智能插座排程记录查询
  62. return self.get_socket_schedule(request_dict, response)
  63. elif operation == 'get-log': # 智能插座开关日志记录查询
  64. return self.get_log(request_dict, response, user_id)
  65. elif operation == 'editor-socket-device': # 编辑设备信息
  66. return self.editor_socket_device(request_dict, response, user_id)
  67. return response.json(404)
  68. @classmethod
  69. def save_power_statistics(cls, request_dict, response):
  70. """
  71. 保存设备上报电量统计
  72. """
  73. try:
  74. serial_number = request_dict.get('serialNumber', None)
  75. electricity = request_dict.get('electricity', 0.00)
  76. power = request_dict.get('power', 0.00)
  77. accumulated_time = request_dict.get('accumulatedTime', None)
  78. device_time = request_dict.get('deviceTime', None)
  79. LOGGER.info('{}上报电量统计data:{}'.format(serial_number, request_dict))
  80. if not all([serial_number, electricity, power, accumulated_time, device_time]):
  81. return response.json(444)
  82. device_time = int(device_time)
  83. electricity = Decimal(electricity).quantize(Decimal("0.00"))
  84. power = Decimal(power).quantize(Decimal("0.00"))
  85. accumulated_time = int(accumulated_time)
  86. now_time = int(time.time())
  87. start_time, end_time = LocalDateTimeUtil.get_today_date(True)
  88. # 查询当前序列号当天是否有上传过电量统计
  89. power_qs = SocketPowerStatistics.objects.filter(serial_number=serial_number,
  90. created_time__gt=start_time,
  91. created_time__lte=end_time)
  92. data = {
  93. 'electricity': electricity,
  94. 'power': power,
  95. 'accumulated_time': accumulated_time,
  96. 'updated_time': now_time
  97. }
  98. if not power_qs.exists():
  99. socket_info_qs = SocketInfo.objects.filter(serial_number=serial_number).values('device_id')
  100. if not socket_info_qs.exists():
  101. return response.json(173)
  102. data['device_id'] = socket_info_qs[0]['device_id']
  103. data['created_time'] = device_time
  104. data['serial_number'] = serial_number
  105. SocketPowerStatistics.objects.create(**data)
  106. return response.json(0)
  107. power_qs.update(**data)
  108. return response.json(0)
  109. except Exception as e:
  110. LOGGER.info('智能插座电量存库异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  111. return response.json(177)
  112. @staticmethod
  113. def get_serial_number_by_device_id(deviceId):
  114. """
  115. 根据设备ID获取序列号
  116. """
  117. device_info = Device_Info.objects.get(id=deviceId)
  118. return device_info.serial_number
  119. @classmethod
  120. def save_switch(cls, request_dict, response):
  121. """
  122. 添加开关
  123. """
  124. device_id = request_dict.get('deviceId', None)
  125. status = request_dict.get('status', None)
  126. if not all([device_id, status]):
  127. return response.json(444)
  128. serial_number = cls.get_serial_number_by_device_id(device_id)
  129. # 保存数据库并下发MQTT消息到插座设备
  130. result = cls.save_socket_switch(device_id, serial_number, int(status))
  131. if not result:
  132. return response.json(177)
  133. return response.json(0)
  134. @staticmethod
  135. def save_socket_switch(device_id, serial_number, status, type_switch=0):
  136. """
  137. 保存插座开关信息
  138. @param device_id: 设备ID
  139. @param serial_number: 序列号
  140. @param status: 状态 0关,1开
  141. @param type_switch: 0:总开关,1倒计时开关
  142. @return: True | False
  143. """
  144. if not device_id:
  145. return False
  146. socket_info_qs = SocketInfo.objects.filter(device_id=device_id, type_switch=type_switch)
  147. now_time = int(time.time())
  148. try:
  149. with transaction.atomic():
  150. # 创建插座开关信息
  151. if not socket_info_qs.exists():
  152. socket_dict = {"device_id": device_id,
  153. "serial_number": serial_number,
  154. "status": status,
  155. "type_switch": type_switch,
  156. "created_time": now_time,
  157. "updated_time": now_time,
  158. "online": True}
  159. SocketInfo.objects.create(**socket_dict)
  160. return True
  161. if socket_info_qs.first().status == status:
  162. return True
  163. socket_info_qs.update(status=status, updated_time=now_time)
  164. # 主题名称
  165. topic_name = SOCKET_TOPIC_NAME.format(serial_number)
  166. # 发布消息内容
  167. msg = {'type': 1, 'data': {'deviceSwitch': status}}
  168. result = CommonService.req_publish_mqtt_msg(serial_number, topic_name, msg)
  169. LOGGER.info('智能插座开关设置发布MQTT消息结果{}'.format(result))
  170. return True
  171. except Exception as e:
  172. LOGGER.info('智能插座异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  173. return False
  174. @classmethod
  175. def save_count_down(cls, request_dict, response):
  176. """
  177. 添加倒计时
  178. """
  179. device_id = request_dict.get('deviceId', None)
  180. status = request_dict.get('status', None)
  181. start = request_dict.get('start', None)
  182. count_down_time = request_dict.get('countDownTime', None)
  183. if not all([device_id, status, count_down_time]):
  184. return response.json(444)
  185. serial_number = cls.get_serial_number_by_device_id(device_id)
  186. # 保存数据库并下发MQTT消息到插座设备
  187. result = cls.save_socket_count_down(device_id, serial_number, int(status), int(start), int(count_down_time))
  188. if not result:
  189. return response.json(177)
  190. return response.json(0)
  191. @staticmethod
  192. def save_socket_count_down(device_id, serial_number, status, start, count_down_time, type_switch=1):
  193. """
  194. 保存插座倒计时信息
  195. @param count_down_time: 倒计时时间戳
  196. @param start: 是否启动倒计时 0:关闭,1:开始
  197. @param device_id: 设备ID
  198. @param serial_number: 序列号
  199. @param status: 倒计时电源状态 0关,1开
  200. @param type_switch: 0:总开关,1倒计时开关
  201. @return:
  202. """
  203. if not device_id:
  204. return False
  205. socket_info_qs = SocketInfo.objects.filter(device_id=device_id, type_switch=type_switch)
  206. now_time = int(time.time())
  207. try:
  208. with transaction.atomic():
  209. # 创建插座倒计时信息
  210. if not socket_info_qs.exists():
  211. socket_dict = {"device_id": device_id,
  212. "serial_number": serial_number,
  213. "status": status,
  214. "type_switch": type_switch,
  215. "created_time": now_time,
  216. "updated_time": now_time,
  217. "online": True,
  218. "count_down_time": count_down_time}
  219. socket_info_qs = SocketInfo.objects.create(**socket_dict)
  220. count_down_id = socket_info_qs.id
  221. else:
  222. socket_info_qs.update(status=status, count_down_time=count_down_time,
  223. updated_time=now_time)
  224. count_down_id = socket_info_qs.first().id
  225. # 主题名称
  226. topic_name = SOCKET_TOPIC_NAME.format(serial_number)
  227. # 发布消息内容
  228. msg = {'type': 2,
  229. 'data': {'powerType': status,
  230. 'countDownId': count_down_id,
  231. 'time': count_down_time,
  232. 'start': start}}
  233. result = CommonService.req_publish_mqtt_msg(serial_number, topic_name, msg)
  234. LOGGER.info('智能插座倒计时发布MQTT消息结果{}'.format(result))
  235. return True
  236. except Exception as e:
  237. LOGGER.info('智能插座异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  238. return False
  239. @classmethod
  240. def save_socket_schedule(cls, request_dict, response):
  241. """
  242. 插座添加排程
  243. """
  244. try:
  245. device_id = request_dict.get('deviceId', None)
  246. task_type = request_dict.get('timeType', None)
  247. start_time = request_dict.get('startTime', None)
  248. end_time = request_dict.get('endTime', None)
  249. repeat = request_dict.get('repeat', None)
  250. task_id = request_dict.get('taskId', None)
  251. device_switch = request_dict.get('deviceSwitch', None)
  252. task_switch = request_dict.get('taskSwitch', None)
  253. if not all([task_type, start_time, repeat, device_switch, task_switch]):
  254. return response.json(444)
  255. device_switch = int(device_switch)
  256. task_switch = int(task_switch)
  257. now_time = int(time.time())
  258. data = {'time_type': int(task_type), 'start_time': int(start_time), 'repeat': int(repeat),
  259. 'switch_status': True if device_switch == 1 else False,
  260. 'task_status': True if task_switch == 1 else False}
  261. serial_number = cls.get_serial_number_by_device_id(device_id)
  262. if task_id: # 修改排程
  263. task_id = int(task_id)
  264. socket_schedule_qs = SocketSchedule.objects.filter(id=task_id)
  265. if not socket_schedule_qs.exists():
  266. return response.json(174)
  267. if end_time:
  268. data['end_time'] = int(end_time)
  269. data['updated_time'] = now_time
  270. socket_schedule_qs.update(**data)
  271. else:
  272. # 添加排程
  273. data['device_id'] = device_id
  274. data['serial_number'] = serial_number
  275. data['updated_time'] = now_time
  276. data['created_time'] = now_time
  277. socket_schedule = SocketSchedule.objects.create(**data)
  278. task_id = socket_schedule.id
  279. # 将排程任务下发给设备
  280. cls.send_socket_schedule(serial_number, task_id, int(task_type), int(start_time),
  281. int(end_time), int(repeat), device_switch,
  282. task_switch)
  283. return response.json(0)
  284. except Exception as e:
  285. LOGGER.info('智能插座异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  286. return False
  287. @staticmethod
  288. def send_socket_schedule(serial_number, task_id, time_type, start_time, end_time, repeat, device_switch,
  289. task_switch):
  290. """
  291. 排程下发设备
  292. @param serial_number: 序列号
  293. @param task_id: 当前排程任务id
  294. @param time_type: 任务类型 0:设定时间,1:设定时间段
  295. @param start_time: 开启时间
  296. @param end_time: 结束时间
  297. @param repeat: 重复日期
  298. @param device_switch: 任务执行后期望设备状态,0:关闭,1:开启
  299. @param task_switch: 任务执行状态 0:不执行,1:执行
  300. @return: True | False
  301. """
  302. msg = {
  303. 'type': 3,
  304. 'data': {'taskId': task_id, 'timeType': time_type,
  305. 'startTime': start_time, 'endTime': end_time,
  306. 'repeat': repeat,
  307. 'deviceSwitch': device_switch,
  308. 'taskSwitch': task_switch}
  309. }
  310. # 主题名称
  311. topic_name = SOCKET_TOPIC_NAME.format(serial_number)
  312. result = CommonService.req_publish_mqtt_msg(serial_number, topic_name, msg)
  313. LOGGER.info('智能插座排程任务发布MQTT消息结果{}'.format(result))
  314. return result
  315. # 以下是查询智能插座接口
  316. @staticmethod
  317. def get_today_scene(request_dict, response):
  318. """
  319. 查询当天插座电量
  320. @request_dict serialNumber: 序列号
  321. @param request_dict: 请求数据
  322. @param response: 响应
  323. @return: response
  324. """
  325. serial_number = request_dict.get('serialNumber', None)
  326. if not all([serial_number]):
  327. return response.json(444)
  328. socket_power_qs = SocketPowerStatistics.objects.filter(serial_number=serial_number).values('power',
  329. 'accumulated_time',
  330. 'electricity')
  331. if not socket_power_qs.exists():
  332. return response.json(173)
  333. socket_info_qs = SocketInfo.objects.filter(serial_number=serial_number).values('status', 'online',
  334. 'count_down_time')
  335. if not socket_info_qs.exists():
  336. return response.json(173)
  337. try:
  338. data = {}
  339. data['serialNumber'] = serial_number
  340. data['power'] = socket_power_qs[0]['power'] if socket_power_qs[0]['power'] else 0.00
  341. data['electricity'] = socket_power_qs[0]['electricity'] if socket_power_qs[0]['electricity'] else 0.00
  342. data['accumulatedTime'] = socket_power_qs[0]['accumulated_time'] if socket_power_qs[0][
  343. 'accumulated_time'] else '0:00'
  344. data['status'] = socket_info_qs[0]['status'] if socket_info_qs[0]['status'] else False
  345. data['online'] = socket_info_qs[0]['online'] if socket_info_qs[0]['online'] else False
  346. data['count_down_time'] = socket_info_qs[0]['count_down_time'] if socket_info_qs[0][
  347. 'count_down_time'] else '00:00:00'
  348. return response.json(0, data)
  349. except Exception as e:
  350. print(e)
  351. return response.json(500)
  352. @classmethod
  353. def get_all_scene(cls, request_dict, response):
  354. '''
  355. 统计智能插座电量
  356. @request_dict serialNumber: 序列号
  357. @request_dict unit: 时间单位
  358. @param request_dict: 请求数据
  359. @param response: 响应
  360. @return: response
  361. '''
  362. serial_number = request_dict.get('serialNumber', None)
  363. unit = request_dict.get('unit', None)
  364. # 确定是否会传值
  365. startTime = request_dict.get('startTime', None)
  366. endTime = request_dict.get('endTime', None)
  367. if not all([unit, serial_number]):
  368. return response.json(444)
  369. socket_power_qs = SocketPowerStatistics.objects.filter(serial_number=serial_number).values(
  370. 'electricity', 'accumulated_time', 'power')
  371. if not socket_power_qs.exists():
  372. return response.json(173)
  373. data = {}
  374. # for device_info in device_info_qs:
  375. # device_id = device_info['id']
  376. # device_list.append(device_id)
  377. try:
  378. data = {
  379. 'electricityToday': '',
  380. 'accumulated_time': '',
  381. 'power': '',
  382. 'electricityYesterday': '',
  383. 'electricityMonth': '',
  384. 'allElectricity': '',
  385. 'accumulatedTime': '',
  386. 'accumulatedPower': '',
  387. }
  388. nowTime = endTime
  389. data['electricity'] = socket_power_qs[0]['electricity'] if socket_power_qs[0]['electricity'] else 0.00
  390. # 昨天使用电量
  391. # data['electricityYesterday'] = socket_power_qs[1]['electricity'] if socket_power_qs[1][
  392. # 'electricity'] else 0.00
  393. data['accumulated_time'] = socket_power_qs[0]['accumulated_time'] if socket_power_qs[0][
  394. 'accumulated_time'] else 0.00
  395. data['power'] = socket_power_qs[0]['power'] if socket_power_qs[0]['power'] else 0.00
  396. time_list = []
  397. if not endTime:
  398. nowTime = 1679241600
  399. if unit == 'week':
  400. startTime = startTime
  401. if not startTime:
  402. startTime = datetime.datetime.fromtimestamp(int(nowTime)) - datetime.timedelta(days=7)
  403. end_time = datetime.datetime.fromtimestamp(int(nowTime))
  404. time_list = CommonService.cutting_time(startTime, end_time, time_unit='day')
  405. elif unit == 'month':
  406. startTime = startTime
  407. if not startTime:
  408. startTime = datetime.datetime.fromtimestamp(int(nowTime)) - datetime.timedelta(days=30)
  409. end_time = datetime.datetime.fromtimestamp(int(nowTime))
  410. time_list = CommonService.cutting_time(startTime, end_time, time_unit='day')
  411. elif unit == 'year':
  412. startTime = startTime
  413. if not startTime:
  414. startTime = datetime.datetime.fromtimestamp(int(nowTime)) - datetime.timedelta(days=365)
  415. end_time = datetime.datetime.fromtimestamp(int(nowTime))
  416. time_list = CommonService.cutting_time(startTime, end_time, time_unit='month')
  417. # all_time_list = []
  418. new_list = []
  419. for item in time_list:
  420. socket_power_qs = socket_power_qs.filter(created_time__gte=item[0], created_time__lt=item[1])
  421. time_tuple = time.localtime(item[-1]) # 把时间戳转换成时间元祖
  422. items = time.strftime('%Y-%m-%d', time_tuple)
  423. electricity = 0.00
  424. new_list.append({
  425. 'time': items,
  426. 'electricity': electricity
  427. })
  428. # #字典key相同则value放一起
  429. # socket_list = list(socket_power_qs)
  430. # new_list.append(socket_list[0])
  431. # for socket in range(1,len(socket_list)):
  432. # for new in new_list:
  433. # if operator.eq(new.keys(), socket_list[socket].keys()):
  434. # for key in new.keys():
  435. # new[key] += socket_list[socket][key]
  436. # break
  437. # elif operator.eq(new, new_list[-1]):
  438. # new_list.append(socket_list[socket])
  439. # break
  440. # data['dict'] = new_list
  441. data['week_or_month_or_year'] = new_list
  442. return response.json(0, data)
  443. except Exception as e:
  444. print(e)
  445. return response.json(500)
  446. @staticmethod
  447. def get_socket_schedule(request_dict, response):
  448. """
  449. 智能插座排程记录查询
  450. @param request_dict: 请求参数
  451. @request_dict page: 页数
  452. @request_dict size: 条数
  453. @request_dict serialNumber: 设备序列号
  454. @param response: 响应对象
  455. @return: response
  456. """
  457. page = request_dict.get('pageNo', None)
  458. size = request_dict.get('pageSize', None)
  459. serial_number = request_dict.get('serialNumber', None)
  460. if not all([page, size, serial_number]):
  461. return response.json(444)
  462. page, size = int(page), int(size)
  463. socket_schedule_qs = SocketSchedule.objects.filter(serial_number=serial_number).values('switch_status',
  464. 'start_time', 'end_time',
  465. 'repeat', 'task_status')
  466. count = socket_schedule_qs.count()
  467. socket_schedule_qs = socket_schedule_qs[(page - 1) * size:page * size]
  468. if not socket_schedule_qs.exists():
  469. return response.json(173)
  470. try:
  471. schedule_list = []
  472. for socket_schedule in socket_schedule_qs:
  473. schedule_list.append({
  474. 'start_time': socket_schedule['start_time'],
  475. 'end_time': socket_schedule['end_time'],
  476. 'switch_status': socket_schedule['switch_status'] if socket_schedule['switch_status'] else False,
  477. 'task_status': socket_schedule['task_status'] if socket_schedule['task_status'] else False,
  478. # 需转换进制
  479. 'repeat': socket_schedule['repeat']
  480. })
  481. return response.json(0, {'list': schedule_list, 'total': count})
  482. except Exception as e:
  483. print(e)
  484. return response.json(500)
  485. @staticmethod
  486. def get_log(request_dict, response, user_id):
  487. """
  488. 智能插座开关日志记录查询
  489. @param request_dict: 请求参数
  490. @param user_id: 用户ID
  491. @request_dict page: 页数
  492. @request_dict size: 条数
  493. @request_dict serialNumber: 设备序列号
  494. @request_dict startTime: 开始时间
  495. @request_dict endTime: 结束时间
  496. @param response: 响应对象
  497. @return: response
  498. """
  499. page = request_dict.get('pageNo', None)
  500. size = request_dict.get('pageSize', None)
  501. serial_number = request_dict.get('serialNumber', None)
  502. start_time = request_dict.get('startTime', None)
  503. end_time = request_dict.get('endTime', None)
  504. if not all([page, size, serial_number]):
  505. return response.json(444)
  506. socket_info_qs = SocketInfo.objects.filter(serial_number=serial_number)
  507. device_id_list = []
  508. pass
  509. @staticmethod
  510. def editor_socket_device(request_dict, response, user_id):
  511. """
  512. 编辑设备
  513. """
  514. # 编辑插座信息
  515. serial_number = request_dict.get('serialNumber', None)
  516. NickName = request_dict.get('NickName', None)
  517. # room_save
  518. # familyRoom = request_dict.get('familyRoom', None)
  519. type_switch = request_dict.get('typeSwitch', None) # 1:倒计时开关
  520. status = request_dict.get('status', None) # 开关状态 0:关闭,1:开启'
  521. # 编辑插座排程
  522. count_down_time = request_dict.get('countDownTime', None) # 倒计时时间戳
  523. time_type = request_dict.get('timeType', None) # 排查时间类型 0:按时间 1:按时间段划分'
  524. switch_status = request_dict.get('switchStatus', None) # 开关状态 0:关闭,1:开启
  525. start_time = request_dict.get('startTime', None)
  526. end_time = request_dict.get('endTime', None)
  527. repeat = request_dict.get('repeat', None) # 重复周期用数值表示
  528. if not all([serial_number]):
  529. return response.json(444)
  530. socket_info_qs = SocketInfo.objects.filter(serial_number=serial_number)
  531. if not socket_info_qs.exists():
  532. return response.json(173)
  533. try:
  534. with transaction.atomic():
  535. if NickName:
  536. Device_Info.objects.update(NickName=NickName)
  537. UidSetModel.objects.update(nickname=NickName)
  538. elif type_switch:
  539. socket_info_qs.update(type_switch=type_switch)
  540. elif status:
  541. socket_info_qs.update(status=status)
  542. elif count_down_time:
  543. socket_info_qs.update(count_down_time=count_down_time)
  544. socket_qs = SocketSchedule.objects.filter(serial_number=serial_number)
  545. if not socket_qs.exists():
  546. socket_info_qs.save()
  547. return response(0)
  548. elif time_type:
  549. socket_qs.update(time_type=time_type)
  550. elif switch_status:
  551. socket_qs.update(switch_status=switch_status)
  552. elif start_time:
  553. socket_qs.update(start_time=start_time)
  554. elif end_time:
  555. socket_qs.update(end_time=end_time)
  556. elif repeat:
  557. socket_qs.update(repeat=repeat)
  558. socket_info_qs.save()
  559. socket_qs.save()
  560. return response.json(0)
  561. except Exception as e:
  562. print(e)
  563. return response.json(500)