EquipmentManager.py 48 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222
  1. import re
  2. import time
  3. import traceback
  4. import threading
  5. import logging
  6. import requests
  7. import simplejson as json
  8. from django.utils import timezone
  9. from Model.models import Device_User, Device_Info, UID_Bucket, UID_Preview, UidSetModel, UidPushModel, \
  10. UIDCompanySerialModel, iotdeviceInfoModel, UIDMainUser
  11. from django.db.models import Q
  12. from Object.ResponseObject import ResponseObject
  13. from Object.TokenObject import TokenObject
  14. from Service.CommonService import CommonService
  15. from Service.ModelService import ModelService
  16. from Ansjer.config import OSS_STS_ACCESS_SECRET, OSS_STS_ACCESS_KEY, BASE_DIR
  17. from Object.ETkObject import ETkObject
  18. import oss2
  19. from django.http import JsonResponse
  20. from Object.RedisObject import RedisObject
  21. from Controller.DetectController import DetectControllerView
  22. # 查询用户设备
  23. def queryUserEquipmentInterface(request):
  24. request.encoding = 'utf-8'
  25. response = ResponseObject()
  26. if request.method == 'POST':
  27. request_dict = request.POST
  28. elif request.method == 'GET':
  29. request_dict = request.GET
  30. else:
  31. return response.json(444)
  32. token = request_dict.get('token', None)
  33. tko = TokenObject(token)
  34. response.lang = tko.lang
  35. if tko.code != 0:
  36. return response.json(tko.code)
  37. userID = tko.userID
  38. if not userID:
  39. return response.json(309)
  40. dvqs = Device_Info.objects.filter(userID_id=userID)
  41. dvdict = CommonService.qs_to_dict(dvqs)
  42. uid_list = Device_Info.objects.filter(userID_id=userID, isShare=False). \
  43. values_list('UID', flat=True)
  44. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  45. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  46. res = []
  47. nowTime = int(time.time())
  48. for p in dvdict['datas']:
  49. p['fields']['vod'] = []
  50. for dm in ubqs:
  51. if p['fields']['UID'] == dm['uid']:
  52. if dm['endTime'] > nowTime:
  53. p['fields']['vod'].append(dm)
  54. # dm['valid'] = 1
  55. # else:
  56. # dm['valid'] = 0
  57. # p['fields']['primaryUserID'] = ''
  58. res.append(p)
  59. return response.json(0, {'datas': res})
  60. def addNewUserEquipmentInterface(request):
  61. request.encoding = 'utf-8'
  62. response = ResponseObject()
  63. if request.method == 'POST':
  64. request_dict = request.POST
  65. elif request.method == 'GET':
  66. request_dict = request.GET
  67. else:
  68. return response.json(444)
  69. token = request_dict.get('token', None)
  70. deviceContent = request_dict.get('content', None)
  71. if not deviceContent:
  72. return response.json(444, 'content')
  73. tko = TokenObject(token)
  74. response.lang = tko.lang
  75. if tko.code != 0:
  76. return response.json(tko.code)
  77. userID = tko.userID
  78. try:
  79. deviceData = json.loads(deviceContent)
  80. UID = deviceData.get('UID', None)
  81. if not UID:
  82. return response.json(444, 'content')
  83. dValid = Device_Info.objects.filter(userID_id=userID, UID=UID)
  84. if dValid:
  85. return response.json(174)
  86. else:
  87. # redisObj = RedisObject(db=8)
  88. # redisObj.del_data(key='uid_qs_' + userID)
  89. UID = deviceData.get('UID', '')
  90. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  91. if re_uid.match(UID):
  92. userDevice = Device_Info(id=CommonService.getUserID(getUser=False), userID_id=userID,
  93. **deviceData)
  94. userDevice.save()
  95. if UID == '98UXAA8BRPA35VAL111A':
  96. asy = threading.Thread(target=ModelService.add_log,
  97. args=(CommonService.get_ip_address(request), userID, 'addV0'))
  98. asy.start()
  99. # is_bind = Device_Info.objects.filter(UID=UID, isShare=False)
  100. # # 判断是否有已绑定用户
  101. # if not is_bind.exists():
  102. # userDevice = Device_Info(id=CommonService.getUserID(getUser=False), userID_id=userID,
  103. # **deviceData)
  104. # userDevice.save()
  105. # else:
  106. # # 分享添加
  107. # if 'isShare' in deviceData:
  108. # deviceData['isShare'] = True
  109. # else:
  110. # deviceData['isShare'] = True
  111. # bind_userID = is_bind[0].userID_id
  112. # userDevice = Device_Info(id=CommonService.getUserID(getUser=False),
  113. # userID_id=userID,
  114. # primaryUserID=bind_userID,
  115. # primaryMaster=ModelService.get_user_name(bind_userID),
  116. # **deviceData)
  117. # userDevice.save()
  118. else:
  119. return response.json(444, 'UID')
  120. except Exception as e:
  121. errorInfo = traceback.format_exc()
  122. print('添加设备错误: %s ' % errorInfo)
  123. return response.json(178, repr(e))
  124. else:
  125. sqlDict = CommonService.qs_to_dict([userDevice])
  126. return response.json(0, sqlDict)
  127. def delUserEquipmentInterface(request):
  128. '''
  129. 删除用户设备
  130. :param request:
  131. :return:
  132. '''
  133. response = ResponseObject()
  134. request.encoding = 'utf-8'
  135. if request.method == 'POST':
  136. request_dict = request.POST
  137. elif request.method == 'GET':
  138. request_dict = request.GET
  139. else:
  140. return response.json(444)
  141. token = request_dict.get('token', None)
  142. id = request_dict.get('id', None)
  143. if not id:
  144. return response.json(444, 'id')
  145. tko = TokenObject(token)
  146. response.lang = tko.lang
  147. if tko.code != 0:
  148. return response.json(tko.code)
  149. userID = tko.userID
  150. # 主用户删除设备全部删除
  151. try:
  152. dv_qs = Device_Info.objects.filter(userID_id=userID, id=id)
  153. # redisObj = RedisObject(db=8)
  154. # redisObj.del_data(key='uid_qs_' + userID)
  155. if dv_qs.exists():
  156. uid = dv_qs[0].UID
  157. asy = threading.Thread(target=ModelService.add_log, args=(CommonService.get_ip_address(request), userID, 'deleteV1'))
  158. asy.start()
  159. print('删除')
  160. UID_Preview.objects.filter(uid=uid).delete()
  161. dv_qs.delete()
  162. asy = threading.Thread(target=ModelService.del_eq_info, args=(userID, uid))
  163. asy.start()
  164. except Exception as e:
  165. errorInfo = traceback.format_exc()
  166. print('删除数据库记录错误: %s' % errorInfo)
  167. return response.json(176, repr(e))
  168. else:
  169. return response.json(0)
  170. def modifyUserEquipmentInterface(request):
  171. '''
  172. 修改用户设备
  173. :param request:
  174. :return:
  175. '''
  176. response = ResponseObject()
  177. if request.method == 'POST':
  178. request.encoding = 'utf-8'
  179. request_dict = request.POST
  180. elif request.method == 'GET':
  181. request.encoding = 'utf-8'
  182. request_dict = request.GET
  183. else:
  184. return response.json(444)
  185. token = request_dict.get('token', None)
  186. deviceContent = request_dict.get('content', None)
  187. id = request_dict.get('id', None)
  188. if not deviceContent or not id:
  189. return response.json(444, 'content,id')
  190. tko = TokenObject(token)
  191. response.lang = tko.lang
  192. if tko.code != 0:
  193. return response.json(tko.code)
  194. userID = tko.userID
  195. if userID is None:
  196. return response.json(309)
  197. try:
  198. deviceData = json.loads(deviceContent)
  199. if deviceData.__contains__('userID_id'):
  200. asy = threading.Thread(target=ModelService.update_log,
  201. args=(CommonService.get_ip_address(request), userID, 'modifyV0', deviceData, id))
  202. asy.start()
  203. return response.json(10, '110')
  204. if deviceData.__contains__('UID'):
  205. del deviceData['UID']
  206. dev_info_qs = Device_Info.objects.filter(userID_id=userID, id=id)
  207. dev_info_qs.update(**deviceData)
  208. except Exception as e:
  209. return response.json(177, repr(e))
  210. else:
  211. qs = Device_Info.objects.filter(userID_id=userID, id=id)
  212. res = CommonService.qs_to_dict(qs)
  213. if qs.exists():
  214. uid = qs[0].UID
  215. if uid == '98UXAA8BRPA35VAL111A':
  216. asy = threading.Thread(target=ModelService.update_log,
  217. args=(CommonService.get_ip_address(request), userID, 'modifyV0', deviceContent, id))
  218. asy.start()
  219. nickname = qs[0].NickName
  220. # 增加设备影子信息修改昵称 start
  221. us_qs = UidSetModel.objects.filter(uid=uid)
  222. if us_qs.exists():
  223. us_qs.update(nickname=nickname)
  224. else:
  225. ChannelIndex = qs[0].ChannelIndex
  226. nowTime = int(time.time())
  227. uid_set_create_dict = {
  228. 'uid': uid,
  229. 'addTime': nowTime,
  230. 'updTime': nowTime,
  231. 'ip': CommonService.get_ip_address(request),
  232. 'channel': ChannelIndex,
  233. 'nickname': nickname,
  234. }
  235. UidSetModel.objects.create(**uid_set_create_dict)
  236. Device_Info.objects.filter(UID=uid).update(NickName=nickname)
  237. # redisObj = RedisObject(db=8)
  238. # redisObj.del_data(key='uid_qs_' + userID)
  239. return response.json(0, res)
  240. def showAllUserEquipmentInterface(request, *callback_args, **callback_kwargs):
  241. request.encoding = 'utf-8'
  242. response = ResponseObject()
  243. if request.method == 'POST':
  244. fieldDict = request.POST
  245. elif request.method == 'GET':
  246. fieldDict = request.GET
  247. else:
  248. return response.json(444)
  249. token = request.POST.get('token', None)
  250. type = request.POST.get('type', None)
  251. tko = TokenObject(token)
  252. response.lang = tko.lang
  253. if tko.code != 0:
  254. return response.json(tko.code)
  255. userID = tko.userID
  256. if not userID:
  257. return response.json(309)
  258. own_perm = ModelService.check_perm(userID=userID, permID=30)
  259. if not own_perm:
  260. return response.json(404)
  261. if type == 'PC':
  262. page = int(fieldDict['page'])
  263. line = int(fieldDict['line'])
  264. qs = Device_Info.objects.all()
  265. count = qs.count()
  266. res = qs[(page - 1) * line:page * line]
  267. sqlDict = CommonService.qs_to_dict(query_set=res)
  268. sqlDict['count'] = count
  269. return response.json(0, sqlDict)
  270. else:
  271. qs = Device_Info.objects.all()
  272. res = CommonService.qs_to_dict(qs)
  273. return response.json(0, res)
  274. def findEquipmentInfoInterface(request, *callback_args, **callback_kwargs):
  275. request.encoding = 'utf-8'
  276. response = ResponseObject()
  277. if request.method == 'GET':
  278. fieldDict = request.GET
  279. elif request.method == 'POST':
  280. fieldDict = request.POST
  281. else:
  282. return response.json(444)
  283. deviceContent = fieldDict.get('content', None)
  284. token = fieldDict.get('token', None)
  285. tko = TokenObject(token)
  286. response.lang = tko.lang
  287. if tko.code != 0:
  288. return response.json(tko.code)
  289. if deviceContent:
  290. try:
  291. searchCondition = json.loads(deviceContent)
  292. except Exception as e:
  293. print(repr(e))
  294. return response.json(10, repr(e))
  295. else:
  296. kwargs = CommonService.get_kwargs(data=searchCondition)
  297. qs = Device_Info.objects.filter(**kwargs)
  298. page = int(fieldDict['page'])
  299. line = int(fieldDict['line'])
  300. count = qs.count()
  301. res = qs[(page - 1) * line:page * line]
  302. send_dict = CommonService.qs_to_dict(query_set=res)
  303. for k, v in enumerate(send_dict["datas"]):
  304. for val in res:
  305. if v['pk'] == val.id:
  306. send_dict["datas"][k]['fields']['username'] = \
  307. ModelService.get_user_mark(send_dict["datas"][k]['fields']['userID'])
  308. send_dict["datas"][k]['fields']['primaryusername'] = \
  309. ModelService.get_user_mark(send_dict["datas"][k]['fields']['primaryUserID'])
  310. send_dict['count'] = count
  311. return response.json(0, send_dict)
  312. else:
  313. qs = Device_Info.objects.all()
  314. page = int(fieldDict['page'])
  315. line = int(fieldDict['line'])
  316. count = qs.count()
  317. res = qs[(page - 1) * line:page * line]
  318. send_dict = CommonService.qs_to_dict(query_set=res)
  319. for k, v in enumerate(send_dict["datas"]):
  320. for val in res:
  321. if v['pk'] == val.id:
  322. username = ModelService.get_user_name(send_dict["datas"][k]['fields']['userID'])
  323. send_dict["datas"][k]['fields']['username'] = username
  324. send_dict["datas"][k]['fields']['primaryusername'] = \
  325. ModelService.get_user_mark(send_dict["datas"][k]['fields']['primaryUserID'])
  326. send_dict['count'] = count
  327. return response.json(0, send_dict)
  328. # 添加设备字段
  329. def addInterface(request):
  330. request.encoding = 'utf-8'
  331. response = ResponseObject()
  332. if request.method == 'POST':
  333. request_dict = request.POST
  334. elif request.method == 'GET':
  335. request_dict = request.GET
  336. else:
  337. return response.json(444)
  338. token = request_dict.get('token', None)
  339. UID = request_dict.get('UID', None)
  340. NickName = request_dict.get('NickName', None)
  341. View_Account = request_dict.get('View_Account', None)
  342. View_Password = request_dict.get('View_Password', '')
  343. Type = request_dict.get('Type', None)
  344. ChannelIndex = request_dict.get('ChannelIndex', None)
  345. version = request_dict.get('version', '')
  346. isCheckMainUser = request_dict.get('isCheckMainUser', None)
  347. isMainUserExists = False
  348. if all([UID, NickName, View_Account, Type, ChannelIndex]):
  349. tko = TokenObject(token)
  350. response.lang = tko.lang
  351. if tko.code == 0:
  352. userID = tko.userID
  353. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  354. if re_uid.match(UID):
  355. is_exist = Device_Info.objects.filter(UID=UID, userID_id=userID)
  356. if is_exist:
  357. # 判断设备是否已存在
  358. if is_exist[0].isExist == 1:
  359. return response.json(174)
  360. else:
  361. is_exist.delete()
  362. if UID == '98UXAA8BRPA35VAL111A':
  363. asy = threading.Thread(target=ModelService.add_log,
  364. args=(CommonService.get_ip_address(request), userID, 'addV1'))
  365. asy.start()
  366. return response.json(10, 'illegal uid: {uid}'.format(uid=UID))
  367. pass
  368. pk = CommonService.getUserID(getUser=False)
  369. userName = Device_User.objects.get(userID=userID).username
  370. main_exist = Device_Info.objects.filter(UID=UID)
  371. main_exist = main_exist.filter(~Q(vodPrimaryUserID='')).values('vodPrimaryUserID', 'vodPrimaryMaster')
  372. vodPrimaryUserID = userID
  373. vodPrimaryMaster = userName
  374. if main_exist.exists():
  375. vodPrimaryUserID = main_exist[0]['vodPrimaryUserID']
  376. vodPrimaryMaster = main_exist[0]['vodPrimaryMaster']
  377. is_bind = Device_Info.objects.filter(UID=UID, isShare=False).values('userID__userID', 'vodPrimaryUserID')
  378. # 判断是否有已绑定用户
  379. isvodPrimaryUserID = ''
  380. for forbind in is_bind:
  381. if forbind['vodPrimaryUserID'] != '':
  382. isvodPrimaryUserID = forbind['vodPrimaryUserID']
  383. if isCheckMainUser != '1':
  384. if main_exist.exists():
  385. vodPrimaryUserID = main_exist[0]['vodPrimaryUserID']
  386. vodPrimaryMaster = main_exist[0]['vodPrimaryMaster']
  387. else:
  388. vodPrimaryUserID = ''
  389. vodPrimaryMaster = ''
  390. isusermain = False
  391. if isvodPrimaryUserID != userID and isvodPrimaryUserID != '':
  392. isusermain = True
  393. uid_main_exist = UIDMainUser.objects.filter(UID=UID).values('UID', 'user_id')
  394. if uid_main_exist.exists():
  395. vodPrimaryUserID = uid_main_exist[0]['user_id']
  396. vodPrimaryMaster = Device_User.objects.get(userID=vodPrimaryUserID).username
  397. if vodPrimaryUserID != userID:
  398. isusermain = True
  399. # 判断是否有已绑定用户
  400. if is_bind and isCheckMainUser == '1' and isusermain:
  401. res = {
  402. 'id': pk,
  403. 'userID': userID,
  404. 'NickName': NickName,
  405. 'UID': UID,
  406. 'View_Account': View_Account,
  407. 'View_Password': View_Password,
  408. 'ChannelIndex': ChannelIndex,
  409. 'Type': Type,
  410. 'isShare': False,
  411. 'primaryUserID': '',
  412. 'primaryMaster': '',
  413. 'vodPrimaryUserID': vodPrimaryUserID,
  414. 'vodPrimaryMaster': vodPrimaryMaster,
  415. 'data_joined': '',
  416. 'version': version,
  417. 'isVod': 0,
  418. 'isExist': 1,
  419. 'userID__userEmail': ''
  420. }
  421. res['vod'] = [
  422. {
  423. "status": 1,
  424. "channel": ChannelIndex,
  425. "endTime": '',
  426. "bucket__content": '',
  427. "uid": UID
  428. }
  429. ]
  430. res['isMainUserExists'] = 1
  431. return response.json(0, res)
  432. try:
  433. # 判断是否有用户绑定
  434. nowTime = int(time.time())
  435. us_qs = UidSetModel.objects.filter(uid=UID)
  436. if not us_qs.exists():
  437. uid_set_create_dict = {
  438. 'uid': UID,
  439. 'addTime': nowTime,
  440. 'updTime': nowTime,
  441. 'ip': CommonService.get_ip_address(request),
  442. 'channel': ChannelIndex,
  443. 'nickname': NickName,
  444. 'version': version,
  445. }
  446. UidSetModel.objects.create(**uid_set_create_dict)
  447. else:
  448. us_qs.update(nickname=NickName)
  449. userDevice = Device_Info(id=pk, userID_id=userID, UID=UID,
  450. NickName=NickName, View_Account=View_Account,
  451. View_Password=View_Password, Type=Type, ChannelIndex=ChannelIndex,
  452. version=version, vodPrimaryUserID=vodPrimaryUserID, vodPrimaryMaster=vodPrimaryMaster)
  453. userDevice.save()
  454. uid_serial_qs = UIDCompanySerialModel.objects.filter(
  455. uid__uid=UID)
  456. if uid_serial_qs.exists():
  457. uid_serial = uid_serial_qs[0]
  458. Device_Info.objects.filter(UID=UID).update(vodPrimaryUserID=vodPrimaryUserID,
  459. vodPrimaryMaster=vodPrimaryMaster,
  460. serial_number=uid_serial.company_serial.serial_number.serial_number + uid_serial.company_serial.company.mark)
  461. else:
  462. Device_Info.objects.filter(UID=UID).update(vodPrimaryUserID=vodPrimaryUserID,
  463. vodPrimaryMaster=vodPrimaryMaster)
  464. if isCheckMainUser == '1':
  465. uid_main_dict = {
  466. 'UID': UID,
  467. 'user_id': vodPrimaryUserID
  468. }
  469. UIDMainUser.objects.create(**uid_main_dict)
  470. # redisObj = RedisObject(db=8)
  471. # redisObj.del_data(key='uid_qs_' + userID)
  472. except Exception as e:
  473. return response.json(10, repr(e))
  474. else:
  475. dvqs = Device_Info.objects.filter(id=pk).values('id', 'userID', 'NickName', 'UID',
  476. 'View_Account',
  477. 'View_Password', 'ChannelIndex', 'Type',
  478. 'isShare',
  479. 'primaryUserID', 'primaryMaster', 'vodPrimaryUserID', 'vodPrimaryMaster', 'userID__userEmail',
  480. 'data_joined', 'version',
  481. 'isVod', 'isExist', 'isCameraOpenCloud', 'serial_number')
  482. dvql = CommonService.qs_to_list(dvqs)
  483. ubqs = UID_Bucket.objects.filter(uid=UID). \
  484. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  485. res = dvql[0]
  486. res['vod'] = list(ubqs)
  487. # 新增获取IOT证书内容
  488. iotqs = iotdeviceInfoModel.objects.filter(serial_number__serial_number=dvql[0]['serial_number'])
  489. if iotqs.exists():
  490. res['iot'].append(
  491. {
  492. 'endpoint': iotqs[0].endpoint,
  493. 'token_iot_number': iotqs[0].endpoint
  494. }
  495. )
  496. if isMainUserExists:
  497. res['isMainUserExists'] = 1
  498. return response.json(0, res)
  499. else:
  500. return response.json(444, {'param': 'UID'})
  501. else:
  502. return response.json(tko.code)
  503. else:
  504. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex,version'})
  505. # 添加设备字段
  506. def judgeInterface(request):
  507. request.encoding = 'utf-8'
  508. response = ResponseObject()
  509. if request.method == 'POST':
  510. request_dict = request.POST
  511. elif request.method == 'GET':
  512. request_dict = request.GET
  513. else:
  514. return response.json(444)
  515. token = request_dict.get('token', None)
  516. uid = request_dict.get('uid', None)
  517. if all([uid, token]):
  518. tko = TokenObject(token)
  519. response.lang = tko.lang
  520. if tko.code == 0:
  521. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  522. if re_uid.match(uid):
  523. is_bind = Device_Info.objects.filter(UID=uid, isShare=False)
  524. # 判断是否有已绑定用户
  525. if is_bind:
  526. qs = is_bind.values('userID__NickName', 'NickName')
  527. nickname = qs[0]['NickName']
  528. us_qs = UidSetModel.objects.filter(uid=uid).values('nickname')
  529. if us_qs.exists():
  530. nickname = us_qs[0]['NickName']
  531. res = {
  532. 'bind_user': qs[0]['userID__NickName'],
  533. 'bind_device_name': nickname,
  534. }
  535. return response.json(15, res=res)
  536. else:
  537. return response.json(0, 'no bind user')
  538. else:
  539. return response.json(444, {'param': 'UID'})
  540. else:
  541. return response.json(tko.code)
  542. else:
  543. return response.json(444, {'param': 'UID,NickName,View_Account,View_Password,Type,ChannelIndex'})
  544. # 管理员添加
  545. def admin_addInterface(request):
  546. request.encoding = 'utf-8'
  547. response = ResponseObject()
  548. if request.method == 'POST':
  549. request_dict = request.POST
  550. elif request.method == 'GET':
  551. request_dict = request.GET
  552. else:
  553. return response.json(444)
  554. token = request_dict.get('token', None)
  555. deviceContent = request_dict.get('content', None)
  556. ipdizhi = request_dict.get('ipdizhi', None)
  557. username = request_dict.get('username', None)
  558. if not username:
  559. return response.json(444, 'username')
  560. if not deviceContent:
  561. return response.json(444, 'content')
  562. tko = TokenObject(token)
  563. response.lang = tko.lang
  564. if tko.code != 0:
  565. return response.json(tko.code)
  566. userID = tko.userID
  567. own_perm = ModelService.check_perm(userID, 40)
  568. # 权限判断
  569. if own_perm is not True:
  570. return response.json(404)
  571. # 查询id
  572. user = Device_User.objects.filter(Q(username=username) | Q(phone=username) | Q(userEmail=username))
  573. if user.exists():
  574. user_dict = CommonService.qs_to_dict(user)
  575. userID = user_dict.get('datas')[0].get('pk')
  576. else:
  577. return response.json(104)
  578. print(deviceContent)
  579. try:
  580. deviceData = json.loads(deviceContent)
  581. UID = deviceData.get('UID', None)
  582. if not UID:
  583. return response.json(444, 'content')
  584. dValid = Device_Info.objects.filter(userID_id=userID, UID=UID)
  585. if dValid:
  586. return response.json(174)
  587. else:
  588. UID = deviceData.get('UID', '')
  589. re_uid = re.compile(r'^[A-Za-z0-9]{20}$')
  590. # redisObj = RedisObject(db=8)
  591. # redisObj.del_data(key='uid_qs_' + userID)
  592. if re_uid.match(UID):
  593. userDevice = Device_Info(id=CommonService.getUserID(getUser=False), userID_id=userID,
  594. **deviceData)
  595. userDevice.save()
  596. file_path = '/'.join((BASE_DIR, 'static/test.log'))
  597. file = open(file_path, 'a+')
  598. file.write(ipdizhi + "; username:" + username + "; time:" + time.strftime("%Y-%m-%d %H:%M:%S",
  599. time.localtime()))
  600. file.write('\n')
  601. file.flush()
  602. file.close()
  603. # is_bind = Device_Info.objects.filter(UID=UID, isShare=False)
  604. # # 判断是否有已绑定用户
  605. # if not is_bind.exists():
  606. # userDevice = Device_Info(id=CommonService.getUserID(getUser=False), userID_id=userID,
  607. # **deviceData)
  608. # userDevice.save()
  609. # else:
  610. # # 分享添加
  611. # if 'isShare' in deviceData:
  612. # deviceData['isShare'] = True
  613. # else:
  614. # deviceData['isShare'] = True
  615. # bind_userID = is_bind[0].userID_id
  616. # userDevice = Device_Info(id=CommonService.getUserID(getUser=False),
  617. # userID_id=userID,
  618. # primaryUserID=bind_userID,
  619. # primaryMaster=ModelService.get_user_name(bind_userID),
  620. # **deviceData)
  621. # userDevice.save()
  622. else:
  623. return response.json(444, 'UID')
  624. except Exception as e:
  625. errorInfo = traceback.format_exc()
  626. print('添加设备错误: %s ' % errorInfo)
  627. return response.json(178, repr(e))
  628. else:
  629. sqlDict = CommonService.qs_to_dict([userDevice])
  630. return response.json(0, sqlDict)
  631. # 超级管理员修改设备
  632. def admin_modifyInterface(request):
  633. response = ResponseObject()
  634. if request.method == 'POST':
  635. request.encoding = 'utf-8'
  636. request_dict = request.POST
  637. elif request.method == 'GET':
  638. request.encoding = 'utf-8'
  639. request_dict = request.GET
  640. else:
  641. return response.json(444)
  642. token = request_dict.get('token', None)
  643. deviceContent = request_dict.get('content', None)
  644. username = request_dict.get('username', None)
  645. if not username:
  646. return response.json(444, 'username')
  647. id = request_dict.get('id', None)
  648. print(deviceContent)
  649. if not deviceContent or not id:
  650. return response.json(444, 'content,id')
  651. tko = TokenObject(token)
  652. response.lang = tko.lang
  653. if tko.code != 0:
  654. return response.json(tko.code)
  655. userID = tko.userID
  656. if userID is None:
  657. return response.json(309)
  658. own_perm = ModelService.check_perm(userID, 50)
  659. # 权限判断
  660. if own_perm is not True:
  661. return response.json(404)
  662. deviceData = json.loads(deviceContent)
  663. print(deviceData['UID'])
  664. # redisObj = RedisObject(db=8)
  665. # redisObj.del_data(key='uid_qs_' + userID)
  666. dValid = Device_Info.objects.filter(userID_id=userID, UID=deviceData['UID'])
  667. if dValid.exists():
  668. dValid_dict = CommonService.qs_to_dict(dValid)
  669. print(dValid_dict.get('datas')[0].get('pk'))
  670. if dValid_dict.get('datas')[0].get('pk') == id:
  671. print('可以编辑')
  672. else:
  673. return response.json(174)
  674. # 查询id
  675. user = Device_User.objects.filter(Q(username=username) | Q(phone=username) | Q(userEmail=username))
  676. if user.exists():
  677. user_dict = CommonService.qs_to_dict(user)
  678. userID = user_dict.get('datas')[0].get('pk')
  679. try:
  680. # 更改的时间
  681. update_time = timezone.localtime(timezone.now())
  682. Device_Info.objects.filter(userID_id=userID, id=id).update(update_time=update_time, **deviceData)
  683. except Exception as e:
  684. return response.json(177, repr(e))
  685. else:
  686. qs = Device_Info.objects.filter(userID_id=userID, id=id)
  687. res = CommonService.qs_to_dict(qs)
  688. return response.json(0, res)
  689. else:
  690. # 查询id
  691. user = Device_User.objects.filter(Q(username=username) | Q(phone=username) | Q(userEmail=username))
  692. if user.exists():
  693. user_dict = CommonService.qs_to_dict(user)
  694. userID = user_dict.get('datas')[0].get('pk')
  695. try:
  696. # 更改的时间
  697. update_time = timezone.localtime(timezone.now())
  698. Device_Info.objects.filter(userID_id=userID, id=id).update(update_time=update_time, **deviceData)
  699. except Exception as e:
  700. return response.json(177, repr(e))
  701. else:
  702. qs = Device_Info.objects.filter(userID_id=userID, id=id)
  703. res = CommonService.qs_to_dict(qs)
  704. return response.json(0, res)
  705. # 新删除设备
  706. def deleteInterface(request):
  707. '''
  708. 删除用户设备
  709. :param request:
  710. :return:
  711. '''
  712. response = ResponseObject()
  713. request.encoding = 'utf-8'
  714. if request.method == 'POST':
  715. request_dict = request.POST
  716. elif request.method == 'GET':
  717. request_dict = request.GET
  718. else:
  719. return response.json(444)
  720. token = request_dict.get('token', None)
  721. id = request_dict.get('id', None)
  722. if not id:
  723. return response.json(444, 'id')
  724. tko = TokenObject(token)
  725. response.lang = tko.lang
  726. if tko.code != 0:
  727. return response.json(tko.code)
  728. userID = tko.userID
  729. # 主用户删除设备全部删除
  730. if not userID:
  731. return response.json(309)
  732. try:
  733. dv_qs = Device_Info.objects.filter(userID_id=userID, id=id)
  734. if dv_qs.exists():
  735. uid = dv_qs[0].UID
  736. asy = threading.Thread(target=ModelService.delete_log,
  737. args=(CommonService.get_ip_address(request), userID, 'deleteV2', uid))
  738. asy.start()
  739. if dv_qs[0].isShare:
  740. dv_qs.delete()
  741. else:
  742. # a.主用户删除设备
  743. dv_qs.delete()
  744. # 删除设备影子信息uid_set 外键关联删除设备推送配置信息 uid_push
  745. up_qs = UidPushModel.objects.filter(uid_set__uid=uid)
  746. DetectControllerView().do_delete_redis(uid)
  747. if up_qs.count() > 1:
  748. UidPushModel.objects.filter(uid_set__uid=uid, userID_id=userID).delete()
  749. redisObj = RedisObject(db=6, SERVER_HOST='push.dvema.com')
  750. ykey = '{uid}_redis_qs'.format(uid=uid)
  751. if ykey:
  752. redisObj.del_data(key=ykey)
  753. else:
  754. up_qs.delete()
  755. # b.分享获得用户假删除
  756. ud_dv_qs = Device_Info.objects.filter(UID=uid, isShare=True, primaryUserID=userID)
  757. if ud_dv_qs.exists():
  758. ud_dv_qs.update(isExist=0)
  759. # 异步删除推送消息
  760. asy = threading.Thread(target=ModelService.del_eq_info, args=(userID, uid))
  761. asy.start()
  762. # redisObj = RedisObject(db=8)
  763. # redisObj.del_data(key='uid_qs_' + userID)
  764. else:
  765. return response.json(14)
  766. except Exception as e:
  767. errorInfo = traceback.format_exc()
  768. print('删除数据库记录错误: %s' % errorInfo)
  769. return response.json(176, repr(e))
  770. else:
  771. return response.json(0)
  772. # 新查询设备字段
  773. def queryInterface(request):
  774. request.encoding = 'utf-8'
  775. response = ResponseObject()
  776. if request.method == 'POST':
  777. request_dict = request.POST
  778. elif request.method == 'GET':
  779. request_dict = request.GET
  780. else:
  781. return response.json(444)
  782. token = request_dict.get('token', None)
  783. page = request_dict.get('page', None)
  784. line = request_dict.get('line', None)
  785. NickName = request_dict.get('NickName', None)
  786. uid = request_dict.get('uid', None)
  787. page = int(page)
  788. line = int(line)
  789. tko = TokenObject(token)
  790. response.lang = tko.lang
  791. if page <= 0:
  792. return response.json(0)
  793. if tko.code == 0:
  794. userID = tko.userID
  795. dvqs = Device_Info.objects.filter(userID_id=userID)
  796. # # 已重置的设备
  797. # dvqs = dvqs.filter(~Q(isExist=2))
  798. if NickName:
  799. dvqs = dvqs.filter(NickName__icontains=NickName)
  800. if uid:
  801. dvqs = dvqs.filter(UID=uid)
  802. # count = dvqs.count()
  803. dvql = dvqs[(page - 1) * line:page * line].values('id', 'userID', 'NickName', 'UID', 'View_Account',
  804. 'View_Password', 'ChannelIndex', 'Type', 'isShare',
  805. 'primaryUserID', 'primaryMaster', 'data_joined', 'version', 'vodPrimaryUserID', 'vodPrimaryMaster', 'userID__userEmail',
  806. 'isVod', 'isExist', 'NotificationMode', 'isCameraOpenCloud', 'serial_number')
  807. dvls = CommonService.qs_to_list(dvql)
  808. uid_list = []
  809. serial_number_list = []
  810. for dvl in dvls:
  811. if dvl['primaryUserID'] and dvl['id'] == dvl['primaryUserID']:
  812. dvl['isPrimaryUser'] = 1
  813. else:
  814. dvl['isPrimaryUser'] = 0
  815. uid_list.append(dvl['UID'])
  816. serial_number_list.append(dvl['serial_number'][0:6])
  817. #新增获取IOT证书内容
  818. iotqs = iotdeviceInfoModel.objects.filter(serial_number__serial_number__in=serial_number_list)
  819. ubqs = UID_Bucket.objects.filter(uid__in=uid_list). \
  820. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  821. upqs = UID_Preview.objects.filter(uid__in=uid_list).order_by('channel').values('id', 'uid', 'channel')
  822. auth = oss2.Auth(OSS_STS_ACCESS_KEY, OSS_STS_ACCESS_SECRET)
  823. bucket = oss2.Bucket(auth, 'oss-cn-hongkong.aliyuncs.com', 'statres')
  824. nowTime = int(time.time())
  825. data = []
  826. # 设备拓展信息表
  827. us_qs = UidSetModel.objects.filter(uid__in=uid_list).\
  828. values('uid', 'version', 'nickname', 'detect_interval')
  829. uv_dict = {}
  830. for us in us_qs:
  831. uv_dict[us['uid']] = {'version': us['version'],
  832. 'nickname': us['nickname'],
  833. 'detect_interval': us['detect_interval']}
  834. for p in dvls:
  835. #新增IOT
  836. p['iot'] = []
  837. for iot in iotqs:
  838. if p['serial_number'][0:6] == iot.serial_number.serial_number:
  839. p['iot'].append(
  840. {
  841. 'endpoint':iot.endpoint,
  842. 'token_iot_number':iot.token_iot_number
  843. }
  844. )
  845. p['vod'] = []
  846. for dm in ubqs:
  847. if p['UID'] == dm['uid']:
  848. if dm['endTime'] > nowTime:
  849. p['vod'].append(dm)
  850. p['preview'] = []
  851. for up in upqs:
  852. if p['UID'] == up['uid']:
  853. obj = 'uid_preview/{uid}/channel_{channel}.png'.\
  854. format(uid=up['uid'], channel=up['channel'])
  855. img_sign = bucket.sign_url('GET', obj, 300)
  856. p['preview'].append(img_sign)
  857. p_uid = p['UID']
  858. if p_uid in uv_dict:
  859. # 设备版本号
  860. p['uid_version'] = uv_dict[p_uid]['version']
  861. p['detect_interval'] = uv_dict[p_uid]['detect_interval']
  862. # 设备昵称 调用影子信息昵称,先阶段不可
  863. if uv_dict[p_uid]['nickname']:
  864. p['NickName'] = uv_dict[p_uid]['nickname']
  865. else:
  866. # 设备版本号
  867. p['uid_version'] = ''
  868. data.append(p)
  869. return response.json(0, data)
  870. else:
  871. return response.json(tko.code)
  872. def uid_status(request):
  873. request.encoding = 'utf-8'
  874. response = ResponseObject()
  875. if request.method == 'POST':
  876. request_dict = request.POST
  877. elif request.method == 'GET':
  878. request_dict = request.GET
  879. else:
  880. return response.json(444)
  881. token = request_dict.get('token', None)
  882. uid = request_dict.get('uid', None)
  883. tko = TokenObject(token)
  884. response.lang = tko.lang
  885. if tko.code != 0:
  886. return response.json(tko.code)
  887. userID = tko.userID
  888. # 调试
  889. logger = logging.getLogger('django')
  890. debugOne = int(time.time())
  891. # 判断用户是否绑定设备
  892. qs = UidSetModel.objects.filter(uid=uid).values('uid', 'detect_status', 'detect_interval', 'version', 'ucode',
  893. 'p2p_region', 'tz', 'video_code', 'channel', 'cloud_vod', 'id',
  894. 'detect_group', 'is_alexa', 'region_alexa')
  895. # 调试
  896. debugOnes = int(time.time())
  897. logger.error('————————debugOne_sec:', debugOnes - debugOne)
  898. # 判断uid配置表信息是否存在
  899. if qs.exists():
  900. # 获取uid推送是否添加过
  901. us_id = qs[0]['id']
  902. # 调试
  903. debugTwo = int(time.time())
  904. if UidPushModel.objects.filter(uid_set_id=us_id, userID_id=userID).exists():
  905. detect_status = qs[0]['detect_status']
  906. else:
  907. detect_status = 0
  908. data = {
  909. 'push_status': detect_status, # 推送状态
  910. 'push_interval': qs[0]['detect_interval'], # 推送间隔
  911. 'ucode': qs[0]['ucode'],
  912. 'version': qs[0]['version'],
  913. 'p2p_region': qs[0]['p2p_region'],
  914. 'tz': qs[0]['tz'],
  915. 'video_code': qs[0]['video_code'],
  916. 'channel': qs[0]['channel'],
  917. 'cloud_vod': qs[0]['cloud_vod'],
  918. 'detect_group': qs[0]['detect_group'], # 推送组
  919. 'is_alexa': qs[0]['is_alexa'], # 推送组
  920. 'region_alexa': qs[0]['region_alexa'], # 推送组
  921. }
  922. # 调试
  923. debugTwos = int(time.time())
  924. logger.error('————————debugTwo_sec:', debugTwos - debugTwo)
  925. # 调试
  926. debugThere = int(time.time())
  927. # 查询云存储相关信息
  928. ubqs = UID_Bucket.objects.filter(uid=uid). \
  929. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  930. # 调试
  931. debugTheres = int(time.time())
  932. logger.error('————————debugTheres_sec:', debugTheres - debugThere)
  933. nowTime = int(time.time())
  934. if ubqs.exists():
  935. if ubqs[0]['endTime'] > nowTime:
  936. data['vod'] = list(ubqs)
  937. return response.json(0, data)
  938. else:
  939. return response.json(0)
  940. def uid_status_test(request):
  941. request.encoding = 'utf-8'
  942. response = ResponseObject()
  943. if request.method == 'POST':
  944. request_dict = request.POST
  945. elif request.method == 'GET':
  946. request_dict = request.GET
  947. else:
  948. return response.json(444)
  949. token = request_dict.get('token', None)
  950. uid = request_dict.get('uid', None)
  951. tko = TokenObject(token)
  952. response.lang = tko.lang
  953. if tko.code != 0:
  954. return response.json(tko.code)
  955. userID = tko.userID
  956. # 判断用户是否绑定设备
  957. print(100000000000)
  958. qs = UidSetModel.objects.filter(uid=uid).values('uid', 'detect_status', 'detect_interval', 'version', 'ucode',
  959. 'p2p_region', 'tz', 'video_code', 'channel', 'cloud_vod', 'id',
  960. 'detect_group', 'is_alexa', 'region_alexa')
  961. # 判断uid配置表信息是否存在
  962. if qs.exists():
  963. # 获取uid推送是否添加过
  964. print(1111111111111)
  965. us_id = qs[0]['id']
  966. if UidPushModel.objects.filter(uid_set_id=us_id, userID_id=userID).exists():
  967. detect_status = qs[0]['detect_status']
  968. else:
  969. detect_status = 0
  970. data = {
  971. 'push_status': detect_status, # 推送状态
  972. 'push_interval': qs[0]['detect_interval'], # 推送间隔
  973. 'ucode': qs[0]['ucode'],
  974. 'version': qs[0]['version'],
  975. 'p2p_region': qs[0]['p2p_region'],
  976. 'tz': qs[0]['tz'],
  977. 'video_code': qs[0]['video_code'],
  978. 'channel': qs[0]['channel'],
  979. 'cloud_vod': qs[0]['cloud_vod'],
  980. 'detect_group': qs[0]['detect_group'], # 推送组
  981. 'is_alexa': qs[0]['is_alexa'], # 推送组
  982. 'region_alexa': qs[0]['region_alexa'], # 推送组
  983. }
  984. print(22222222222)
  985. # 查询云存储相关信息
  986. ubqs = UID_Bucket.objects.filter(uid=uid). \
  987. values('bucket__content', 'status', 'channel', 'endTime', 'uid')
  988. nowTime = int(time.time())
  989. if ubqs.exists():
  990. if ubqs[0]['endTime'] > nowTime:
  991. data['vod'] = list(ubqs)
  992. print(3333333333333)
  993. return response.json(0, data)
  994. else:
  995. return response.json(0)
  996. def update_uid_set(request):
  997. request.encoding = 'utf-8'
  998. response = ResponseObject()
  999. if request.method == 'POST':
  1000. request_dict = request.POST
  1001. elif request.method == 'GET':
  1002. request_dict = request.GET
  1003. else:
  1004. return response.json(444)
  1005. token = request_dict.get('token', None)
  1006. uid = request_dict.get('uid', None)
  1007. version = request_dict.get('version', '')
  1008. ucode = request_dict.get('ucode', '')
  1009. tko = TokenObject(token)
  1010. response.lang = tko.lang
  1011. if tko.code == 0:
  1012. userID = tko.userID
  1013. nowTime = int(time.time())
  1014. dvqs = Device_Info.objects.filter(userID_id=userID)
  1015. # redisObj = RedisObject(db=8)
  1016. # redisObj.del_data(key='uid_qs_' + userID)
  1017. if dvqs.exists():
  1018. us_qs = UidSetModel.objects.filter(uid=uid)
  1019. if us_qs.exists():
  1020. uid_set_update_dict = {
  1021. 'updTime': nowTime,
  1022. 'version': version,
  1023. 'ucode': ucode,
  1024. }
  1025. us_qs.update(**uid_set_update_dict)
  1026. else:
  1027. uid_set_create_dict = {
  1028. 'uid': uid,
  1029. 'addTime': nowTime,
  1030. 'updTime': nowTime,
  1031. 'version': version,
  1032. 'ucode': ucode,
  1033. }
  1034. UidSetModel.objects.create(**uid_set_create_dict)
  1035. return response.json(0)
  1036. else:
  1037. return response.json(14)
  1038. else:
  1039. return response.json(tko.code)
  1040. # 测试环境
  1041. # test.shadow.dvema.com
  1042. # 生产环境
  1043. # shadow.dvema.com
  1044. # http://test.dvema.com/deviceShadow/update?etk=JVJWbFpFU0VOV1FsbEVTMFpOU2xKWFFURXhNVUU9Xz0=&ucode=1234&version=1324&p2p_region=CN
  1045. # 设备影子更新
  1046. def update_device_shadow(request):
  1047. request.encoding = 'utf-8'
  1048. response = ResponseObject()
  1049. if request.method == 'POST':
  1050. request_dict = request.POST
  1051. elif request.method == 'GET':
  1052. request_dict = request.GET
  1053. else:
  1054. return response.json(444)
  1055. etk = request_dict.get('etk', None)
  1056. eto = ETkObject(etk)
  1057. uid = eto.uid
  1058. if uid:
  1059. # 重置按钮
  1060. is_reset = request_dict.get('is_reset', None)
  1061. # 传1则重置设备信息
  1062. if is_reset == '1':
  1063. UidSetModel.objects.filter(uid=uid).delete()
  1064. # 重置设备,判断设备为已删除
  1065. nowTime = int(time.time())
  1066. uid_bucket = UID_Bucket.objects.filter(uid=uid, endTime__gte=nowTime).values('id', 'has_unused').order_by('addTime')
  1067. if not uid_bucket.exists():
  1068. di_qs = Device_Info.objects.filter(UID=uid)
  1069. di_qs.update(isExist=2)
  1070. # 清除redis缓存
  1071. # data = di_qs.values()
  1072. # redisObj = RedisObject(db=8)
  1073. # for di in data:
  1074. # key = 'uid_qs_' + di['userID_id']
  1075. # redis_value = redisObj.get_data(key=key)
  1076. # if redis_value is not False:
  1077. # redisObj.del_data(key)
  1078. ucode = request_dict.get('ucode', None)
  1079. version = request_dict.get('version', None)
  1080. p2p_region = request_dict.get('p2p_region', None)
  1081. tz = request_dict.get('tz', None)
  1082. video_code = request_dict.get('video_code', None)
  1083. ip = CommonService.get_ip_address(request)
  1084. channel = request_dict.get('channel', None)
  1085. cloud_vod = request_dict.get('cloud_vod', None)
  1086. push_status = request_dict.get('push_status', None)
  1087. pwd = request_dict.get('pwd', None)
  1088. resetTime = request_dict.get('resetTime', None)
  1089. is_alexa = request_dict.get('is_alexa', None)
  1090. us_qs = UidSetModel.objects.filter(uid=uid)
  1091. # 更新
  1092. nowTime = int(time.time())
  1093. print('-------')
  1094. print(resetTime)
  1095. print('-------')
  1096. qs_dict = {
  1097. 'updTime': nowTime,
  1098. 'ip': ip
  1099. }
  1100. if channel:
  1101. qs_dict['channel'] = channel
  1102. if p2p_region:
  1103. qs_dict['p2p_region'] = p2p_region
  1104. if ucode:
  1105. qs_dict['ucode'] = ucode
  1106. if version:
  1107. qs_dict['version'] = version
  1108. if tz:
  1109. qs_dict['tz'] = tz
  1110. if video_code:
  1111. qs_dict['video_code'] = video_code
  1112. if cloud_vod:
  1113. qs_dict['cloud_vod'] = cloud_vod
  1114. if push_status:
  1115. qs_dict['detect_status'] = push_status
  1116. if pwd:
  1117. qs_dict['pwd'] = pwd
  1118. if is_alexa:
  1119. qs_dict['is_alexa'] = is_alexa
  1120. if us_qs.exists():
  1121. us_qs.update(**qs_dict)
  1122. # 如果推送状态开启,返回推送url
  1123. return JsonResponse(status=200, data={'code': 0, 'msg': 'success', 'data': {}})
  1124. # 新增
  1125. else:
  1126. qs_dict['uid'] = uid
  1127. qs_dict['addTime'] = nowTime
  1128. UidSetModel.objects.create(**qs_dict)
  1129. # 如果推送状态开启,返回推送url
  1130. return JsonResponse(status=200, data={'code': 0, 'msg': 'success', 'data': {}})
  1131. else:
  1132. return JsonResponse(status=200, data={'code': 403, 'msg': 'error etk'})