UidSetController.py 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
  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 threading
  15. import time
  16. import traceback
  17. import requests
  18. import simplejson as json
  19. from django.db import transaction
  20. from django.utils.decorators import method_decorator
  21. from django.views.decorators.csrf import csrf_exempt
  22. from django.views.generic.base import View
  23. from Model.models import UidSetModel, Device_Info, UidPushModel, Equipment_Info, UID_Preview, UID_Bucket, \
  24. VodHlsModel, Order_Model, OssCrdModel, UidUserModel, UidChannelSetModel, ExperienceContextModel, \
  25. StsCrdModel, Unused_Uid_Meal, LogModel, CountryModel
  26. from Object.ResponseObject import ResponseObject
  27. from Object.TokenObject import TokenObject
  28. from Service.CommonService import CommonService
  29. from Service.ModelService import ModelService
  30. from Service.VodHlsService import SplitVodHlsObject
  31. '''
  32. # 管理员获取信息
  33. http://192.168.136.39:8000/uidset/adminQuery?token=local&page=1&line=10
  34. 管理员删除信息
  35. http://192.168.136.39:8000/uidset/adminDelete?token=local&id=2
  36. 管理员添加信息
  37. http://192.168.136.39:8000/uidset/adminAdd?token=local&uid=JW3684H8BSHG9TTM111A
  38. 管理员编辑信息
  39. http://192.168.136.39:8000/uidset/adminUpdate?token=local&id=6&content={"uid":"9999"}
  40. '''
  41. # 设备信息添加
  42. class UidSetView(View):
  43. @method_decorator(csrf_exempt)
  44. def dispatch(self, *args, **kwargs):
  45. return super(UidSetView, self).dispatch(*args, **kwargs)
  46. def get(self, request, *args, **kwargs):
  47. request.encoding = 'utf-8'
  48. operation = kwargs.get('operation')
  49. return self.validation(request.GET, request, operation)
  50. def post(self, request, *args, **kwargs):
  51. request.encoding = 'utf-8'
  52. operation = kwargs.get('operation')
  53. return self.validation(request.POST, request, operation)
  54. def validation(self, request_dict, request, operation):
  55. response = ResponseObject()
  56. if operation is None:
  57. return response.json(444, 'error path')
  58. token = request_dict.get('token', None)
  59. # 设备主键uid
  60. tko = TokenObject(token)
  61. response.lang = tko.lang
  62. if tko.code != 0:
  63. return response.json(tko.code)
  64. userID = tko.userID
  65. if operation == 'queryAll':
  66. return self.do_queryAll(request_dict, userID, response)
  67. elif operation == 'adminQueryAll':
  68. return self.do_admin_queryAll(request_dict, userID, response)
  69. elif operation == 'adminDelete':
  70. return self.do_admin_delete(request_dict, userID, response)
  71. elif operation == 'adminQuery':
  72. return self.do_admin_query(request_dict, userID, response)
  73. elif operation == 'adminAdd':
  74. return self.do_admin_add(request_dict, userID, response)
  75. elif operation == 'adminUpdate':
  76. return self.do_admin_update(request_dict, userID, response)
  77. elif operation == 'update':
  78. return self.do_update(request_dict, response)
  79. elif operation == 'updateSet':
  80. return self.do_update_set(request, request_dict, response)
  81. elif operation == 'updateChannel':
  82. return self.do_update_channel_set(request_dict, response)
  83. elif operation == 'setVoicePrompt':
  84. return self.do_set_voice(userID, request_dict, response)
  85. elif operation == 'vod_reset':
  86. return self.vod_reset(request, request_dict, response)
  87. elif operation == 'primary_user_reset':
  88. return self.primary_user_reset(request, request_dict, response)
  89. # elif operation == 'test':
  90. # return self.do_test(response)
  91. else:
  92. return response.json(444, 'error path')
  93. def do_queryAll(self, request_dict, userID, response):
  94. uid_list = Device_Info.objects.filter(userID_id=userID).values_list('UID', flat=True)
  95. uid_set_qs = UidSetModel.objects.filter(uid__in=uid_list).values('uid', 'detect_status', 'detect_interval',
  96. 'version', 'ucode', 'p2p_region', 'tz',
  97. 'video_code', 'channel', 'cloud_vod')
  98. if uid_set_qs.exists():
  99. return response.json(0, list(uid_set_qs))
  100. else:
  101. return response.json(0)
  102. def do_admin_queryAll(self, request_dict, userID, response):
  103. uid = request_dict.get('uid', None)
  104. user_search = UidPushModel.objects.filter(uid_set__uid=uid).values(
  105. 'userID__username', 'userID__userEmail', 'userID__phone', 'userID__is_active',
  106. 'userID__NickName', 'uid_set__video_code', 'uid_set__version', 'uid_set__ucode',
  107. 'uid_set__tz', 'uid_set__p2p_region', 'uid_set__nickname', 'uid_set__detect_status',
  108. 'uid_set__detect_interval', 'uid_set__cloud_vod', 'uid_set__channel', 'updTime',
  109. 'tz', 'token_val', 'push_type', 'm_code',
  110. 'lang', 'app_type', 'uid_set__uid', 'userID__data_joined', 'appBundleId'
  111. )
  112. qs_list = CommonService.qs_to_list(user_search)
  113. return response.json(0, qs_list)
  114. # 管理员删除
  115. def do_admin_delete(self, request_dict, userID, response):
  116. own_perm = ModelService.check_perm(userID, 10)
  117. if own_perm is True:
  118. uid = request_dict.getlist('uid', None)
  119. id_list = request_dict.get('id_list', None)
  120. # 删除回滚
  121. with transaction.atomic(): # 上下文格式,可以在python代码的任何位置使用
  122. val = 1
  123. if 'UidSetModel' in id_list:
  124. del_uid = UidSetModel.objects.filter(uid__in=uid)
  125. if del_uid.exists():
  126. del_uid.delete()
  127. print('删除UidSetModel')
  128. else:
  129. val = 1
  130. print('UidSetModel表没有数据')
  131. if 'Equipment_Info' in id_list:
  132. del_uid = Equipment_Info.objects.filter(devUid__in=uid)
  133. if del_uid.exists():
  134. del_uid.delete()
  135. # print('删除Equipment_Info')
  136. else:
  137. val = val + 1
  138. print('Equipment_Info表没有数据')
  139. if 'UID_Preview' in id_list:
  140. del_uid = UID_Preview.objects.filter(uid__in=uid)
  141. if del_uid.exists():
  142. del_uid.delete()
  143. # print ('删除UID_Preview')
  144. else:
  145. val = val + 1
  146. print('UID_Preview表没有数据')
  147. if 'Reset_Vod' in id_list: # 重置设备云存
  148. UID_Bucket.objects.filter(uid__in=uid).delete()
  149. Unused_Uid_Meal.objects.filter(uid__in=uid).delete()
  150. Order_Model.objects.filter(UID__in=uid).delete()
  151. StsCrdModel.objects.filter(uid__in=uid).delete()
  152. VodHlsModel.objects.filter(uid__in=uid).delete()
  153. # 删除vod_hls分表数据
  154. split_vod_hls_obj = SplitVodHlsObject()
  155. split_vod_hls_obj.del_vod_hls_data(uid__in=uid)
  156. ExperienceContextModel.objects.filter(uid__in=uid).delete()
  157. Device_Info.objects.filter(UID__in=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  158. if 'Device_Info' in id_list:
  159. del_uid = Device_Info.objects.filter(UID__in=uid)
  160. if del_uid.exists():
  161. del_uid.delete()
  162. # print ('删除Device_Info')
  163. else:
  164. val = val + 1
  165. print('Order_Model表没有数据')
  166. if 'OssCrdModel' in id_list:
  167. del_uid = OssCrdModel.objects.filter(uid__in=uid)
  168. if del_uid.exists():
  169. del_uid.delete()
  170. # print ('删除OssCrdModel')
  171. else:
  172. val = val + 1
  173. print('OssCrdModel表没有数据')
  174. if 'UidUserModel' in id_list:
  175. del_uid = UidUserModel.objects.filter(UID__in=uid)
  176. if del_uid.exists():
  177. del_uid.delete()
  178. # print ('删除UidUserModel')
  179. else:
  180. val = val + 1
  181. print('UidUserModel表没有数据')
  182. # 有后台管理 设备配置表UidSetModel ---uid --本身,
  183. # 有后台管理 设备关联用户推送表Equipment_Info --devUid --独立没有儿子的,
  184. # 有后台管理 设备预览图表UID_Preview ---uid---孤立,
  185. # 有后台管理 设备关联套餐表UID_Bucket ---uid---孤立,
  186. # 有后台管理 云存回放信息表VodHlsModel ---uid---孤立,
  187. # 有后台管理 订单信息表Order_Model --UID----独立没有儿子的,
  188. # 有后台管理 用户设备信息表(最多信息量的表)Device_Info ---UID---孤立,
  189. # 设备证书OssCrdModel ---uid---孤立
  190. # 有后台管理 设备ap表 UidUserModel
  191. # 设备绑定UidPushModel---关联表---设备配置表UidSetModel---配置表的详情有显示
  192. # raise DatabaseError #测试用,检测是否能捕捉错误
  193. if val == 9:
  194. return response.json(173)
  195. else:
  196. return response.json(0)
  197. else:
  198. return response.json(404)
  199. # 管理员查询接口
  200. def do_admin_query(self, request_dict, userID, response):
  201. own_perm = ModelService.check_perm(userID, 20)
  202. if own_perm is True:
  203. page = request_dict.get('page', None)
  204. line = request_dict.get('line', None)
  205. page = int(page)
  206. line = int(line)
  207. deviceContent = request_dict.get('content', None)
  208. if deviceContent:
  209. try:
  210. searchCondition = json.loads(deviceContent)
  211. except Exception as e:
  212. return response.json(10, repr(e))
  213. else:
  214. kwargs = CommonService.get_kwargs(data=searchCondition)
  215. omqs = UidSetModel.objects.filter(**kwargs).order_by('-id')
  216. if not omqs.exists():
  217. return response.json(0, [])
  218. count = omqs.count()
  219. order_ql = omqs[(page - 1) * line:page * line]
  220. uidset_json = CommonService.qs_to_dict(order_ql)
  221. uidset_json['count'] = count
  222. return response.json(0, uidset_json)
  223. else:
  224. omqs = UidSetModel.objects.all().order_by('-id')
  225. if not omqs.exists():
  226. return response.json(0, [])
  227. count = omqs.count()
  228. order_ql = omqs[(page - 1) * line:page * line]
  229. uidset_json = CommonService.qs_to_dict(order_ql)
  230. uidset_json['count'] = count
  231. return response.json(0, uidset_json)
  232. else:
  233. return response.json(404)
  234. # 管理员的添加
  235. def do_admin_add(self, request_dict, userID, response):
  236. own_perm = ModelService.check_perm(userID=userID, permID=40)
  237. if own_perm is not True:
  238. return response.json(404)
  239. uid = request_dict.get('uid', None)
  240. timestamp = int(time.time())
  241. param_flag = CommonService.get_param_flag(
  242. data=[uid])
  243. if param_flag is not True:
  244. return response.json(444)
  245. try:
  246. uidset = UidSetModel(
  247. uid=uid,
  248. addTime=timestamp,
  249. updTime=timestamp)
  250. uidset.save()
  251. return response.json(0)
  252. except Exception:
  253. errorInfo = traceback.format_exc()
  254. print(errorInfo)
  255. return response.json(500, {'details': errorInfo})
  256. # 管理员的编辑
  257. def do_admin_update(self, request_dict, userID, response):
  258. own_perm = ModelService.check_perm(userID=userID, permID=50)
  259. if own_perm is not True:
  260. return response.json(404)
  261. deviceContent = request_dict.get('content', None)
  262. id = request_dict.get('id', None)
  263. if not deviceContent or not id:
  264. return response.json(444, 'content,id')
  265. try:
  266. timestamp = int(time.time())
  267. deviceData = json.loads(deviceContent)
  268. uid_set = UidSetModel.objects.filter(id=id)
  269. if uid_set.exists():
  270. uid_set.update(updTime=timestamp, **deviceData)
  271. return response.json(0)
  272. else:
  273. return response.json(173)
  274. except Exception:
  275. errorInfo = traceback.format_exc()
  276. print(errorInfo)
  277. return response.json(500, {'details': errorInfo})
  278. def do_update(self, request_dict, response):
  279. uid = request_dict.get('uid', None)
  280. region_alexa = request_dict.get('region_alexa', None)
  281. is_alexa = request_dict.get('is_alexa', None)
  282. try:
  283. timestamp = int(time.time())
  284. uid_set = UidSetModel.objects.filter(uid=uid)
  285. if uid_set.exists():
  286. if region_alexa is None:
  287. uid_set.update(updTime=timestamp, is_alexa=is_alexa)
  288. else:
  289. if is_alexa is None:
  290. uid_set.update(updTime=timestamp, region_alexa=region_alexa)
  291. else:
  292. uid_set.update(updTime=timestamp, region_alexa=region_alexa, is_alexa=is_alexa)
  293. return response.json(0)
  294. else:
  295. return response.json(173)
  296. except Exception:
  297. errorInfo = traceback.format_exc()
  298. return response.json(500, {'details': errorInfo})
  299. def do_update_set(self, request, request_dict, response):
  300. uid = request_dict.get('uid', None)
  301. deviceContent = request_dict.get('content', None)
  302. token = request_dict.get('token', None)
  303. # print(deviceContent)
  304. if not deviceContent or not uid:
  305. return response.json(444, 'content,uid')
  306. tko = TokenObject(token)
  307. response.lang = tko.lang
  308. if tko.code != 0:
  309. return response.json(tko.code)
  310. userID = tko.userID
  311. if userID is None:
  312. return response.json(309)
  313. try:
  314. # redisObj = RedisObject(db=8)
  315. # redisObj.del_data(key='uid_qs_' + userID)
  316. deviceData = json.loads(deviceContent)
  317. uid_set_qs = UidSetModel.objects.filter(uid=uid)
  318. if not uid_set_qs.exists():
  319. # 由于uid_set表和device_info表设备数量不一致,所以添加以下逻辑把device_info表中的相关信息保存到uid_set表
  320. di_qs = Device_Info.objects.filter(UID=uid, userID=userID)
  321. if di_qs.exists():
  322. di = di_qs[0]
  323. ip = CommonService.get_ip_address(request)
  324. ipInfo = CommonService.getIpIpInfo(ip, 'CN')
  325. country_qs = CountryModel.objects.filter(country_code=ipInfo['country_code']).values('id')
  326. country = country_qs.exists() if country_qs[0]['id'] else 0
  327. nowTime = int(time.time())
  328. uid_set_create_dict = {
  329. 'uid': di.UID,
  330. 'addTime': nowTime,
  331. 'updTime': nowTime,
  332. 'ip': CommonService.get_ip_address(request),
  333. 'channel': di.ChannelIndex,
  334. 'nickname': di.NickName,
  335. 'device_type': di.Type,
  336. 'tb_country': country
  337. }
  338. for k, v in deviceData.items():
  339. uid_set_create_dict[k] = v
  340. UidSetModel.objects.create(**uid_set_create_dict)
  341. else:
  342. return response.json(177)
  343. else:
  344. uid_set_qs.update(**deviceData)
  345. print('update success')
  346. except Exception as e:
  347. return response.json(177, repr(e))
  348. else:
  349. return response.json(0)
  350. def do_update_channel_set(self, request_dict, response):
  351. uid = request_dict.get('uid', None)
  352. channel = request_dict.get('channel', None)
  353. channelContent = request_dict.get('content', None)
  354. token = request_dict.get('token', None)
  355. print(channelContent)
  356. if not channelContent or not uid or not channel:
  357. return response.json(444, 'content,uid, channel')
  358. tko = TokenObject(token)
  359. response.lang = tko.lang
  360. if tko.code != 0:
  361. return response.json(tko.code)
  362. userID = tko.userID
  363. if userID is None:
  364. return response.json(309)
  365. channel = int(channel)
  366. if channel < 1:
  367. return response.json(444, 'channel')
  368. try:
  369. deviceData = json.loads(channelContent)
  370. uid_channel_set_qs = UidChannelSetModel.objects.filter(uid__uid=uid, channel=channel)
  371. uidObject = UidSetModel.objects.filter(uid=uid)
  372. if not uid_channel_set_qs.exists():
  373. ucs = {
  374. 'channel': channel,
  375. 'uid': uidObject[0]
  376. }
  377. keys = deviceData.keys()
  378. for key in keys:
  379. ucs[key] = deviceData[key]
  380. UidChannelSetModel.objects.create(**ucs)
  381. else:
  382. uid_channel_set_qs.update(**deviceData)
  383. if uidObject[0].is_alexa == 1 and 'channel_name' in deviceData.keys():
  384. data_list = [{'userID': userID, 'UID': uid, 'uid_nick': deviceData['channel_name'], 'password': ''}]
  385. # 请求Alexa服务器更新事件网关
  386. CommonService.update_alexa_events(data_list)
  387. except Exception as e:
  388. return response.json(177, repr(e))
  389. else:
  390. return response.json(0)
  391. def do_set_voice(self, userID, request_dict, response):
  392. uid = request_dict.get('uid', None)
  393. channel = request_dict.get('channel', None)
  394. enter_voice = request_dict.get('enter_voice', None)
  395. leave_voice = request_dict.get('leave_voice', None)
  396. voice_status = request_dict.get('voice_status', None)
  397. intelligent_mute = request_dict.get('intelligent_mute', None)
  398. start_x = request_dict.get('start_x', None)
  399. start_y = request_dict.get('start_y', None)
  400. end_x = request_dict.get('end_x', None)
  401. end_y = request_dict.get('end_y', None)
  402. start_time = request_dict.get('start_time', None)
  403. end_time = request_dict.get('end_time', None)
  404. repeat_day = request_dict.get('repeat_day', None)
  405. direction = request_dict.get('direction', None)
  406. algorithm_type = int(request_dict.get('algorithmType', 99))
  407. if uid and channel:
  408. channel = int(channel)
  409. if channel < 1:
  410. return response.json(444, 'channel')
  411. try:
  412. ucs = {}
  413. if enter_voice:
  414. ucs['voice_prompt_enter'] = enter_voice
  415. if leave_voice:
  416. ucs['voice_prompt_leave'] = leave_voice
  417. if voice_status:
  418. ucs['voice_prompt_status'] = voice_status
  419. if intelligent_mute:
  420. ucs['voice_prompt_intelligent_mute'] = intelligent_mute
  421. if start_x:
  422. ucs['voice_start_x'] = start_x
  423. if start_y:
  424. ucs['voice_start_y'] = start_y
  425. if end_x:
  426. ucs['voice_end_x'] = end_x
  427. if end_y:
  428. ucs['voice_end_y'] = end_y
  429. if start_time:
  430. ucs['voice_start_time'] = start_time
  431. if end_time:
  432. ucs['voice_end_time'] = end_time
  433. if repeat_day:
  434. ucs['voice_repeat_day'] = repeat_day
  435. if direction:
  436. ucs['voice_direction'] = direction
  437. ucs['algorithm_type'] = algorithm_type
  438. uid_channel_set_qs = UidChannelSetModel.objects.filter(uid__uid=uid, channel=channel)
  439. uid_channel_set_qs = uid_channel_set_qs.filter(algorithm_type=algorithm_type)
  440. if not uid_channel_set_qs.exists():
  441. uidObject = UidSetModel.objects.filter(uid=uid)
  442. ucs['channel'] = channel
  443. ucs['uid'] = uidObject[0]
  444. UidChannelSetModel.objects.create(**ucs)
  445. else:
  446. uid_channel_set_qs.update(**ucs)
  447. except Exception as e:
  448. return response.json(177, repr(e))
  449. else:
  450. return response.json(0)
  451. # 重置设备云存
  452. def vod_reset(self, request, request_dict, response):
  453. uid = request_dict.get('uid', None)
  454. if uid:
  455. try:
  456. # 记录操作日志
  457. ip = CommonService.get_ip_address(request)
  458. content = json.loads(json.dumps(request_dict))
  459. log = {
  460. 'ip': ip,
  461. 'user_id': 1,
  462. 'status': 200,
  463. 'time': int(time.time()),
  464. 'url': 'uidset/vod_reset',
  465. 'content': json.dumps(content),
  466. 'operation': '{}重置设备云存'.format(uid),
  467. }
  468. with transaction.atomic():
  469. LogModel.objects.create(**log)
  470. # 删除和更新设备云存相关数据
  471. UID_Bucket.objects.filter(uid=uid).delete()
  472. Unused_Uid_Meal.objects.filter(uid=uid).delete()
  473. Order_Model.objects.filter(UID=uid).delete()
  474. StsCrdModel.objects.filter(uid=uid).delete()
  475. VodHlsModel.objects.filter(uid=uid).delete()
  476. # 删除vod_hls分表数据
  477. split_vod_hls_obj = SplitVodHlsObject()
  478. split_vod_hls_obj.del_vod_hls_data(uid=uid)
  479. ExperienceContextModel.objects.filter(uid=uid).delete()
  480. # UIDMainUser.objects.filter(UID=uid).delete()
  481. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  482. except Exception as e:
  483. print(e)
  484. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  485. else:
  486. return response.json(0)
  487. # 重置设备主用户
  488. def primary_user_reset(self, request, request_dict, response):
  489. uid = request_dict.get('uid', None)
  490. if not uid:
  491. return response.json(404)
  492. try:
  493. # 记录操作日志
  494. ip = CommonService.get_ip_address(request)
  495. content = json.loads(json.dumps(request_dict))
  496. log = {
  497. 'ip': ip,
  498. 'user_id': 1,
  499. 'status': 200,
  500. 'time': int(time.time()),
  501. 'url': 'uidset/primary_user_reset',
  502. 'content': json.dumps(content),
  503. 'operation': '{}重置设备主用户'.format(uid),
  504. }
  505. LogModel.objects.create(**log)
  506. Device_Info.objects.filter(UID=uid).update(vodPrimaryUserID='', vodPrimaryMaster='')
  507. return response.json(0)
  508. except Exception as e:
  509. return response.json(500, 'error_line:{}, error_msg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  510. # def do_test(self, response):
  511. # di_qs = Device_Info.objects.values('Type').annotate(c=Count('UID', distinct=True)).order_by()
  512. # for di in di_qs:
  513. # print(di)
  514. #
  515. # # 设备总数量
  516. # count = Device_Info.objects.values('UID').distinct().count()
  517. # print('设备总数量:' + str(count))
  518. #
  519. # # 设备型号统计
  520. # print('设备型号统计:')
  521. # us_qs = UidSetModel.objects.values('deviceModel').annotate(c=Count('id')).order_by()
  522. # for us in us_qs:
  523. # print(us)
  524. #
  525. # # 手机品牌类型统计
  526. # print('手机品牌类型统计:')
  527. # ub_qs = User_Brand.objects.values('deviceSupplier').annotate(c=Count('id')).order_by()
  528. # for ub in ub_qs:
  529. # print(ub)
  530. #
  531. # # 手机型号统计
  532. # print('手机型号统计:')
  533. # ub_qs = User_Brand.objects.values('deviceSupplier', 'deviceModel').annotate(c=Count('id')).order_by()
  534. # for ub in ub_qs:
  535. # print(ub)
  536. #
  537. # # 区域统计
  538. # print('区域统计:')
  539. # di_qs = Device_Info.objects.values('area').annotate(c=Count('UID', distinct=True)).order_by()
  540. # for di in di_qs:
  541. # print(di)
  542. #
  543. # # 区域设备类型统计
  544. # print('区域设备类型统计:')
  545. # di_qs = Device_Info.objects.values('area', 'Type').annotate(c=Count('UID', distinct=True)).order_by()
  546. # for di in di_qs:
  547. # print(di)
  548. # return response.json(0)