UidSetController.py 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD019
  6. @NAME: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2019/5/27 15:50
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: AliPayObject.py
  12. @Contact: pzb3076@163.com
  13. """
  14. import time
  15. import traceback
  16. from django.db.models import Count
  17. from Object.RedisObject import RedisObject
  18. import simplejson as json
  19. from django.utils.decorators import method_decorator
  20. from django.views.decorators.csrf import csrf_exempt
  21. from django.views.generic.base import View
  22. from Model.models import UidSetModel, Device_User, Device_Info, UidPushModel, Equipment_Info, UID_Preview, UID_Bucket, \
  23. VodHlsModel, Order_Model, OssCrdModel, UidUserModel, UidChannelSetModel, User_Brand
  24. from Object.ResponseObject import ResponseObject
  25. from Object.TokenObject import TokenObject
  26. from Service.CommonService import CommonService
  27. from Service.ModelService import ModelService
  28. from django.db import transaction
  29. '''
  30. # 管理员获取信息
  31. http://192.168.136.39:8000/uidset/adminQuery?token=local&page=1&line=10
  32. 管理员删除信息
  33. http://192.168.136.39:8000/uidset/adminDelete?token=local&id=2
  34. 管理员添加信息
  35. http://192.168.136.39:8000/uidset/adminAdd?token=local&uid=JW3684H8BSHG9TTM111A
  36. 管理员编辑信息
  37. http://192.168.136.39:8000/uidset/adminUpdate?token=local&id=6&content={"uid":"9999"}
  38. '''
  39. # 设备信息添加
  40. class UidSetView(View):
  41. @method_decorator(csrf_exempt)
  42. def dispatch(self, *args, **kwargs):
  43. return super(UidSetView, self).dispatch(*args, **kwargs)
  44. def get(self, request, *args, **kwargs):
  45. request.encoding = 'utf-8'
  46. operation = kwargs.get('operation')
  47. return self.validation(request.GET, request, operation)
  48. def post(self, request, *args, **kwargs):
  49. request.encoding = 'utf-8'
  50. operation = kwargs.get('operation')
  51. return self.validation(request.POST, request, operation)
  52. def validation(self, request_dict, request, operation):
  53. response = ResponseObject()
  54. if operation is None:
  55. return response.json(444, 'error path')
  56. token = request_dict.get('token', None)
  57. # 设备主键uid
  58. tko = TokenObject(token)
  59. response.lang = tko.lang
  60. if tko.code != 0:
  61. return response.json(tko.code)
  62. userID = tko.userID
  63. if operation == 'queryAll':
  64. return self.do_queryAll(request_dict, userID, response)
  65. elif operation == 'adminQueryAll':
  66. return self.do_admin_queryAll(request_dict, userID, response)
  67. elif operation == 'adminDelete':
  68. return self.do_admin_delete(request_dict, userID, response)
  69. elif operation == 'adminQuery':
  70. return self.do_admin_query(request_dict, userID, response)
  71. elif operation == 'adminAdd':
  72. return self.do_admin_add(request_dict, userID, response)
  73. elif operation == 'adminUpdate':
  74. return self.do_admin_update(request_dict, userID, response)
  75. elif operation == 'update':
  76. return self.do_update(request_dict, response)
  77. elif operation == 'updateSet':
  78. return self.do_update_set(request, request_dict, response)
  79. elif operation == 'updateChannel':
  80. return self.do_update_channel_set(request_dict, response)
  81. # elif operation == 'test':
  82. # return self.do_test(response)
  83. else:
  84. return response.json(444, 'error path')
  85. def do_queryAll(self, request_dict, userID, response):
  86. uid_list = Device_Info.objects.filter(userID_id=userID).values_list('UID', flat=True)
  87. uid_set_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'detect_status', 'detect_interval',
  88. 'version', 'ucode', 'p2p_region', 'tz',
  89. 'video_code', 'channel', 'cloud_vod')
  90. if uid_set_qs.exists():
  91. return response.json(0, list(uid_set_qs))
  92. else:
  93. return response.json(0)
  94. def do_admin_queryAll(self, request_dict, userID, response):
  95. uid = request_dict.get('uid', None)
  96. user_search = UidPushModel.objects.filter(uid_set__uid=uid).values(
  97. 'userID__username', 'userID__userEmail', 'userID__phone', 'userID__is_active',
  98. 'userID__NickName', 'uid_set__video_code', 'uid_set__version', 'uid_set__ucode',
  99. 'uid_set__tz', 'uid_set__p2p_region', 'uid_set__nickname', 'uid_set__detect_status',
  100. 'uid_set__detect_interval', 'uid_set__cloud_vod', 'uid_set__channel', 'updTime',
  101. 'tz', 'token_val', 'push_type', 'm_code',
  102. 'lang', 'app_type', 'uid_set__uid', 'userID__data_joined', 'appBundleId'
  103. )
  104. qs_list = CommonService.qs_to_list(user_search)
  105. return response.json(0, qs_list)
  106. # 管理员删除
  107. def do_admin_delete(self, request_dict, userID, response):
  108. own_perm = ModelService.check_perm(userID, 10)
  109. if own_perm is True:
  110. uid = request_dict.getlist('uid', None)
  111. id_list = request_dict.get('id_list', None)
  112. redisObj = RedisObject(db=8)
  113. redisObj.del_data(key='uid_qs_' + userID)
  114. # 删除回滚
  115. with transaction.atomic(): # 上下文格式,可以在python代码的任何位置使用
  116. val = 1
  117. if 'UidSetModel' in id_list:
  118. del_uid = UidSetModel.objects.filter(uid__in=uid)
  119. if del_uid.exists():
  120. del_uid.delete()
  121. print ('删除UidSetModel')
  122. else:
  123. val = 1
  124. print('UidSetModel表没有数据')
  125. if 'Equipment_Info' in id_list:
  126. del_uid = Equipment_Info.objects.filter(devUid__in=uid)
  127. if del_uid.exists():
  128. del_uid.delete()
  129. # print('删除Equipment_Info')
  130. else:
  131. val = val+1
  132. print('Equipment_Info表没有数据')
  133. if 'UID_Preview' in id_list:
  134. del_uid = UID_Preview.objects.filter(uid__in=uid)
  135. if del_uid.exists():
  136. del_uid.delete()
  137. # print ('删除UID_Preview')
  138. else:
  139. val = val + 1
  140. print('UID_Preview表没有数据')
  141. if 'UID_Bucket' in id_list:
  142. del_uid = UID_Bucket.objects.filter(uid__in=uid)
  143. if del_uid.exists():
  144. del_uid.delete()
  145. # print ('删除UID_Bucket')
  146. else:
  147. val = val + 1
  148. print('UID_Bucket表没有数据')
  149. if 'VodHlsModel' in id_list:
  150. del_uid = VodHlsModel.objects.filter(uid__in=uid)
  151. if del_uid.exists():
  152. # del_uid.delete()
  153. print ('删除VodHlsModel')
  154. else:
  155. val = val + 1
  156. print('VodHlsModel表没有数据')
  157. if 'Order_Model' in id_list:
  158. del_uid = Order_Model.objects.filter(UID__in=uid)
  159. if del_uid.exists():
  160. del_uid.delete()
  161. # print ('删除Order_Model')
  162. else:
  163. val = val + 1
  164. print('Order_Model表没有数据')
  165. if 'Device_Info' in id_list:
  166. del_uid = Device_Info.objects.filter(UID__in=uid)
  167. if del_uid.exists():
  168. del_uid.delete()
  169. # print ('删除Device_Info')
  170. else:
  171. val = val + 1
  172. print('Order_Model表没有数据')
  173. if 'OssCrdModel' in id_list:
  174. del_uid = OssCrdModel.objects.filter(uid__in=uid)
  175. if del_uid.exists():
  176. del_uid.delete()
  177. # print ('删除OssCrdModel')
  178. else:
  179. val = val + 1
  180. print('OssCrdModel表没有数据')
  181. if 'UidUserModel' in id_list:
  182. del_uid = UidUserModel.objects.filter(UID__in=uid)
  183. if del_uid.exists():
  184. del_uid.delete()
  185. # print ('删除UidUserModel')
  186. else:
  187. val = val + 1
  188. print('UidUserModel表没有数据')
  189. # 有后台管理 设备配置表UidSetModel ---uid --本身,
  190. # 有后台管理 设备关联用户推送表Equipment_Info --devUid --独立没有儿子的,
  191. # 有后台管理 设备预览图表UID_Preview ---uid---孤立,
  192. # 有后台管理 设备关联套餐表UID_Bucket ---uid---孤立,
  193. # 有后台管理 云存回放信息表VodHlsModel ---uid---孤立,
  194. # 有后台管理 订单信息表Order_Model --UID----独立没有儿子的,
  195. # 有后台管理 用户设备信息表(最多信息量的表)Device_Info ---UID---孤立,
  196. # 设备证书OssCrdModel ---uid---孤立
  197. # 有后台管理 设备ap表 UidUserModel
  198. # 设备绑定UidPushModel---关联表---设备配置表UidSetModel---配置表的详情有显示
  199. # raise DatabaseError #测试用,检测是否能捕捉错误
  200. if val == 9:
  201. return response.json(173)
  202. else:
  203. return response.json(0)
  204. else:
  205. return response.json(404)
  206. # 管理员查询接口
  207. def do_admin_query(self, request_dict, userID, response):
  208. own_perm = ModelService.check_perm(userID, 20)
  209. if own_perm is True:
  210. page = request_dict.get('page', None)
  211. line = request_dict.get('line', None)
  212. page = int(page)
  213. line = int(line)
  214. deviceContent = request_dict.get('content', None)
  215. if deviceContent:
  216. try:
  217. searchCondition = json.loads(deviceContent)
  218. except Exception as e:
  219. return response.json(10, repr(e))
  220. else:
  221. kwargs = CommonService.get_kwargs(data=searchCondition)
  222. omqs = UidSetModel.objects.filter(**kwargs).order_by('-id')
  223. if not omqs.exists():
  224. return response.json(0, [])
  225. count = omqs.count()
  226. order_ql = omqs[(page - 1) * line:page * line]
  227. uidset_json = CommonService.qs_to_dict(order_ql)
  228. uidset_json['count'] = count
  229. return response.json(0, uidset_json)
  230. else:
  231. omqs = UidSetModel.objects.all().order_by('-id')
  232. if not omqs.exists():
  233. return response.json(0, [])
  234. count = omqs.count()
  235. order_ql = omqs[(page - 1) * line:page * line]
  236. uidset_json = CommonService.qs_to_dict(order_ql)
  237. uidset_json['count'] = count
  238. return response.json(0, uidset_json)
  239. else:
  240. return response.json(404)
  241. # 管理员的添加
  242. def do_admin_add(self, request_dict, userID, response):
  243. own_perm = ModelService.check_perm(userID=userID, permID=40)
  244. if own_perm is not True:
  245. return response.json(404)
  246. uid = request_dict.get('uid', None)
  247. timestamp = int(time.time())
  248. param_flag = CommonService.get_param_flag(
  249. data=[uid])
  250. if param_flag is not True:
  251. return response.json(444)
  252. try:
  253. uidset = UidSetModel(
  254. uid=uid,
  255. addTime=timestamp,
  256. updTime=timestamp)
  257. uidset.save()
  258. return response.json(0)
  259. except Exception:
  260. errorInfo = traceback.format_exc()
  261. print(errorInfo)
  262. return response.json(500, {'details': errorInfo})
  263. # 管理员的编辑
  264. def do_admin_update(self, request_dict, userID, response):
  265. own_perm = ModelService.check_perm(userID=userID, permID=50)
  266. if own_perm is not True:
  267. return response.json(404)
  268. deviceContent = request_dict.get('content', None)
  269. id = request_dict.get('id', None)
  270. if not deviceContent or not id:
  271. return response.json(444, 'content,id')
  272. try:
  273. timestamp = int(time.time())
  274. deviceData = json.loads(deviceContent)
  275. uid_set = UidSetModel.objects.filter(id=id)
  276. if uid_set.exists():
  277. uid_set.update(updTime=timestamp, **deviceData)
  278. return response.json(0)
  279. else:
  280. return response.json(173)
  281. except Exception:
  282. errorInfo = traceback.format_exc()
  283. print(errorInfo)
  284. return response.json(500, {'details': errorInfo})
  285. def do_update(self, request_dict, response):
  286. uid = request_dict.get('uid', None)
  287. region_alexa = request_dict.get('region_alexa', None)
  288. is_alexa = request_dict.get('is_alexa', None)
  289. try:
  290. timestamp = int(time.time())
  291. uid_set = UidSetModel.objects.filter(uid=uid)
  292. if uid_set.exists():
  293. if region_alexa is None:
  294. uid_set.update(updTime=timestamp, is_alexa=is_alexa)
  295. else:
  296. if is_alexa is None:
  297. uid_set.update(updTime=timestamp, region_alexa=region_alexa)
  298. else:
  299. uid_set.update(updTime=timestamp, region_alexa=region_alexa, is_alexa=is_alexa)
  300. return response.json(0)
  301. else:
  302. return response.json(173)
  303. except Exception:
  304. errorInfo = traceback.format_exc()
  305. return response.json(500, {'details': errorInfo})
  306. def do_update_set(self, request, request_dict, response):
  307. uid = request_dict.get('uid', None)
  308. deviceContent = request_dict.get('content', None)
  309. token = request_dict.get('token', None)
  310. # print(deviceContent)
  311. if not deviceContent or not uid:
  312. return response.json(444, 'content,uid')
  313. tko = TokenObject(token)
  314. response.lang = tko.lang
  315. if tko.code != 0:
  316. return response.json(tko.code)
  317. userID = tko.userID
  318. if userID is None:
  319. return response.json(309)
  320. try:
  321. redisObj = RedisObject(db=8)
  322. redisObj.del_data(key='uid_qs_' + userID)
  323. deviceData = json.loads(deviceContent)
  324. uid_set_qs = UidSetModel.objects.filter(uid=uid)
  325. if not uid_set_qs.exists():
  326. # 由于uid_set表和device_info表设备数量不一致,所以添加以下逻辑把device_info表中的相关信息保存到uid_set表
  327. di_qs = Device_Info.objects.filter(UID=uid, userID=userID)
  328. if di_qs.exists():
  329. di = di_qs[0]
  330. nowTime = int(time.time())
  331. uid_set_create_dict = {
  332. 'uid': di.UID,
  333. 'addTime': nowTime,
  334. 'updTime': nowTime,
  335. 'ip': CommonService.get_ip_address(request),
  336. 'channel': di.ChannelIndex,
  337. 'nickname': di.NickName,
  338. }
  339. for k, v in deviceData.items():
  340. uid_set_create_dict[k] = v
  341. UidSetModel.objects.create(**uid_set_create_dict)
  342. else:
  343. return response.json(177)
  344. else:
  345. uid_set_qs.update(**deviceData)
  346. print('update success')
  347. except Exception as e:
  348. return response.json(177, repr(e))
  349. else:
  350. return response.json(0)
  351. def do_update_channel_set(self, request_dict, response):
  352. uid = request_dict.get('uid', None)
  353. channel = request_dict.get('channel', None)
  354. channelContent = request_dict.get('content', None)
  355. token = request_dict.get('token', None)
  356. print(channelContent)
  357. if not channelContent or not uid or not channel:
  358. return response.json(444, 'content,uid, chan')
  359. tko = TokenObject(token)
  360. response.lang = tko.lang
  361. if tko.code != 0:
  362. return response.json(tko.code)
  363. userID = tko.userID
  364. if userID is None:
  365. return response.json(309)
  366. channel = int(channel)
  367. if channel < 1:
  368. return response.json(444, 'channel')
  369. try:
  370. redisObj = RedisObject(db=8)
  371. redisObj.del_data(key='uid_qs_' + userID)
  372. deviceData = json.loads(channelContent)
  373. uid_channel_set_qs = UidChannelSetModel.objects.filter(uid__uid=uid, channel=channel)
  374. if not uid_channel_set_qs.exists():
  375. uidObject = UidSetModel.objects.filter(uid=uid)
  376. ucs = {
  377. 'channel': channel,
  378. 'uid': uidObject[0]
  379. }
  380. keys = deviceData.keys()
  381. for key in keys:
  382. ucs[key] = deviceData[key]
  383. UidChannelSetModel.objects.create(**ucs)
  384. else:
  385. uid_channel_set_qs.update(**deviceData)
  386. except Exception as e:
  387. return response.json(177, repr(e))
  388. else:
  389. return response.json(0)
  390. # def do_test(self, response):
  391. # di_qs = Device_Info.objects.values('Type').annotate(c=Count('UID', distinct=True)).order_by()
  392. # for di in di_qs:
  393. # print(di)
  394. #
  395. # # 设备总数量
  396. # count = Device_Info.objects.values('UID').distinct().count()
  397. # print('设备总数量:' + str(count))
  398. #
  399. # # 设备型号统计
  400. # print('设备型号统计:')
  401. # us_qs = UidSetModel.objects.values('deviceModel').annotate(c=Count('id')).order_by()
  402. # for us in us_qs:
  403. # print(us)
  404. #
  405. # # 手机品牌类型统计
  406. # print('手机品牌类型统计:')
  407. # ub_qs = User_Brand.objects.values('deviceSupplier').annotate(c=Count('id')).order_by()
  408. # for ub in ub_qs:
  409. # print(ub)
  410. #
  411. # # 手机型号统计
  412. # print('手机型号统计:')
  413. # ub_qs = User_Brand.objects.values('deviceSupplier', 'deviceModel').annotate(c=Count('id')).order_by()
  414. # for ub in ub_qs:
  415. # print(ub)
  416. #
  417. # # 区域统计
  418. # print('区域统计:')
  419. # di_qs = Device_Info.objects.values('area').annotate(c=Count('UID', distinct=True)).order_by()
  420. # for di in di_qs:
  421. # print(di)
  422. #
  423. # # 区域设备类型统计
  424. # print('区域设备类型统计:')
  425. # di_qs = Device_Info.objects.values('area', 'Type').annotate(c=Count('UID', distinct=True)).order_by()
  426. # for di in di_qs:
  427. # print(di)
  428. # return response.json(0)