|
@@ -65,8 +65,6 @@ class NotificationView(View):
|
|
|
is_st = request_dict.get('is_st', None)
|
|
|
company_secrete = request_dict.get('company_secrete', None)
|
|
|
region = request_dict.get('region', None)
|
|
|
- is_filter = request_dict.get('is_filter', 1)
|
|
|
- is_filter = int(is_filter)
|
|
|
if not region:
|
|
|
return JsonResponse(status=200, data={'code': 404, 'msg': 'region is not exist'})
|
|
|
region = int(region)
|
|
@@ -105,14 +103,13 @@ class NotificationView(View):
|
|
|
# 一分钟外,推送开启状态
|
|
|
detect_med_type = 0 # 0推送旧机制 1存库不推送,2推送存库
|
|
|
# 暂时注销
|
|
|
- if is_filter == 1:
|
|
|
- if have_pkey:
|
|
|
- if SERVER_TYPE != "Ansjer.formal_settings":
|
|
|
- res_data = {'code': 0, 'msg': 'Push once every 10 seconds'}
|
|
|
- else:
|
|
|
- res_data = {'code': 0, 'msg': 'Push it once a minute'}
|
|
|
+ if have_pkey:
|
|
|
+ if SERVER_TYPE != "Ansjer.formal_settings":
|
|
|
+ res_data = {'code': 0, 'msg': 'Push once every 10 seconds'}
|
|
|
+ else:
|
|
|
+ res_data = {'code': 0, 'msg': 'Push it once a minute'}
|
|
|
|
|
|
- return JsonResponse(status=200, data=res_data)
|
|
|
+ return JsonResponse(status=200, data=res_data)
|
|
|
|
|
|
# 数据库读取数据
|
|
|
if have_ykey:
|
|
@@ -174,12 +171,7 @@ class NotificationView(View):
|
|
|
if not nickname:
|
|
|
nickname = uid
|
|
|
|
|
|
-
|
|
|
-
|
|
|
if detect_group is not None:
|
|
|
- if is_filter == 0:
|
|
|
- have_dkey = 0
|
|
|
-
|
|
|
if have_dkey:
|
|
|
detect_med_type = 1 # 1为存库不推送
|
|
|
else:
|
|
@@ -265,7 +257,6 @@ class NotificationView(View):
|
|
|
logger.info(detect_med_type)
|
|
|
push_server_status = 0
|
|
|
#推送
|
|
|
-
|
|
|
if detect_med_type == 2 or detect_med_type == 0:
|
|
|
if push_type == 0: # ios apns
|
|
|
print('do_apns')
|
|
@@ -862,3 +853,282 @@ class PushNotificationView(View):
|
|
|
send_text = '{msg_type} channel:{channel} date:{date}'. \
|
|
|
format(msg_type=msg_type, channel=channel, date=n_date)
|
|
|
return send_text
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+# 移动侦测接口
|
|
|
+class PWnotificationView(View):
|
|
|
+
|
|
|
+ def get(self, request, *args, **kwargs):
|
|
|
+ request.encoding = 'utf-8'
|
|
|
+ return self.validation(request.GET)
|
|
|
+
|
|
|
+ def post(self, request, *args, **kwargs):
|
|
|
+ request.encoding = 'utf-8'
|
|
|
+ return self.validation(request.POST)
|
|
|
+
|
|
|
+ def validation(self, request_dict):
|
|
|
+
|
|
|
+ uid = request_dict.get('uid', None)
|
|
|
+ channel = request_dict.get('channel', None)
|
|
|
+ electricity = request_dict.get('electricity', None)
|
|
|
+ uid_push_qs = UidPushModel.objects.filter(uid_set__uid=uid, uid_set__detect_status=1). \
|
|
|
+ values('token_val', 'app_type', 'appBundleId', 'm_code',
|
|
|
+ 'push_type', 'userID_id', 'userID__NickName',
|
|
|
+ 'lang', 'm_code', 'tz', 'uid_set__nickname', 'uid_set__detect_interval', 'uid_set__detect_group',
|
|
|
+ 'uid_set__channel')
|
|
|
+ print(uid_push_qs)
|
|
|
+ # 新建一个list接收数据
|
|
|
+ redis_list = []
|
|
|
+ # 把数据库数据追加进redis_list
|
|
|
+ for qs in uid_push_qs:
|
|
|
+ redis_list.append(qs)
|
|
|
+
|
|
|
+ if not redis_list:
|
|
|
+ print("没有redi_list")
|
|
|
+ res_data = {'code': 0, 'msg': 'no redi_list success!'}
|
|
|
+ return JsonResponse(status=200, data=res_data)
|
|
|
+
|
|
|
+ nickname = redis_list[0]['uid_set__nickname']
|
|
|
+ if not nickname:
|
|
|
+ nickname = uid
|
|
|
+
|
|
|
+ now_time = int(time.time())
|
|
|
+ channel = channel
|
|
|
+ event_type = 704
|
|
|
+ sys_msg_list = []
|
|
|
+ userID_ids = []
|
|
|
+ kwag_args = {
|
|
|
+ 'uid': uid,
|
|
|
+ 'channel': channel,
|
|
|
+ 'event_type': event_type,
|
|
|
+ 'n_time': now_time,
|
|
|
+ # 'appBundleId': appBundleId,
|
|
|
+ # 'token_val': token_val,
|
|
|
+ # 'msg_title': msg_title,
|
|
|
+ # 'msg_text': msg_text
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ for up in redis_list:
|
|
|
+ push_type = up['push_type']
|
|
|
+ appBundleId = up['appBundleId']
|
|
|
+ token_val = up['token_val']
|
|
|
+ lang = up['lang']
|
|
|
+ tz = up['tz']
|
|
|
+ if tz is None or tz == '':
|
|
|
+ tz = 0
|
|
|
+ # 发送标题
|
|
|
+ msg_title = self.get_msg_title(appBundleId=appBundleId, nickname=nickname)
|
|
|
+ # 发送内容
|
|
|
+ msg_text = self.get_msg_text(channel=channel, n_time=now_time, lang=lang, tz=tz,
|
|
|
+ event_type=event_type, electricity= electricity)
|
|
|
+ kwag_args['appBundleId'] = appBundleId
|
|
|
+ kwag_args['token_val'] = token_val
|
|
|
+ kwag_args['msg_title'] = msg_title
|
|
|
+ kwag_args['msg_text'] = msg_text
|
|
|
+
|
|
|
+ if push_type == 0: # ios apns
|
|
|
+ do_apns_code = self.do_apns(**kwag_args)
|
|
|
+ elif push_type == 1: # android gcm
|
|
|
+ print('do_fcm')
|
|
|
+ do_fcm_code = self.do_fcm(**kwag_args)
|
|
|
+ elif push_type == 2: # android jpush
|
|
|
+ print('do_jpush')
|
|
|
+ do_jpush_code = self.do_jpush(**kwag_args)
|
|
|
+
|
|
|
+ # 以下是存库
|
|
|
+ userID_id = up["userID_id"]
|
|
|
+ if userID_id not in userID_ids:
|
|
|
+ sys_msg_text = self.get_msg_text(channel=channel, n_time=now_time, lang=lang, tz=tz,
|
|
|
+ event_type=event_type, is_sys=1, electricity= electricity)
|
|
|
+ sys_msg_list.append(SysMsgModel(
|
|
|
+ userID_id=userID_id,
|
|
|
+ msg=sys_msg_text,
|
|
|
+ addTime=now_time,
|
|
|
+ updTime=now_time,
|
|
|
+ uid=uid,
|
|
|
+ eventType=event_type))
|
|
|
+
|
|
|
+ userID_ids.append(userID_id)
|
|
|
+
|
|
|
+ SysMsgModel.objects.bulk_create(sys_msg_list)
|
|
|
+
|
|
|
+
|
|
|
+ return JsonResponse(status=200, data={'code': 0})
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ def get_msg_title(self, appBundleId, nickname):
|
|
|
+ package_title_config = {
|
|
|
+ 'com.ansjer.customizedd_a': 'DVS',
|
|
|
+ 'com.ansjer.zccloud_a': 'ZosiSmart',
|
|
|
+ 'com.ansjer.zccloud_ab': '周视',
|
|
|
+ 'com.ansjer.adcloud_a': 'ADCloud',
|
|
|
+ 'com.ansjer.adcloud_ab': 'ADCloud',
|
|
|
+ 'com.ansjer.accloud_a': 'ACCloud',
|
|
|
+ 'com.ansjer.loocamccloud_a': 'Loocam',
|
|
|
+ 'com.ansjer.loocamdcloud_a': 'Anlapus',
|
|
|
+ 'com.ansjer.customizedb_a': 'COCOONHD',
|
|
|
+ 'com.ansjer.customizeda_a': 'Guardian365',
|
|
|
+ 'com.ansjer.customizedc_a': 'PatrolSecure',
|
|
|
+ }
|
|
|
+ if appBundleId in package_title_config.keys():
|
|
|
+ return package_title_config[appBundleId] + '(' + nickname + ')'
|
|
|
+ else:
|
|
|
+ return nickname
|
|
|
+
|
|
|
+ def is_sys_msg(self, event_type):
|
|
|
+ event_type_list = [702, 703, 704]
|
|
|
+ if event_type in event_type_list:
|
|
|
+ return True
|
|
|
+ return False
|
|
|
+
|
|
|
+ def get_msg_text(self, channel, n_time, lang, tz, event_type, electricity, is_sys=0):
|
|
|
+ n_date = CommonService.get_now_time_str(n_time=n_time, tz=tz,lang=lang)
|
|
|
+ etype = int(event_type)
|
|
|
+ if lang == 'cn':
|
|
|
+ if etype == 704:
|
|
|
+ msg_type = '电量不足:'+electricity+'%'
|
|
|
+ elif etype == 702:
|
|
|
+ msg_type = '摄像头休眠'
|
|
|
+ elif etype == 703:
|
|
|
+ msg_type = '摄像头唤醒'
|
|
|
+ else:
|
|
|
+ msg_type = ''
|
|
|
+ if is_sys:
|
|
|
+ send_text = '{msg_type} 通道:{channel}'.format(msg_type=msg_type, channel=channel)
|
|
|
+ else:
|
|
|
+ send_text = '{msg_type} 通道:{channel} 日期:{date}'.format(msg_type=msg_type, channel=channel, date=n_date)
|
|
|
+ # send_text = '{msg_type} 通道:{channel} 日期:{date}'.format(msg_type=msg_type, channel=channel, date=n_date)
|
|
|
+ else:
|
|
|
+ if etype == 704:
|
|
|
+ msg_type = 'Insufficient battery: '+electricity+'%'
|
|
|
+ elif etype == 702:
|
|
|
+ msg_type = 'Camera sleep'
|
|
|
+ elif etype == 703:
|
|
|
+ msg_type = 'Camera wake'
|
|
|
+ else:
|
|
|
+ msg_type = ''
|
|
|
+ if is_sys:
|
|
|
+ send_text = '{msg_type} channel:{channel}'. \
|
|
|
+ format(msg_type=msg_type, channel=channel)
|
|
|
+ else:
|
|
|
+ send_text = '{msg_type} channel:{channel} date:{date}'. \
|
|
|
+ format(msg_type=msg_type, channel=channel, date=n_date)
|
|
|
+ return send_text
|
|
|
+
|
|
|
+ def do_jpush(self, uid, channel, appBundleId, token_val, event_type, n_time,
|
|
|
+ msg_title, msg_text):
|
|
|
+ app_key = JPUSH_CONFIG[appBundleId]['Key']
|
|
|
+ master_secret = JPUSH_CONFIG[appBundleId]['Secret']
|
|
|
+ # 此处换成各自的app_key和master_secre
|
|
|
+ _jpush = jpush.JPush(app_key, master_secret)
|
|
|
+ push = _jpush.create_push()
|
|
|
+ # if you set the logging level to "DEBUG",it will show the debug logging.
|
|
|
+ # _jpush.set_logging("DEBUG")
|
|
|
+ # push.audience = jpush.all_
|
|
|
+ push.audience = jpush.registration_id(token_val)
|
|
|
+ push_data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
|
|
|
+ "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1", "channel": channel}
|
|
|
+ android = jpush.android(alert=msg_text, priority=1, style=1, alert_type=7,
|
|
|
+ big_text=msg_text, title=msg_title,
|
|
|
+ extras=push_data)
|
|
|
+ push.notification = jpush.notification(android=android)
|
|
|
+ push.platform = jpush.all_
|
|
|
+ res = push.send()
|
|
|
+ print(res)
|
|
|
+ return res.status_code
|
|
|
+ # try:
|
|
|
+ # res = push.send()
|
|
|
+ # print(res)
|
|
|
+ # except Exception as e:
|
|
|
+ # print("jpush fail")
|
|
|
+ # print("Exception")
|
|
|
+ # print(repr(e))
|
|
|
+ # return
|
|
|
+ # else:
|
|
|
+ # print("jpush success")
|
|
|
+ # return
|
|
|
+
|
|
|
+ def do_fcm(self, uid, channel, appBundleId, token_val, event_type, n_time, msg_title, msg_text):
|
|
|
+ try:
|
|
|
+ serverKey = FCM_CONFIG[appBundleId]
|
|
|
+ except Exception as e:
|
|
|
+ return 'serverKey abnormal'
|
|
|
+ push_service = FCMNotification(api_key=serverKey)
|
|
|
+ data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
|
|
|
+ "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1", "channel": channel}
|
|
|
+ result = push_service.notify_single_device(registration_id=token_val, message_title=msg_title,
|
|
|
+ message_body=msg_text, data_message=data,
|
|
|
+ extra_kwargs={
|
|
|
+ 'default_vibrate_timings': True,
|
|
|
+ 'default_sound': True,
|
|
|
+ 'default_light_settings': True
|
|
|
+ })
|
|
|
+ print('fcm push ing')
|
|
|
+ print(result)
|
|
|
+ return result
|
|
|
+
|
|
|
+ def do_apns(self, uid, channel, appBundleId, token_val, event_type, n_time, msg_title,
|
|
|
+ msg_text):
|
|
|
+ logger = logging.getLogger('info')
|
|
|
+ logger.info("进来do_apns函数了")
|
|
|
+ logger.info(token_val)
|
|
|
+ logger.info(APNS_MODE)
|
|
|
+ logger.info(os.path.join(BASE_DIR, APNS_CONFIG[appBundleId]['pem_path']))
|
|
|
+ try:
|
|
|
+ cli = apns2.APNSClient(mode=APNS_MODE,
|
|
|
+ client_cert=os.path.join(BASE_DIR, APNS_CONFIG[appBundleId]['pem_path']))
|
|
|
+
|
|
|
+ push_data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
|
|
|
+ "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1", "channel": channel}
|
|
|
+ alert = apns2.PayloadAlert(body=msg_text, title=msg_title)
|
|
|
+ payload = apns2.Payload(alert=alert, custom=push_data)
|
|
|
+
|
|
|
+ # return uid, channel, appBundleId, str(token_val), event_type, n_time, msg_title,msg_text
|
|
|
+ n = apns2.Notification(payload=payload, priority=apns2.PRIORITY_LOW)
|
|
|
+ res = cli.push(n=n, device_token=token_val, topic=appBundleId)
|
|
|
+ print(res.status_code)
|
|
|
+ logger.info("推送状态:")
|
|
|
+ logger.info(res.status_code)
|
|
|
+
|
|
|
+ # 200, 推送成功。
|
|
|
+ # 400, 请求有问题。
|
|
|
+ # 403, 证书或Token有问题。
|
|
|
+ # 405, 请求方式不正确, 只支持POST请求
|
|
|
+ # 410, 设备的Token与证书不一致
|
|
|
+ if res.status_code == 200:
|
|
|
+ return res.status_code
|
|
|
+ else:
|
|
|
+ print('apns push fail')
|
|
|
+ print(res.reason)
|
|
|
+ logger.info('apns push fail')
|
|
|
+ logger.info(res.reason)
|
|
|
+ return res.status_code
|
|
|
+ except (ValueError, ArithmeticError):
|
|
|
+ return 'The program has a numeric format exception, one of the arithmetic exceptions'
|
|
|
+ except Exception as e:
|
|
|
+ print(repr(e))
|
|
|
+ logger.info(repr(e))
|
|
|
+ return repr(e)
|
|
|
+
|
|
|
+ def do_update_detect_interval(self, uid, channel, redisObject, detect_interval):
|
|
|
+ if channel == 0:
|
|
|
+ channel = 17
|
|
|
+ else:
|
|
|
+ channel += 1
|
|
|
+ for i in range(1, channel):
|
|
|
+ tmpDKey = '{uid}_{channel}_{event_type}_flag'.format(uid=uid, event_type=51, channel=i)
|
|
|
+ if tmpDKey is not False:
|
|
|
+ llt = redisObject.get_ttl(tmpDKey)
|
|
|
+ if llt > detect_interval:
|
|
|
+ redisObject.set_data(key=tmpDKey, val=1, expire=detect_interval)
|
|
|
+
|
|
|
+ tmpDKey = '{uid}_{channel}_{event_type}_flag'.format(uid=uid, event_type=54, channel=i)
|
|
|
+ if tmpDKey is not False:
|
|
|
+ llt = redisObject.get_ttl(tmpDKey)
|
|
|
+ if llt > detect_interval:
|
|
|
+ redisObject.set_data(key=tmpDKey, val=1, expire=detect_interval)
|