DetectController.py 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2019/1/14 15:57
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: DetectController.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import json
  15. import os
  16. import time
  17. from pyfcm import FCMNotification
  18. import apns2
  19. import jpush as jpush
  20. import oss2
  21. from django.utils.decorators import method_decorator
  22. from django.views.decorators.csrf import csrf_exempt
  23. from django.views.generic.base import View
  24. from Ansjer.config import OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET, BASE_DIR, DETECT_PUSH_DOMAIN
  25. from Model.models import Device_Info, VodHlsModel, Equipment_Info, UidSetModel, UidPushModel
  26. from Object.ResponseObject import ResponseObject
  27. from Object.TokenObject import TokenObject
  28. from Object.UidTokenObject import UidTokenObject
  29. from django.http import JsonResponse
  30. from Object.RedisObject import RedisObject
  31. # http://192.168.136.40:8077/detect/changeStatus?uid=JW3684H8BSHG9TTM111A&token_val=18071adc03536302f34&appBundleId=com.ansjer.zccloud_ab&push_type=2&token=local&status=1&app_type=1
  32. class DetectControllerView(View):
  33. @method_decorator(csrf_exempt)
  34. def dispatch(self, *args, **kwargs):
  35. return super(DetectControllerView, self).dispatch(*args, **kwargs)
  36. def get(self, request, *args, **kwargs):
  37. request.encoding = 'utf-8'
  38. operation = kwargs.get('operation')
  39. return self.validation(request.GET, operation)
  40. def post(self, request, *args, **kwargs):
  41. request.encoding = 'utf-8'
  42. operation = kwargs.get('operation')
  43. return self.validation(request.POST, operation)
  44. def validation(self, request_dict, operation):
  45. response = ResponseObject()
  46. if operation is None:
  47. return response.json(444, 'error path')
  48. token = request_dict.get('token', None)
  49. tko = TokenObject(token)
  50. if tko.code == 0:
  51. userID = tko.userID
  52. # 修改推送设置
  53. if operation == 'changeStatus':
  54. return self.do_change_status(userID, request_dict, response)
  55. # 查询推送信息
  56. elif operation == 'queryInfo':
  57. return self.do_query(request_dict, response, userID)
  58. # 更新推送延迟
  59. elif operation == 'updateInterval':
  60. return self.do_update_interval(userID, request_dict, response)
  61. else:
  62. return response.json(414)
  63. else:
  64. return response.json(tko.code)
  65. def do_query(self, request_dict, response, userID):
  66. page = int(request_dict.get('page', None))
  67. line = int(request_dict.get('line', None))
  68. nowTime = int(time.time())
  69. if not page or not line:
  70. return response.json(444, 'page,line')
  71. qs = Equipment_Info.objects.filter(userID_id=userID, addTime__gte=nowTime - 3600 * 24 * 27)
  72. uid = request_dict.get('uid', None)
  73. if uid:
  74. qs = qs.filter(devUid=uid)
  75. dvqs = Device_Info.objects.filter(UID=uid).values('Type', 'NickName')
  76. uid_type_dict = {uid: {'type': dvqs[0]['Type'], 'NickName': dvqs[0]['NickName']}}
  77. else:
  78. dvqs = Device_Info.objects.filter(userID_id=userID).values('UID', 'Type', 'NickName')
  79. uid_type_dict = {}
  80. for dv in dvqs:
  81. uid_type_dict[dv['UID']] = {'type': dv['Type'], 'NickName': dv['NickName']}
  82. print(uid_type_dict)
  83. if not qs.exists():
  84. return response.json(0, {'datas': [], 'count': 0})
  85. qs = qs.values('id', 'devUid', 'devNickName', 'Channel', 'eventType', 'status', 'alarm', 'eventTime',
  86. 'receiveTime', 'is_st')
  87. count = qs.count()
  88. qr = qs[(page - 1) * line:page * line]
  89. res = []
  90. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  91. img_bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'apg')
  92. # vod_time_list = []
  93. for p in qr:
  94. devUid = p['devUid']
  95. eventTime = p['eventTime']
  96. channel = p['Channel']
  97. if p['is_st'] == 1:
  98. p['img'] = img_bucket.sign_url('GET', '{uid}/{channel}/{time}.jpeg'.
  99. format(uid=devUid, channel=p['Channel'], time=eventTime), 300)
  100. p['img_list'] = [img_bucket.sign_url('GET', '{uid}/{channel}/{time}.jpeg'.
  101. format(uid=devUid, channel=channel, time=eventTime), 300)]
  102. elif p['is_st'] == 2:
  103. # 列表装载回放时间戳标记
  104. vodqs = VodHlsModel.objects.filter(uid=devUid, channel=channel, time=int(eventTime)) \
  105. .values("bucket__bucket", "bucket__endpoint")
  106. print(vodqs)
  107. if vodqs.exists():
  108. bucket_name = vodqs[0]['bucket__bucket']
  109. endpoint = vodqs[0]['bucket__endpoint']
  110. bucket = oss2.Bucket(auth, endpoint, bucket_name)
  111. ts = '{uid}/vod{channel}/{etime}/ts0.ts'.format(uid=devUid, channel=p['Channel'], etime=eventTime)
  112. thumb0 = bucket.sign_url('GET', ts, 3600, params={'x-oss-process': 'video/snapshot,t_0000,w_700'})
  113. thumb1 = bucket.sign_url('GET', ts, 3600, params={'x-oss-process': 'video/snapshot,t_1000,w_700'})
  114. thumb2 = bucket.sign_url('GET', ts, 3600, params={'x-oss-process': 'video/snapshot,t_2000,w_700'})
  115. # thumb3 = bucket.sign_url('GET', ts, 3600, params={'x-oss-process': 'video/snapshot,t_3000,w_700'})
  116. p['img_list'] = [thumb0, thumb1, thumb2]
  117. if devUid in uid_type_dict.keys():
  118. p['uid_type'] = uid_type_dict[devUid]['type']
  119. p['devNickName'] = uid_type_dict[devUid]['NickName']
  120. else:
  121. p['uid_type'] = ''
  122. res.append(p)
  123. return response.json(0, {'datas': res, 'count': count})
  124. def do_change_status(self, userID, request_dict, response):
  125. uid = request_dict.get('uid', None)
  126. token_val = request_dict.get('token_val', None)
  127. appBundleId = request_dict.get('appBundleId', None)
  128. app_type = request_dict.get('app_type', None)
  129. push_type = request_dict.get('push_type', None)
  130. status = request_dict.get('status', None)
  131. m_code = request_dict.get('m_code', None)
  132. # 设备语言
  133. lang = request_dict.get('lang', 'en')
  134. # interval = request_dict.get('interval', None)
  135. print('status:' + status)
  136. if not status:
  137. return response.json(444, 'status')
  138. # 关闭推送
  139. if not all([appBundleId, app_type, token_val, uid, m_code]):
  140. return response.json(444, 'appBundleId,app_type,token_val,uid,m_code')
  141. dvqs = Device_Info.objects.filter(userID_id=userID, UID=uid)
  142. status = int(status)
  143. if dvqs.exists():
  144. nowTime = int(time.time())
  145. uid_set_qs = UidSetModel.objects. \
  146. filter(uid=uid, uidpushmodel__userID_id=userID, uidpushmodel__m_code=m_code)
  147. # 判断是否有曾经开启过
  148. if uid_set_qs.exists():
  149. uid_push_update_dict = {
  150. 'appBundleId': appBundleId,
  151. 'app_type': app_type,
  152. 'push_type': push_type,
  153. 'token_val': token_val,
  154. 'updTime': nowTime,
  155. 'lang': lang
  156. }
  157. uid_set_qs.update(detect_status=status, updTime=nowTime)
  158. UidPushModel.objects.filter(userID_id=userID, m_code=m_code, uid_set__uid=uid). \
  159. update(**uid_push_update_dict)
  160. if status == 0:
  161. # 关闭成功
  162. return response.json(0)
  163. utko = UidTokenObject()
  164. # right
  165. utko.generate(data={'uid': uid})
  166. detectUrl = "{DETECT_PUSH_DOMAIN}notify/push?uidToken={uidToken}". \
  167. format(uidToken=utko.token, DETECT_PUSH_DOMAIN=DETECT_PUSH_DOMAIN)
  168. return response.json(0, {'detectUrl': detectUrl})
  169. else:
  170. uid_set_qs = UidSetModel.objects.filter(uid=uid)
  171. # 判断uid push是否绑定
  172. if not uid_set_qs.exists():
  173. uid_set_create_dict = {
  174. 'uid': uid,
  175. 'addTime': nowTime,
  176. 'updTime': nowTime,
  177. 'detect_status': status,
  178. }
  179. # 添加设备配置
  180. uid_set_qs = UidSetModel.objects.create(**uid_set_create_dict)
  181. uid_set_id = uid_set_qs.id
  182. uid_set_qs = UidSetModel.objects.filter(uid=uid)
  183. from var_dump import var_dump
  184. var_dump('==========================')
  185. var_dump(uid_set_qs)
  186. var_dump('==========================')
  187. else:
  188. uid_set_id = uid_set_qs[0].id
  189. uid_push_create_dict = {
  190. 'uid_set_id': uid_set_id,
  191. 'userID_id': userID,
  192. 'appBundleId': appBundleId,
  193. 'app_type': app_type,
  194. 'push_type': push_type,
  195. 'token_val': token_val,
  196. 'm_code': m_code,
  197. 'addTime': nowTime,
  198. 'updTime': nowTime,
  199. 'lang': lang
  200. }
  201. # 绑定设备推送
  202. UidPushModel.objects.create(**uid_push_create_dict)
  203. if status == 0:
  204. return response.json(0)
  205. utko = UidTokenObject()
  206. utko.generate(data={'uid': uid})
  207. detectUrl = "{DETECT_PUSH_DOMAIN}notify/push?uidToken={uidToken}". \
  208. format(uidToken=utko.token, DETECT_PUSH_DOMAIN=DETECT_PUSH_DOMAIN)
  209. return response.json(0, {'detectUrl': detectUrl})
  210. else:
  211. return response.json(14)
  212. def do_update_interval(self, userID, request_dict, response):
  213. uid = request_dict.get('uid', None)
  214. interval = request_dict.get('interval', None)
  215. dvqs = Device_Info.objects.filter(userID_id=userID, UID=uid)
  216. if dvqs.exists():
  217. uid_set_qs = UidSetModel.objects. \
  218. filter(uid=uid, uidpushmodel__userID_id=userID)
  219. if uid_set_qs.exists():
  220. uid_set_qs.update(interval=int(interval))
  221. else:
  222. return response.json(173)
  223. else:
  224. return response.json(0)
  225. # http://192.168.136.40:8077/notify/push?uidToken=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1aWQiOiJUTjdNUEUzMjExVUU3NkFQMTExQSJ9.k501567VdnhFpn_ygzGRDat3Kqlz5CsEA9jAC2dDk_g&obj=12341234&n_time=1234561234
  226. # http://test.dvema.com/notify/push?uidToken=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1aWQiOiJQMldOR0pSRDJFSEE1RVU5MTExQSJ9.xOCI5lerk8JOs5OcAzunrKCfCrtuPIZ3AnkMmnd-bPY&n_time=1526845794&channel=1&event_type=51&is_st=0
  227. # 移动侦测接口
  228. class NotificationView(View):
  229. def get(self, request, *args, **kwargs):
  230. request.encoding = 'utf-8'
  231. # operation = kwargs.get('operation')
  232. return self.validation(request.GET)
  233. def post(self, request, *args, **kwargs):
  234. request.encoding = 'utf-8'
  235. # operation = kwargs.get('operation')
  236. return self.validation(request.POST)
  237. def validation(self, request_dict):
  238. response = ResponseObject()
  239. uidToken = request_dict.get('uidToken', None)
  240. channel = request_dict.get('channel', '1')
  241. n_time = request_dict.get('n_time', None)
  242. event_type = request_dict.get('event_type', None)
  243. is_st = request_dict.get('is_st', None)
  244. if not all([uidToken, channel, n_time]):
  245. return JsonResponse(status=200, data={
  246. 'code': 444,
  247. 'msg': 'param is wrong'})
  248. # return response.json(444)
  249. utko = UidTokenObject(uidToken)
  250. uid = utko.UID
  251. uid_set_qs = UidSetModel.objects.filter(uid=uid, detect_status=1)
  252. if uid_set_qs.exists():
  253. uid_set_id = uid_set_qs[0].id
  254. nickname = uid_set_qs[0].nickname
  255. uid_push_qs = UidPushModel.objects.filter(uid_set__id=uid_set_id). \
  256. values('token_val', 'app_type', 'appBundleId', 'push_type', 'userID_id', 'userID__NickName', 'lang')
  257. if uid_set_qs.exists():
  258. redisObj = RedisObject(db=6)
  259. pkey = '{uid}_{channel}_ptl'.format(uid=uid, channel=channel)
  260. if redisObj.get_data(key=pkey):
  261. res_data = {'code': 0, 'msg': 'success,!'}
  262. return JsonResponse(status=200, data=res_data)
  263. else:
  264. detect_interval = uid_set_qs[0].detect_interval
  265. if detect_interval:
  266. redisObj.set_data(key=pkey, val=1, expire=detect_interval)
  267. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  268. bucket = oss2.Bucket(auth, 'oss-cn-shenzhen.aliyuncs.com', 'apg')
  269. for up in uid_push_qs:
  270. push_type = up['push_type']
  271. # ios apns
  272. if push_type == 0:
  273. self.do_apns(request_dict, up, response, uid, channel, nickname)
  274. # android gcm
  275. elif push_type == 1:
  276. self.do_fcm(request_dict, up, response, uid, channel, nickname)
  277. # self.do_gmc(request_dict, up, response, uid, channel,nickname)
  278. # android jpush
  279. elif push_type == 2:
  280. self.do_jpush(request_dict, up, response, uid, channel, nickname)
  281. # self.do_save_equipment_info(ua, n_time, channel, event_type, is_st)
  282. # 需求不一样,所以这么做的
  283. self.do_bulk_create_info(uid_push_qs, n_time, channel, event_type, is_st, uid)
  284. if is_st == '0' or is_st == '2':
  285. return JsonResponse(status=200, data={'code': 0, 'msg': 'success'})
  286. else:
  287. # Endpoint以杭州为例,其它Region请按实际情况填写。
  288. obj = '{uid}/{channel}/{filename}.jpeg'.format(uid=uid, channel=channel, filename=n_time)
  289. # 设置此签名URL在60秒内有效。
  290. url = bucket.sign_url('PUT', obj, 7200)
  291. res_data = {'code': 0, 'img_push': url, 'msg': 'success'}
  292. return JsonResponse(status=200, data=res_data)
  293. else:
  294. return JsonResponse(status=200, data={'code': 404, 'msg': 'data is not exist'})
  295. else:
  296. return JsonResponse(status=200, data={'code': 404, 'msg': 'data is not exist'})
  297. def do_jpush(self, request_dict, uaql, response, uid, channel, nickname):
  298. event_type = request_dict.get('event_type', None)
  299. jpush_config = {
  300. 'com.ansjer.accloud_ab': {
  301. 'Key': 'f0dc047e5e53fd14199de5b0',
  302. 'Secret': 'aa7f7db33e9f0a7f3871aa1c'},
  303. 'com.ansjer.adcloud_ab': {
  304. 'Key': '76d97b535185114985608234',
  305. 'Secret': 'c9a92b301043cc9c52778692'},
  306. 'com.ansjer.zccloud_ab': {
  307. 'Key': 'd9924f56d3cc7c6017965130',
  308. 'Secret': '869d832d126a232f158b5987'},
  309. 'com.ansjer.loocamccloud_ab': {
  310. 'Key': 'd1cc44797b4642b0e05304fe',
  311. 'Secret': 'c3e8b4ca8c576de61401e56a'},
  312. 'com.ansjer.loocamdcloud_ab': {
  313. 'Key': '76d97b535185114985608234',
  314. 'Secret': 'c9a92b301043cc9c52778692'},
  315. 'com.ansjer.zccloud_a': {
  316. 'Key': '57de2a80d68bf270fd6bdf5a',
  317. 'Secret': '3d354eb6a0b49c2610decf42'},
  318. 'com.ansjer.accloud_a': {
  319. 'Key': 'ff95ee685f49c0dc4013347b',
  320. 'Secret': 'de2c20959f5516fdeeafe78e'},
  321. 'com.ansjer.adcloud_a': {
  322. 'Key': '2e47eb1aee9b164460df3668',
  323. 'Secret': 'b9137d8d684bc248f1809b6d'},
  324. 'com.ansjer.loocamccloud_a': {
  325. 'Key': '23c9213215c7ca0ec945629b',
  326. 'Secret': '81e4b1e859cc8387e2e6c431'},
  327. 'com.ansjer.loocamdcloud_a': {
  328. 'Key': '1dbdd60a16e9892d6f68a073',
  329. 'Secret': '80a97690e7e043109059b403'},
  330. 'com.ansjer.customizedb_a': {
  331. 'Key': '9d79630aa49adfa291fe2568',
  332. 'Secret': '4d8ff52f88136561875a0212'},
  333. 'com.ansjer.customizedd_a': {
  334. 'Key': '8fc4f495685bde53341ee25dMaster',
  335. 'Secret': 'f1da11fa466509fa2670fb66',
  336. }
  337. }
  338. n_time = request_dict.get('n_time', None)
  339. appBundleId = uaql['appBundleId']
  340. token_val = uaql['token_val']
  341. lang = uaql['lang']
  342. response = ResponseObject()
  343. app_key = jpush_config[appBundleId]['Key']
  344. master_secret = jpush_config[appBundleId]['Secret']
  345. # 此处换成各自的app_key和master_secre
  346. _jpush = jpush.JPush(app_key, master_secret)
  347. push = _jpush.create_push()
  348. # if you set the logging level to "DEBUG",it will show the debug logging.
  349. _jpush.set_logging("DEBUG")
  350. # push.audience = jpush.all_
  351. push.audience = jpush.registration_id(token_val)
  352. push_data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
  353. "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1", "channel": channel}
  354. n_date = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(n_time)))
  355. if lang == 'cn':
  356. if nickname:
  357. message_title = "周视({nickname})".format(nickname=nickname)
  358. else:
  359. message_title = "周视({uid})".format(uid=uid)
  360. send_text = '通道:{channel} 日期:{date}'.format(channel=channel, date=n_date)
  361. else:
  362. if nickname:
  363. message_title = "zosi({nickname})".format(nickname=nickname)
  364. else:
  365. message_title = "zosi({uid})".format(uid=uid)
  366. send_text = 'channel:{channel} date:{date}'.format(channel=channel, date=n_date)
  367. android = jpush.android(alert=send_text, priority=1, style=1, alert_type=7,
  368. big_text=send_text, title=message_title,
  369. extras=push_data)
  370. push.notification = jpush.notification(android=android)
  371. push.platform = jpush.all_
  372. try:
  373. res = push.send()
  374. print(res)
  375. except Exception as e:
  376. print("Exception")
  377. print(repr(e))
  378. return response.json(10, repr(e))
  379. else:
  380. return response.json(0)
  381. '''
  382. def do_gmc(self, request_dict, uaql, response, uid, channel):
  383. n_time = request_dict.get('n_time')
  384. appBundleId = uaql['appBundleId']
  385. token_val = uaql['token_val']
  386. gcm_config = {
  387. 'com.ansjer.zccloud_a': 'AAAAb9YP3rk:APA91bHu8u-CTpcd0g6lKPo0WNVqCi8jZub1cPPbSAY9AucT1HxlF65ZDUko9iG8q2ch17bwu9YWHpK1xI1gHSRXCslLvZlXEmHZC0AG3JKg15XuUvlFKACIajUFV-pOeGRT8tM6-31I',
  388. 'com.ansjer.loocamccloud_a': 'AAAAb9YP3rk:APA91bFCgd-kbVmpK4EVpfdHH_PJZQCYTkOGnTZdIuBWEz2r7aMRsJYHOH3sB-rwcbaRWgnufTyjX9nGQxb6KxQbWVk4ah_H-M3IqGh6Mb60WQQAuR33V6g_Jes5pGL6ViuIxGHqVMaR',
  389. 'com.ansjer.loocamdcloud_a': 'AAAAb9YP3rk:APA91bGw2I2KMD4i-5T7nZO_wB8kuAOuqgyqe5rxmY-W5qkpYEx9IL2IfmC_qf6B_xOyjIDDSjckvMo-RauN__SEoxvAkis7042GRkoKpw7cjZ_H8lC-d50PC0GclPzccrOGFusyKbFY',
  390. 'com.ansjer.customizedb_a': 'AAAAb9YP3rk:APA91bE7kI4vcm-9h_CJNFlOZfc-xwP4Btn6AnjOrwoKV6fgYN7fdarkO76sYxVZiAbDnxsFfOJyP7vQfwyan6mdjuyD5iHdt_XgO22VqniC0vA1V4GJiCS8Tp7LxIX8JVKZl9I_Powt',
  391. 'com.ansjer.customizeda_a': 'AAAAb9YP3rk:APA91bF0HzizVWDc6dKzobY9fsaKDK4veqkOZehDXshVXs8pEEvNWjR_YWbhP60wsRYCHCal8fWN5cECVOWNMMzDsfU88Ty2AUl8S5FtZsmeDTkoGntQOswBr8Ln7Fm_LAp1VqTf9CpM',
  392. }
  393. serverKey = gcm_config[appBundleId]
  394. event_type = request_dict.get('event_type', None)
  395. push_data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
  396. "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1"}
  397. json_data = {
  398. "collapse_key": "WhatYouWant",
  399. "data": push_data,
  400. "delay_while_idle": False,
  401. "time_to_live": 3600,
  402. "registration_ids": [token_val]
  403. }
  404. url = 'https://android.googleapis.com/gcm/send'
  405. # serverKey = "AAAAb9YP3rk:APA91bHu8u-CTpcd0g6lKPo0WNVqCi8jZub1cPPbSAY9AucT1HxlF65ZDUko9iG8q2ch17bwu9YWHpK1xI1gHSRXCslLvZlXEmHZC0AG3JKg15XuUvlFKACIajUFV-pOeGRT8tM6-31I"
  406. data = json.dumps(json_data).encode('utf-8')
  407. headers = {'Content-Type': 'application/json', 'Authorization': 'key=%s' % serverKey}
  408. req = requests.post(url, data, headers=headers)
  409. return response.json(0)
  410. '''
  411. def do_fcm(self, request_dict, uaql, response, uid, channel, nickname):
  412. n_time = request_dict.get('n_time')
  413. appBundleId = uaql['appBundleId']
  414. token_val = uaql['token_val']
  415. lang = uaql['lang']
  416. fcm_config = {
  417. 'com.ansjer.zccloud_a': 'AAAAb9YP3rk:APA91bHu8u-CTpcd0g6lKPo0WNVqCi8jZub1cPPbSAY9AucT1HxlF65ZDUko9iG8q2ch17bwu9YWHpK1xI1gHSRXCslLvZlXEmHZC0AG3JKg15XuUvlFKACIajUFV-pOeGRT8tM6-31I',
  418. 'com.ansjer.loocamccloud_a': 'AAAAb9YP3rk:APA91bFCgd-kbVmpK4EVpfdHH_PJZQCYTkOGnTZdIuBWEz2r7aMRsJYHOH3sB-rwcbaRWgnufTyjX9nGQxb6KxQbWVk4ah_H-M3IqGh6Mb60WQQAuR33V6g_Jes5pGL6ViuIxGHqVMaR',
  419. 'com.ansjer.loocamdcloud_a': 'AAAAb9YP3rk:APA91bGw2I2KMD4i-5T7nZO_wB8kuAOuqgyqe5rxmY-W5qkpYEx9IL2IfmC_qf6B_xOyjIDDSjckvMo-RauN__SEoxvAkis7042GRkoKpw7cjZ_H8lC-d50PC0GclPzccrOGFusyKbFY',
  420. 'com.ansjer.customizedb_a': 'AAAAb9YP3rk:APA91bE7kI4vcm-9h_CJNFlOZfc-xwP4Btn6AnjOrwoKV6fgYN7fdarkO76sYxVZiAbDnxsFfOJyP7vQfwyan6mdjuyD5iHdt_XgO22VqniC0vA1V4GJiCS8Tp7LxIX8JVKZl9I_Powt',
  421. 'com.ansjer.customizeda_a': 'AAAAb9YP3rk:APA91bF0HzizVWDc6dKzobY9fsaKDK4veqkOZehDXshVXs8pEEvNWjR_YWbhP60wsRYCHCal8fWN5cECVOWNMMzDsfU88Ty2AUl8S5FtZsmeDTkoGntQOswBr8Ln7Fm_LAp1VqTf9CpM',
  422. 'com.ansjer.customizedd_a': 'AAAAb9YP3rk:APA91bHkxOozJWBrlv3eNT0PgwosYENI9aM4Zuzd418cX-iKkpa1zFNC5MkNDKApx1KH4fhmAfaJ6IMRZ0nj5GIxCpstDYCaZWwgC7-etqfSxG5JAq8LOwJx0o_1tUZqwjIic8ztsg0o'
  423. }
  424. serverKey = fcm_config[appBundleId]
  425. event_type = request_dict.get('event_type', None)
  426. push_service = FCMNotification(api_key=serverKey)
  427. registration_id = token_val
  428. n_date = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(n_time)))
  429. if lang == 'cn':
  430. if nickname:
  431. message_title = "周视({nickname})".format(nickname=nickname)
  432. else:
  433. message_title = "周视({uid})".format(uid=uid)
  434. send_text = '通道:{channel} 日期:{date}'.format(channel=channel, date=n_date)
  435. else:
  436. if nickname:
  437. message_title = "zosi({nickname})".format(nickname=nickname)
  438. else:
  439. message_title = "zosi({uid})".format(uid=uid)
  440. send_text = 'channel:{channel} date:{date}'.format(channel=channel, date=n_date)
  441. data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
  442. "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1", "channel": channel}
  443. result = push_service.notify_single_device(registration_id=registration_id, message_title=message_title,
  444. message_body=send_text, data_message=data,
  445. extra_kwargs={
  446. 'default_vibrate_timings': True,
  447. 'default_sound': True,
  448. 'default_light_settings': True
  449. })
  450. response = ResponseObject()
  451. return response.json(0, result)
  452. def do_apns(self, request_dict, uaql, response, uid, channel, nickname):
  453. event_type = request_dict.get('event_type', None)
  454. token_val = uaql['token_val']
  455. lang = uaql['lang']
  456. n_time = request_dict.get('n_time')
  457. appBundleId = uaql['appBundleId']
  458. apns_config = {
  459. 'com.ansjer.loocamccloud': {
  460. 'pem_path': os.path.join(BASE_DIR, 'Ansjer/file/apns_pem/apns-dev-test.pem'),
  461. 'password': '111111'
  462. }
  463. }
  464. n_date = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(n_time)))
  465. if lang == 'cn':
  466. if nickname:
  467. message_title = "周视({nickname})".format(nickname=nickname)
  468. else:
  469. message_title = "周视({uid})".format(uid=uid)
  470. send_text = '通道:{channel} 日期:{date}'.format(channel=channel, date=n_date)
  471. else:
  472. if nickname:
  473. message_title = "zosi({nickname})".format(nickname=nickname)
  474. else:
  475. message_title = "zosi({uid})".format(uid=uid)
  476. send_text = 'channel:{channel} date:{date}'.format(channel=channel, date=n_date)
  477. try:
  478. cli = apns2.APNSClient(mode="dev", client_cert=apns_config[appBundleId]['pem_path'],
  479. password=apns_config[appBundleId]['password'])
  480. push_data = {"alert": "Motion ", "event_time": n_time, "event_type": event_type, "msg": "",
  481. "received_at": n_time, "sound": "sound.aif", "uid": uid, "zpush": "1", "channel": channel}
  482. # body = json.dumps(push_data)
  483. alert = apns2.PayloadAlert(body=send_text, title=message_title)
  484. payload = apns2.Payload(alert=alert, custom=push_data)
  485. n = apns2.Notification(payload=payload, priority=apns2.PRIORITY_LOW)
  486. res = cli.push(n=n, device_token=token_val, topic=appBundleId)
  487. # assert res.status_code == 200, res.reason
  488. # assert res.apns_id
  489. if res.status_code == 200:
  490. return response.json(0)
  491. else:
  492. return response.json(404, res.reason)
  493. except Exception as e:
  494. return response.json(10, repr(e))
  495. def do_bulk_create_info(self, uaqs, n_time, channel, event_type, is_st, uid):
  496. #
  497. qs_list = []
  498. nowTime = int(time.time())
  499. # 设备昵称
  500. for dv in uaqs:
  501. add_data = {
  502. 'userID_id': dv["userID_id"],
  503. 'eventTime': n_time,
  504. 'eventType': event_type,
  505. 'devUid': uid,
  506. 'devNickName': uid,
  507. 'Channel': channel,
  508. 'alarm': 'Motion \tChannel:{channel}'.format(channel=channel),
  509. 'is_st': int(is_st),
  510. 'receiveTime': n_time,
  511. 'addTime': nowTime
  512. }
  513. qs_list.append(Equipment_Info(**add_data))
  514. if qs_list:
  515. print(1)
  516. Equipment_Info.objects.bulk_create(qs_list)
  517. return True
  518. else:
  519. return False