AdminManage.py 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627
  1. # -*- coding: utf-8 -*-
  2. import time
  3. from django.db.models import Count,Q
  4. from django.views.decorators.csrf import csrf_exempt
  5. from django.views.generic import TemplateView
  6. from django.utils.decorators import method_decorator
  7. from django.contrib.auth.hashers import make_password # 对密码加密模块
  8. from Model.models import Device_Info, Role, UserExModel, User_Brand, UidSetModel, AppFrequencyYearStatisticsModel, \
  9. AppFrequencyStatisticsModel, EquipmentInfoExStatisticsModel, EquipmentInfoExModel
  10. from Service.ModelService import ModelService
  11. from django.utils import timezone
  12. from Model.models import Access_Log, Device_User
  13. from django.views.decorators.http import require_http_methods
  14. from Object.ResponseObject import ResponseObject
  15. from Object.TokenObject import TokenObject
  16. from Ansjer.config import OFF_LINE_TIME_DELTA, DEVICE_TYPE
  17. import datetime, simplejson as json
  18. from Service.CommonService import CommonService
  19. from Object.RedisObject import RedisObject
  20. '''
  21. http://192.168.136.40:8077/adminManage/manage?operation=getAllDeviceArea&token=debug
  22. http://192.168.136.40:8077/adminManage/manage?operation=getAllUserName&token=debug
  23. http://192.168.136.40:8077/adminManage/manage?operation=getAllUID&token=debug
  24. http://127.0.0.1:8000/adminManage/manage?operation=getAllOnLine&token=stest
  25. http://127.0.0.1:8000/adminManage/manage?operation=getOnLine&token=stest
  26. '''
  27. class AdminManage(TemplateView):
  28. @method_decorator(csrf_exempt)
  29. def dispatch(self, *args, **kwargs):
  30. return super(AdminManage, self).dispatch(*args, **kwargs)
  31. def get(self, request, *args, **kwargs):
  32. request.encoding = 'utf-8'
  33. return self.validation(request_dict=request.GET)
  34. def post(self, request, *args, **kwargs):
  35. request.encoding = 'utf-8'
  36. return self.validation(request_dict=request.POST)
  37. def validation(self, request_dict, *args, **kwargs):
  38. response = ResponseObject()
  39. # token = request_dict.get('token', None)
  40. # tko = TokenObject(token)
  41. # response.lang = tko.lang
  42. # if tko.code != 0:
  43. # return response.json(tko.code)
  44. # userID = tko.userID
  45. userID = 1
  46. operation = request_dict.get('operation', None)
  47. if userID is None or operation is None:
  48. return response.json(444, 'operation')
  49. if operation == 'resetUserPwd':
  50. return self.resetUserPwd(request_dict, userID, response)
  51. if operation == 'getAllOnLine':
  52. return self.getAllOnLine(userID, response)
  53. if operation == 'getOnLine':
  54. return self.getRedisOnline(userID, response)
  55. # return self.getOnLine(userID, response)
  56. if operation == 'getAllUserName':
  57. return self.getAllUserName(userID, response)
  58. if operation == 'getStatisAccess':
  59. return self.getStatisAccess(userID, request_dict, response)
  60. if operation == 'getAllUID':
  61. return self.getAllUID(userID, response)
  62. if operation == 'getAllDeviceArea':
  63. return self.getAllDeviceArea(userID, response)
  64. if operation == 'getUserBrand':
  65. return self.getUserBrand(userID, response)
  66. if operation == 'getAreaDeviceType':
  67. return self.getAreaDeviceType(userID, response)
  68. if operation == 'getDeviceType':
  69. return self.getDeviceType(userID, response)
  70. if operation == 'getAppFrequency':
  71. return self.getAppFrequency(userID, request_dict, response)
  72. if operation == 'getHistoryAppFrequency':
  73. return self.getAllAppFrequency(userID, response)
  74. if operation == 'getPushStatistics':
  75. return self.query_push_by_level(userID, request_dict, response)
  76. def resetUserPwd(self, request_dict, userID, response):
  77. own_permission = ModelService.check_perm(userID=userID, permID=50)
  78. if not own_permission:
  79. return response.json(404)
  80. duserID = request_dict.get('duserID', None)
  81. userPwd = request_dict.get('userPwd', None)
  82. if not duserID:
  83. return response.json(444, 'duserID')
  84. UserValid = Device_User.objects.filter(userID=duserID)
  85. if UserValid:
  86. if userPwd is None:
  87. userPwd = '123456'
  88. is_update = UserValid.update(password=make_password(userPwd))
  89. if is_update:
  90. return response.json(0)
  91. else:
  92. return response.json(177)
  93. else:
  94. return response.json(104)
  95. def getAllUserName(self, userID, response):
  96. # 权限固定为30
  97. own_permission = ModelService.check_perm(userID=userID, permID=30)
  98. if own_permission is not True:
  99. return response.json(404)
  100. username_list = Device_User.objects.all().values_list('username', flat=True)
  101. if username_list:
  102. return response.json(0, {'username_list': list(username_list)})
  103. else:
  104. return response.json(0)
  105. # 获取全部用户的在线个数
  106. def getAllOnLine(self, userID, response):
  107. # 权限固定为30
  108. own_permission = ModelService.check_perm(userID=userID, permID=30)
  109. if own_permission is not True:
  110. return response.json(404)
  111. allonline = Device_User.objects.all().values('online')
  112. # 两个变量,分别是在线,离线
  113. onlinenum = 0
  114. noonlinenum = 0
  115. for q in allonline:
  116. if q['online'] == True:
  117. onlinenum += 1
  118. else:
  119. noonlinenum += 1
  120. print("在线人数:")
  121. print(onlinenum)
  122. return response.json(0, {"onlinenum": onlinenum, "no_onlinenum": noonlinenum})
  123. # 获取全部用户的在线人数
  124. def getOnLine(self, userID, response):
  125. # 权限固定为30
  126. own_permission = ModelService.check_perm(userID=userID, permID=30)
  127. if own_permission is True:
  128. online_list = Device_User.objects.all().values('online', 'last_login')
  129. # 两个变量,分别是在线,离线
  130. onlinenum = 0
  131. noonlinenum = 0
  132. for q in online_list:
  133. # print(q['last_login'] )
  134. # 最后访问时间加5分种
  135. dl_time = q['last_login'] + datetime.timedelta(minutes=OFF_LINE_TIME_DELTA)
  136. # print(dl_time)
  137. # 当前时间
  138. now_time = timezone.localtime(timezone.now())
  139. # print(now_time)
  140. # 如果当前时间大于最后访问的时间
  141. if now_time < dl_time:
  142. onlinenum += 1
  143. else:
  144. noonlinenum += 1
  145. print("在线人")
  146. print(onlinenum)
  147. return response.json(0, {"onlinenum": onlinenum, "no_onlinenum": noonlinenum})
  148. else:
  149. return response.json(404)
  150. # 获取全部用户的在线人数
  151. def getRedisOnline(self, userID, response):
  152. # 权限固定为30
  153. own_perm = ModelService.check_perm(userID, 30)
  154. if own_perm:
  155. count = int(Device_User.objects.count())
  156. redisObj = RedisObject(db=3)
  157. onlines = int(redisObj.get_size())
  158. print(onlines)
  159. return response.json(0, {"onlinenum": onlines, "no_onlinenum": count - onlines})
  160. else:
  161. return response.json(404)
  162. # 获取所有设备地区
  163. def getAllDeviceArea(self, userID, response):
  164. own_permission = ModelService.check_perm(userID=userID, permID=30)
  165. if own_permission is True:
  166. qs = Device_Info.objects.all().values('area', 'UID')
  167. uid_area_dict = {}
  168. for q in qs:
  169. if q['UID'] and q['area']:
  170. uid_area_dict[q['UID']] = q['area']
  171. if len(uid_area_dict):
  172. area_dict = {}
  173. for k, v in uid_area_dict.items():
  174. if v in area_dict:
  175. area_dict[v] += 1
  176. else:
  177. area_dict[v] = 1
  178. return response.json(0, {'area': area_dict})
  179. else:
  180. return response.json(0)
  181. else:
  182. return response.json(404)
  183. '''
  184. 统计一天访问量
  185. http://192.168.136.45:8077/adminManage/manage?token=test&operation=getStatisAccess&timestamp=1528773308
  186. '''
  187. def getStatisAccess(self, userID, request_dict, response):
  188. own_permission = ModelService.check_perm(userID=userID, permID=30)
  189. if own_permission is not True:
  190. return response.json(404)
  191. time_stamp = int(request_dict.get('timestamp', None))
  192. times = datetime.datetime.fromtimestamp(time_stamp)
  193. time_dict = CommonService.getTimeDict(times)
  194. res = {}
  195. for k, v in time_dict.items():
  196. start_date = time_dict[k]
  197. end_date = time_dict[k] + datetime.timedelta(hours=1)
  198. count = Access_Log.objects.filter(time__range=(start_date, end_date)).count()
  199. if count:
  200. res[k] = count
  201. else:
  202. res[k] = 0
  203. return response.json(0, {'count': res})
  204. def getAllUID(self, userID, response):
  205. own_permission = ModelService.check_perm(userID=userID, permID=30)
  206. if own_permission is not True:
  207. return response.json(404)
  208. uid_list = Device_Info.objects.all().values_list('UID', flat=True)
  209. res = {}
  210. if uid_list:
  211. res = {'count': uid_list.count(), 'uid_list': list(uid_list)}
  212. return response.json(0, res)
  213. def getUserBrand(self, userID, response):
  214. own_permission = ModelService.check_perm(userID=userID, permID=30)
  215. if own_permission is not True:
  216. return response.json(404)
  217. # 手机型号统计
  218. print('手机型号统计:')
  219. ub_qs = User_Brand.objects.values('deviceSupplier', 'deviceModel').annotate(value=Count('id')).order_by()
  220. res = {
  221. 'value': 0,
  222. 'data': []
  223. }
  224. data = res['data']
  225. tmpDict = {}
  226. for ub in ub_qs:
  227. deviceSupplier = ub['deviceSupplier']
  228. if not tmpDict.__contains__(deviceSupplier):
  229. tmpDict[deviceSupplier] = {
  230. 'name': deviceSupplier,
  231. 'value': 0,
  232. 'children': []
  233. }
  234. item = tmpDict[deviceSupplier]
  235. item['value'] = item['value'] + ub['value']
  236. res['value'] = res['value'] + item['value']
  237. model = {
  238. 'name': ub['deviceModel'],
  239. 'value': ub['value']
  240. }
  241. item['children'].append(model)
  242. for k, v in tmpDict.items():
  243. data.append(v)
  244. print(res)
  245. return response.json(0, res)
  246. def getAreaDeviceType(self, userID, response):
  247. own_permission = ModelService.check_perm(userID=userID, permID=30)
  248. if own_permission is not True:
  249. return response.json(404)
  250. print('区域设备类型统计:')
  251. di_qs = Device_Info.objects.values('area', 'Type').annotate(value=Count('UID', distinct=True)).order_by()
  252. res = {
  253. 'quantity': 0,
  254. 'data': []
  255. }
  256. data = res['data']
  257. tmpDict = {}
  258. tmpDict['null'] = {
  259. 'area': '未知',
  260. 'quantity': 0,
  261. 'models': []
  262. }
  263. for di in di_qs:
  264. area = di['area']
  265. if area is None or area == '':
  266. area = 'null'
  267. if not tmpDict.__contains__(area):
  268. tmpDict[area] = {
  269. 'area': area,
  270. 'quantity': 0,
  271. 'models': []
  272. }
  273. item = tmpDict[area]
  274. item['quantity'] = item['quantity'] + di['value']
  275. res['quantity'] = res['quantity'] + item['quantity']
  276. device_model = None
  277. if DEVICE_TYPE.__contains__(di['Type']):
  278. device_model = DEVICE_TYPE[di['Type']]
  279. else:
  280. device_model = DEVICE_TYPE[0]
  281. model = {
  282. 'model': device_model,
  283. 'quantity': di['value']
  284. }
  285. item['models'].append(model)
  286. for k, v in tmpDict.items():
  287. data.append(v)
  288. return response.json(0, res)
  289. def getDeviceType(self, userID, response):
  290. own_permission = ModelService.check_perm(userID=userID, permID=30)
  291. if own_permission is not True:
  292. return response.json(404)
  293. # 设备类型统计
  294. di_qs = Device_Info.objects.values('Type').annotate(quantity=Count('UID', distinct=True)).order_by()
  295. # 设备型号统计
  296. us_qs = UidSetModel.objects.values('deviceModel').annotate(quantity=Count('id')).order_by()
  297. res = {
  298. 'type_data': {
  299. 'quantity': 0,
  300. 'data': []
  301. },
  302. 'model_data': {
  303. 'quantity': 0,
  304. 'data': []
  305. }
  306. }
  307. type_data = res['type_data']
  308. data = type_data['data']
  309. quantity = 0
  310. for di in di_qs:
  311. if DEVICE_TYPE.__contains__(di['Type']):
  312. device_model = DEVICE_TYPE[di['Type']]
  313. else:
  314. device_model = DEVICE_TYPE[0]
  315. di['Type'] = device_model
  316. quantity += di['quantity']
  317. data.append(di)
  318. type_data['quantity'] = quantity
  319. model_data = res['model_data']
  320. data = model_data['data']
  321. quantity = 0
  322. for us in us_qs:
  323. data.append(us)
  324. quantity += us['quantity']
  325. model_data['quantity'] = quantity
  326. return response.json(0, res)
  327. def getAppFrequency(self, userID, request_dict, response):
  328. own_permission = ModelService.check_perm(userID=userID, permID=30)
  329. if own_permission is not True:
  330. return response.json(404)
  331. # 当前的年份
  332. current_time = int(time.time())
  333. localtime = time.localtime(current_time)
  334. current_year = localtime.tm_year
  335. current_month = localtime.tm_mon
  336. start_year = end_year = current_year
  337. end_month = current_month
  338. start_month = 1
  339. result = []
  340. if end_month != 12:
  341. start_month = end_month + 1
  342. start_year = current_year - 1
  343. time_struct = [start_year, start_month, 0, 0, 0, 0, 0, 0, 0]
  344. key_formal = '{year}{month}'
  345. for i in range(12):
  346. result.append({
  347. 'date_time': key_formal.format(year=time_struct[0], month=str(time_struct[1]).zfill(2)),
  348. 'data': None
  349. })
  350. month = time_struct[1] + 1
  351. if month > 12:
  352. time_struct[0] = time_struct[0] + 1
  353. time_struct[1] = 1
  354. else:
  355. time_struct[1] = month
  356. #
  357. afs_qs = {}
  358. if start_year == end_year:
  359. afs_qs = list(AppFrequencyStatisticsModel.objects.filter(year=start_year, month__gte=start_month, month__lte=end_month).values().order_by('-year', 'month'))
  360. else:
  361. afs_qs = list(AppFrequencyStatisticsModel.objects.filter(year=start_year, month__gte=start_month).values().order_by('-year', 'month'))
  362. tmps_qs = list(AppFrequencyStatisticsModel.objects.filter(year=end_year, month__lte=end_month).values().order_by('-year', 'month'))
  363. for tmp in tmps_qs:
  364. afs_qs.append(tmp)
  365. tmp_dict = {}
  366. for afs in afs_qs:
  367. key = key_formal.format(year=afs['year'], month=str(afs['month']).zfill(2))
  368. tmp_dict[key] = json.loads(afs['data'])
  369. for res in result:
  370. if tmp_dict.__contains__(res['date_time']):
  371. res['data'] = tmp_dict[res['date_time']]
  372. print(result)
  373. return response.json(0, result)
  374. def getAllAppFrequency(self, userID, response):
  375. own_permission = ModelService.check_perm(userID=userID, permID=30)
  376. if own_permission is not True:
  377. return response.json(404)
  378. # 取出请求年份的统计好的数据
  379. print('start')
  380. time_struct = time.localtime()
  381. current_year = time_struct.tm_year
  382. start_year = current_year - 5 + 1
  383. afs_qs = AppFrequencyYearStatisticsModel.objects.filter(year__gte=start_year, year__lt=current_year).order_by(
  384. '-year')
  385. if afs_qs.exists():
  386. afs_qs = afs_qs.values('id', 'data', 'num', 'year')
  387. res = []
  388. for afs in afs_qs:
  389. res.append({
  390. 'year': afs['year'],
  391. 'data': json.loads(afs['data'])
  392. })
  393. return response.json(0, res)
  394. else:
  395. return response.json(0, [])
  396. def query_push_by_level(self, userID, request_dict, response):
  397. own_permission = ModelService.check_perm(userID=userID, permID=30)
  398. if own_permission is not True:
  399. return response.json(404)
  400. level = request_dict.get('level', None)
  401. print(level)
  402. if level is None:
  403. return response.json(444)
  404. level = int(level)
  405. if level < 0:
  406. return response.json(444)
  407. elif level < 3:
  408. return self.query_push_day_statistics(level, response)
  409. else:
  410. return response.json(404)
  411. def query_push_day_statistics(self, level, response):
  412. start_time = 0
  413. end_time = 0
  414. localtime = time.localtime()
  415. current_day = localtime.tm_mday
  416. time_struct = [localtime.tm_year, localtime.tm_mon, current_day, 0, 0, 0, 0, 0, 0]
  417. current_time = time.mktime(tuple(time_struct))
  418. count = 0
  419. if level == 0: # 七天
  420. start_time = current_time - 6 * 24 * 60 * 60
  421. count = 6
  422. elif level == 1:
  423. start_time = current_time - 13 * 24 * 60 * 60
  424. count = 13
  425. elif level == 2:
  426. start_time = current_time - 29 * 24 * 60 * 60
  427. count = 29
  428. end_time = current_time
  429. eqx_qs = EquipmentInfoExStatisticsModel.objects.filter(statistics_date__gte=start_time, statistics_date__lte=end_time, date_type=0, push_type=-1).values()
  430. data = []
  431. for i in range(count + 1):
  432. data.append({
  433. 'date_time': time.strftime('%m-%d', time.localtime(start_time)),
  434. 'data': None
  435. })
  436. start_time += (24 * 60 * 60)
  437. tmp_dict = {}
  438. successes = 0
  439. failures = 0
  440. for eqx in eqx_qs:
  441. statistics_date = time.strftime('%m-%d', time.localtime(eqx['statistics_date']))
  442. successes += eqx['number_of_successes']
  443. failures += eqx['number_of_failures']
  444. tmp_dict[statistics_date] = {
  445. 'number_of_successes': eqx['number_of_successes'],
  446. 'number_of_failures': eqx['number_of_failures'],
  447. 'total': (eqx['number_of_successes'] + eqx['number_of_failures'])
  448. }
  449. # 取出当前的推送数据
  450. start_time = current_time
  451. current_time = int(time.time())
  452. eq_qs = EquipmentInfoExModel.objects.filter(add_time__gte=start_time, add_time__lte=current_time)
  453. print(eq_qs.values())
  454. # 0:APNS推送,1:谷歌推送,2:极光推送
  455. tmp = {
  456. 'number_of_successes': 0,
  457. 'number_of_failures': 0,
  458. 'total': 0
  459. }
  460. for eq in eq_qs:
  461. if eq.push_server_status == 200:
  462. tmp['number_of_successes'] += 1
  463. successes += 1
  464. else:
  465. tmp['number_of_failures'] += 1
  466. failures += 1
  467. tmp['total'] += 1
  468. statistics_date = time.strftime('%M-%d', time.localtime(start_time))
  469. tmp_dict[statistics_date] = tmp
  470. for item in data:
  471. if tmp_dict.__contains__(item['date_time']):
  472. item['data'] = tmp_dict[item['date_time']]
  473. success_rate = (successes / (successes + failures))
  474. arrival_rate = success_rate
  475. res = {
  476. 'data': data,
  477. 'successes': successes,
  478. 'failures': failures,
  479. 'success_rate': success_rate,
  480. 'arrival_rate': arrival_rate
  481. }
  482. return response.json(0, res)
  483. @require_http_methods(["GET"])
  484. def getUserIds(request):
  485. token = request.GET.get('token', None)
  486. response = ResponseObject()
  487. tko = TokenObject(token)
  488. response.lang = tko.lang
  489. if tko.code != 0:
  490. return response.json(tko.code)
  491. userID = tko.userID
  492. own_perm = ModelService.check_perm(userID, 30)
  493. if own_perm is not True:
  494. return response.json(404)
  495. dn = Device_User.objects.all().values('userID', 'username')
  496. return response.json(0, {"datas": list(dn)})
  497. @csrf_exempt
  498. def search_user_by_content(request):
  499. if request.method == 'GET':
  500. request_dict = request.GET
  501. if request.method == 'POST':
  502. request_dict = request.POST
  503. token = request_dict.get('token', None)
  504. page = request_dict.get('page', None)
  505. line = request_dict.get('line', None)
  506. content = request_dict.get('content', None)
  507. rstime = request_dict.get('rstime', None)
  508. retime = request_dict.get('retime', None)
  509. response = ResponseObject()
  510. if page is not None and line is not None:
  511. page = int(page)
  512. line = int(line)
  513. else:
  514. return response.json(10, 'page,line is none')
  515. tko = TokenObject(token)
  516. response.lang = tko.lang
  517. if tko.code != 0:
  518. return response.json(tko.code)
  519. userID = tko.userID
  520. own_perm = ModelService.check_perm(userID=userID, permID=20)
  521. if own_perm is not True:
  522. return response.json(404)
  523. try:
  524. content = json.loads(content)
  525. search_kwargs = CommonService.get_kwargs(data=content)
  526. queryset = Device_User.objects.filter(**search_kwargs)
  527. except Exception as e:
  528. return response.json(444, repr(e))
  529. if rstime is not None and rstime != '' and retime is not None and retime != '':
  530. startt = datetime.datetime.fromtimestamp(int(rstime))
  531. rstime = startt.strftime("%Y-%m-%d %H:%M:%S.%f")
  532. endt = datetime.datetime.fromtimestamp(int(retime))
  533. retime = endt.strftime("%Y-%m-%d %H:%M:%S.%f")
  534. queryset = queryset.filter(data_joined__range=(rstime, retime))
  535. elif rstime is not None and rstime != '':
  536. startt = datetime.datetime.fromtimestamp(int(rstime))
  537. rstime = startt.strftime("%Y-%m-%d %H:%M:%S.%f")
  538. queryset = queryset.filter(data_joined__gte=rstime)
  539. elif retime is not None and retime != '':
  540. endt = datetime.datetime.fromtimestamp(int(retime))
  541. retime = endt.strftime("%Y-%m-%d %H:%M:%S.%f")
  542. queryset = queryset.filter(data_joined__lte=retime)
  543. if queryset.exists():
  544. count = queryset.count()
  545. res = queryset[(page - 1) * line:page * line]
  546. sqlDict = CommonService.qs_to_dict(res)
  547. for k, v in enumerate(sqlDict["datas"]):
  548. if len(v['fields']['role']) > 0:
  549. role_query_set = Role.objects.get(rid=v['fields']['role'][0])
  550. sqlDict["datas"][k]['fields']['role'].append(role_query_set.roleName)
  551. for val in res:
  552. if v['pk'] == val.userID:
  553. if sqlDict["datas"][k]['fields']['online'] is True:
  554. dl_time = val.last_login + datetime.timedelta(minutes=5)
  555. now_time = timezone.localtime(timezone.now())
  556. if now_time > dl_time:
  557. sqlDict["datas"][k]['fields']['online'] = False
  558. ue = UserExModel.objects.filter(userID=v['pk'])
  559. if ue.exists():
  560. sqlDict["datas"][k]['fields']['appBundleId'] = ue[0].appBundleId
  561. else:
  562. sqlDict["datas"][k]['fields']['appBundleId'] = ''
  563. sqlDict['count'] = count
  564. return response.json(0, sqlDict)
  565. return response.json(0, {'datas': [], 'count': 0})