123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- # -*- encoding: utf-8 -*-
- """
- @File : EquipmentMessagePush.py
- @Time : 2022/5/16 11:46
- @Author : stephen
- @Email : zhangdongming@asj6.wecom.work
- @Software: PyCharm
- """
- import logging
- import time
- from django.db import transaction
- from django.views.generic.base import View
- from Model.models import AiService, UidSetModel, Device_Info
- from Object.ResponseObject import ResponseObject
- from Object.TokenObject import TokenObject
- from Service.CommonService import CommonService
- # 设备消息推送视图
- class EquipmentMessagePushView(View):
- def get(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.GET, request, operation)
- def post(self, request, *args, **kwargs):
- request.encoding = 'utf-8'
- operation = kwargs.get('operation')
- return self.validation(request.POST, request, operation)
- def validation(self, request_dict, request, operation):
- token = TokenObject(request.META.get('HTTP_AUTHORIZATION'))
- lang = request_dict.get('lang', None)
- logger = logging.getLogger('info')
- logger.info("传参语言{}".format(lang))
- lang = lang if lang else token.lang
- response = ResponseObject(lang)
- if token.code != 0:
- return response.json(token.code)
- if operation is None:
- return response.json(444, 'error path')
- elif operation == 'update':
- return self.do_change_status_all(request_dict, response)
- elif operation == 'query':
- return self.do_uid_set_query(request_dict, response)
- @classmethod
- def do_uid_set_query(cls, request_dict, response):
- logger = logging.getLogger('info')
- uid = request_dict.get('uid', None)
- logger.info("----查询状态打印uid{}".format(uid))
- if not uid:
- return response.json(444, 'uid')
- uid_set_qs = UidSetModel.objects.filter(uid=uid).order_by('-updTime')
- if uid_set_qs.exists():
- uid_set = uid_set_qs.first()
- data = {
- 'status': uid_set.is_notification,
- 'interval': uid_set.new_detect_interval
- }
- return response.json(0, res=data)
- return response.json(0)
- @classmethod
- def do_change_status_all(cls, request_dict, response):
- logger = logging.getLogger('info')
- status = request_dict.get('status', None)
- uid = request_dict.get('uid', None)
- interval = request_dict.get('interval', None)
- if not status:
- return response.json(444, 'status')
- if not uid:
- return response.json(444, 'uid')
- try:
- with transaction.atomic():
- n_time = int(time.time())
- status = int(status)
- uid_set_qs = UidSetModel.objects.filter(uid=uid)
- device_qs = Device_Info.objects.filter(UID=uid)
- if not uid_set_qs.exists():
- qs_data = {
- 'uid': uid,
- 'addTime': n_time,
- 'updTime': n_time,
- 'device_type': device_qs[0].Type if device_qs.exists() else 0
- }
- if interval:
- qs_data['new_detect_interval'] = int(interval)
- qs_data['is_notification'] = status
- UidSetModel.objects.create(**qs_data)
- if status == 1:
- if uid_set_qs.exists():
- qs_data = {
- 'updTime': n_time,
- }
- if interval:
- qs_data['new_detect_interval'] = int(interval)
- qs_data['is_notification'] = status
- uid_set_qs.update(**qs_data)
- if status == 0:
- ai_service_qs = AiService.objects.filter(uid=uid, use_status=1)
- if ai_service_qs.exists():
- qs_data = {'uid': uid, 'updTime': n_time, 'detect_status': status}
- ai_service_qs.update(**qs_data)
- topic_name = 'ansjer/generic/{}'.format(uid)
- # mqtt通知设备关闭AI识别功能
- msg = {'commandType': 'AIDisable'}
- req_success = CommonService.req_publish_mqtt_msg(uid, topic_name, msg)
- logger.info("推送>>>> mqtt回调:{}".format(req_success))
- if uid_set_qs.exists():
- uid_set_data = {'updTime': n_time, 'uid': uid, 'new_detect_interval': int(interval),
- 'detect_status': int(interval), 'is_notification': status}
- uid_set_qs.update(**uid_set_data)
- return response.json(0)
- except Exception as e:
- print(e)
- return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
|