UserBrandController.py 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663
  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/9 11:50
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: AliPayObject.py
  12. @Contact: pzb3076@163.com
  13. """
  14. import time
  15. from collections import Counter
  16. from django.utils.decorators import method_decorator
  17. from django.views.decorators.csrf import csrf_exempt
  18. from django.views.generic.base import View
  19. from Ansjer.config import DOMAIN_HOST, AWS_DynamoDB_REGION, AWS_DynamoDB_ACCESS_KEY, AWS_DynamoDB_SECRET_KEY, \
  20. USER_BRAND, USER_BRAND_ALL
  21. from Model.models import Device_User
  22. from Object.RedisObject import RedisObject
  23. from Object.ResponseObject import ResponseObject
  24. from Object.TokenObject import TokenObject
  25. from Service.CommonService import CommonService
  26. from Service.ModelService import ModelService
  27. '''
  28. http://192.168.136.39:8000/userbrandinfo/queryByAdmin?token=test&page=1&line=10 记录
  29. http://192.168.136.39:8000/userbrandinfo/queryArea?token=test 市的区域统计
  30. http://192.168.136.39:8000/userbrandinfo/queryDeviceSupplier?token=test 品牌统计
  31. http://192.168.136.39:8000/userbrandinfo/queryAllByAdmin?token=test&page=1&line=10 全部记录中每个用户的数据
  32. http://192.168.136.39:8000/userbrandinfo/queryAll?token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VySUQiOiIxNTQzOTA5MDUwNDEzMTM4MDAxMzgwMDAiLCJsYW5nIjoiY24iLCJ1c2VyIjoiMTM4MDAxMzgwMDEiLCJtX2NvZGUiOiIxMjM0MTMyNDMyMTQiLCJleHAiOjE1NTk4OTY4NTd9.nhK3VSghSGjyXKjel4woz7R_3bhjgqQDlX-ypYsklNU&page=1&line=5
  33. '''
  34. # coding:utf-8
  35. from boto3 import Session
  36. from botocore.exceptions import ClientError
  37. from boto3.dynamodb.conditions import Key, Attr
  38. import logging
  39. import json
  40. logger = logging.getLogger(__name__)
  41. class MyserviceDynamodb(object):
  42. def __init__(self, **kwargs):
  43. self.region = AWS_DynamoDB_REGION
  44. self.access_key = AWS_DynamoDB_ACCESS_KEY
  45. self.secret_key = AWS_DynamoDB_SECRET_KEY
  46. self.session = self.__session()
  47. def __session(self):
  48. try:
  49. session = Session(aws_access_key_id=self.access_key, aws_secret_access_key=self.secret_key,
  50. region_name=self.region)
  51. except:
  52. print("Failed to connect session in region{0}".format(self.region))
  53. return session
  54. # 创建user_brand_all表
  55. def user_brand_all_table_create(self, table_name):
  56. dynamodb = self.session.resource('dynamodb')
  57. inventory = my.tables_list(table_name)
  58. if table_name in inventory:
  59. print('包含')
  60. else:
  61. try:
  62. table = dynamodb.create_table(
  63. TableName=table_name,
  64. KeySchema=[
  65. {
  66. 'AttributeName': 'userID',
  67. 'KeyType': 'HASH'
  68. },
  69. {
  70. 'AttributeName': 'addTime',
  71. 'KeyType': 'RANGE'
  72. }
  73. ],
  74. AttributeDefinitions=[
  75. {
  76. 'AttributeName': 'userID',
  77. 'AttributeType': 'S'
  78. },
  79. {
  80. 'AttributeName': 'addTime',
  81. 'AttributeType': 'N'
  82. },
  83. ],
  84. ProvisionedThroughput={
  85. 'ReadCapacityUnits': 5,
  86. 'WriteCapacityUnits': 5,
  87. }
  88. )
  89. except Exception:
  90. logger.error(table_name + '表已经存在')
  91. # 查询aws数据库里面有什么表
  92. def tables_list(self, table_name):
  93. client = self.session.client('dynamodb')
  94. response = client.list_tables()
  95. return response['TableNames']
  96. # 创建user_brand表
  97. def table_create(self, table_name):
  98. dynamodb = self.session.resource('dynamodb')
  99. inventory = my.tables_list(table_name)
  100. if table_name in inventory:
  101. print('包含')
  102. else:
  103. try:
  104. table = dynamodb.create_table(
  105. TableName=table_name,
  106. KeySchema=[
  107. {
  108. 'AttributeName': 'userID',
  109. 'KeyType': 'HASH'
  110. }
  111. ],
  112. AttributeDefinitions=[
  113. {
  114. 'AttributeName': 'userID',
  115. 'AttributeType': 'S'
  116. }
  117. ],
  118. ProvisionedThroughput={
  119. 'ReadCapacityUnits': 5,
  120. 'WriteCapacityUnits': 5,
  121. }
  122. )
  123. except Exception:
  124. logger.error(table_name + '表已经存在')
  125. # 添加user_brand_all表数据
  126. def user_brand_all_item_put(self, table_name, data_list):
  127. dynamodb = self.session.resource('dynamodb')
  128. table = dynamodb.Table(table_name)
  129. with table.batch_writer() as batch:
  130. for i in data_list:
  131. data = json.loads(i.decode('utf-8'))
  132. # print (json.loads(i))
  133. # data = i
  134. if data['city'] == '':
  135. data['city'] = '无'
  136. if data['area'] == '':
  137. data['area'] = '无'
  138. if data['street'] == '':
  139. data['street'] = '无'
  140. if data['longitude'] == '':
  141. data['longitude'] = '无'
  142. if data['latitude'] == '':
  143. data['latitude'] = '无'
  144. batch.put_item(
  145. Item={
  146. 'userID': data['userID'],
  147. 'addTime': data['addTime'],
  148. 'deviceSupplier': data['deviceSupplier'],
  149. 'deviceModel': data['deviceModel'],
  150. 'osType': data['osType'],
  151. 'osVersion': data['osVersion'],
  152. 'country': data['country'],
  153. 'province': data['province'],
  154. 'city': data['city'],
  155. 'area': data['area'],
  156. 'street': data['street'],
  157. 'longitude': data['longitude'],
  158. 'latitude': data['latitude'],
  159. 'appId': data['appId'],
  160. 'status_all': data['status_all'],
  161. 'ExpirationTime_TTL': data['ExpirationTime_TTL'],
  162. 'ip': data['ip'],
  163. }
  164. )
  165. print('批量添加数据成功!')
  166. # 添加user_brand表数据
  167. def user_brand_item_put(self, table_name, user_id, add_time, device_supplier, device_model, os_type,
  168. os_version, country, province, city, area, street, longitude, latitude, app_id,
  169. status_all, ip):
  170. dynamodb = self.session.resource('dynamodb')
  171. table = dynamodb.Table(table_name)
  172. table.put_item(
  173. Item={
  174. 'userID': user_id,
  175. 'addTime': add_time,
  176. 'deviceSupplier': device_supplier,
  177. 'deviceModel': device_model,
  178. 'osType': os_type,
  179. 'osVersion': os_version,
  180. 'country': country,
  181. 'province': province,
  182. 'city': city,
  183. 'area': area,
  184. 'street': street,
  185. 'longitude': longitude,
  186. 'latitude': latitude,
  187. 'appId': app_id,
  188. 'status_all': status_all,
  189. 'ip': ip,
  190. }
  191. )
  192. print('添加表一条数据成功!')
  193. # page分页数,line条数,table_name表名称,last_evaluated查询开始值,page_value记录分页开始值
  194. def get_page_line(self, page, line, table_name, last_evaluated, page_value):
  195. dynamodb = self.session.resource('dynamodb')
  196. if not dynamodb:
  197. raise DynamodbConnectionError("Failed to get resource for dynamodb!")
  198. table = dynamodb.Table(table_name)
  199. last_evaluated_key = last_evaluated
  200. try:
  201. if last_evaluated_key is None:
  202. response = table.scan(
  203. Limit=line,
  204. )
  205. page_value.append(last_evaluated_key)
  206. else:
  207. # 构建分页的起点,传入下一页面的起点,这是由主键来控制的,last_evaluated_key的值就是本表中的uid
  208. response = table.scan(
  209. Limit=line,
  210. ExclusiveStartKey=last_evaluated_key)
  211. try:
  212. last_evaluated_key = response['LastEvaluatedKey']
  213. # 如果有知就追加在该值的后面
  214. page_value.append(last_evaluated_key)
  215. my.get_page_line(page, line, table_name, last_evaluated_key, page_value)
  216. except Exception:
  217. return page_value
  218. except Exception as e:
  219. logger.error("Failed to get table {0}, error".format(table_name, e))
  220. return page_value
  221. def item_get(self, line, table_name, last_evaluated_key):
  222. dynamodb = self.session.resource('dynamodb')
  223. table = dynamodb.Table(table_name)
  224. if last_evaluated_key is None:
  225. response = table.scan(
  226. Limit=line,
  227. )
  228. else:
  229. # 构建分页的起点,传入下一页面的起点,这是由主键来控制的,last_evaluated_key的值就是本表中的uid
  230. response = table.scan(
  231. Limit=line,
  232. ExclusiveStartKey=last_evaluated_key)
  233. return response
  234. def item_get_count(self, table_name):
  235. dynamodb = self.session.resource('dynamodb')
  236. table = dynamodb.Table(table_name)
  237. response = table.scan()
  238. return len(response['Items'])
  239. def item_get_brand(self, table_name):
  240. dynamodb = self.session.resource('dynamodb')
  241. table = dynamodb.Table(table_name)
  242. try:
  243. response = table.scan()
  244. response = response['Items']
  245. return response
  246. except Exception:
  247. logger.error("Failed to put item in to {0}:error{1}".format(table))
  248. def put_item(self, table, item_dict=None):
  249. try:
  250. response = table.put_item(Item=item_dict)
  251. except Exception as e:
  252. logger.error("Failed to put item in to {0}:error{1}".format(table, e))
  253. return response
  254. def get_item(self, table_name, username):
  255. dynamodb = self.session.resource('dynamodb')
  256. if not dynamodb:
  257. raise DynamodbConnectionError("Failed to get resource for dynamodb!")
  258. try:
  259. table = dynamodb.Table(table_name)
  260. response = table.scan(
  261. FilterExpression=Attr('deviceSupplier').eq(username)
  262. | Key('osType').eq(username)
  263. | Key('deviceModel').eq(username)
  264. | Key('userID').eq(username)
  265. | Key('osVersion').eq(username)
  266. | Key('country').eq(username)
  267. | Key('appId').eq(username)
  268. | Key('province').eq(username)
  269. | Key('city').eq(username)
  270. | Key('area').eq(username)
  271. | Key('street').eq(username)
  272. | Key('longitude').eq(username)
  273. | Key('latitude').eq(username)
  274. | Key('status_all').eq(username)
  275. | Key('ip').eq(username)
  276. )
  277. items = response['Items']
  278. for k, v in enumerate(items):
  279. # print (items[k]['userID'])
  280. user_ID = Device_User.objects.filter(userID=items[k]['userID']).values('userID', 'username', 'NickName')
  281. try:
  282. items[k]['username'] = user_ID[0]['username']
  283. except Exception:
  284. items[k]['username'] = ''
  285. except Exception as e:
  286. logger.error("Failed to get table {0}, error".format(table_name, e))
  287. return items
  288. def update_table(self, table_name, user_id, username, add_time, deviceSupplier, deviceModel, osType, osVersion,
  289. country, province, city, area, street, longitude, latitude, appId, ip, status_all
  290. ):
  291. dynamodb = self.session.resource('dynamodb')
  292. table = dynamodb.Table(table_name)
  293. try:
  294. response = table.update_item(
  295. Key={
  296. 'userID': user_id,
  297. 'username': username
  298. },
  299. UpdateExpression="SET addTime = :add_time, deviceSupplier= :deviceSupplier, deviceModel = :deviceModel, osType = :osType, osVersion = :osVersion, country = :country, province = :province, city = :city, area= :area, street= :street, longitude= :longitude, latitude= :latitude, appId= :appId, ip= :ip, status_all= :status_all",
  300. ExpressionAttributeValues={
  301. ':add_time': add_time,
  302. ':deviceSupplier': deviceSupplier,
  303. ':deviceModel': deviceModel,
  304. ':osType': osType,
  305. ':osVersion': osVersion,
  306. ':country': country,
  307. ':province': province,
  308. ':city': city,
  309. ':area': area,
  310. ':street': street,
  311. ':longitude': longitude,
  312. ':latitude': latitude,
  313. ':appId': appId,
  314. ':ip': ip,
  315. ':status_all': status_all,
  316. }, ReturnValues="UPDATED_NEW")
  317. except ClientError as e:
  318. if e.response['Error']['Code'] == "ConditionalCheckFailedException":
  319. logger.error(e.response['Error']['Message'])
  320. else:
  321. print('Failed update the dynamodb by event_id,not Failed Conditional')
  322. else:
  323. print('修改成功')
  324. def table_delete(self, table_name):
  325. dynamodb = self.session.resource('dynamodb')
  326. table = dynamodb.Table(table_name)
  327. table.delete()
  328. print('删除表成功')
  329. def item_delete(self, table_name, name, user_id, add_time):
  330. dynamodb = self.session.resource('dynamodb')
  331. table = dynamodb.Table(table_name)
  332. try:
  333. if name == 'user_brand':
  334. table.delete_item(
  335. Key={
  336. 'userID': user_id,
  337. }
  338. )
  339. else:
  340. table.delete_item(
  341. Key={
  342. 'userID': user_id,
  343. 'addTime': int(add_time),
  344. }
  345. )
  346. return 'ok'
  347. except Exception:
  348. logger.error("Failed to put item in to {0}:error{1}".format(table))
  349. return 'no'
  350. my = MyserviceDynamodb()
  351. # print(my.table_delete('user_brand'))
  352. # print(my.table_delete('user_brand_all'))
  353. my.table_create(USER_BRAND)
  354. my.user_brand_all_table_create(USER_BRAND_ALL)
  355. # print(my.item_put('user_brand'))
  356. # table_value = my.get_table('user_brand')
  357. class UserBrandInfo(View):
  358. @method_decorator(csrf_exempt)
  359. def dispatch(self, *args, **kwargs):
  360. return super(UserBrandInfo, self).dispatch(*args, **kwargs)
  361. def get(self, request, *args, **kwargs):
  362. request.encoding = 'utf-8'
  363. operation = kwargs.get('operation')
  364. return self.validation(request.GET, request, operation)
  365. def post(self, request, *args, **kwargs):
  366. request.encoding = 'utf-8'
  367. operation = kwargs.get('operation')
  368. return self.validation(request.POST, request, operation)
  369. def validation(self, request_dict, request, operation):
  370. self.clientIP = CommonService.get_ip_address(request)
  371. response = ResponseObject()
  372. token = request_dict.get('token', None)
  373. tko = TokenObject(token)
  374. if tko.code == 0:
  375. response.lang = tko.lang
  376. userID = tko.userID
  377. if operation == 'add':
  378. return self.add_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  379. elif operation == 'queryByAdmin':
  380. return self.query_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  381. elif operation == 'queryAllByAdmin':
  382. return self.query_all_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  383. elif operation == 'deleteByAdmin':
  384. return self.delete_by_admin(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  385. elif operation == 'queryDeviceSupplier':
  386. return self.query_deviceSupplier_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  387. elif operation == 'queryArea':
  388. return self.query_area_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  389. else:
  390. return response.json(444)
  391. else:
  392. return response.json(tko.code)
  393. # http://192.168.136.39:8000/userbrandinfo?operation=add&token=test&deviceSupplier=小米&deviceModel=HM NOTE 1TD&osType=WEB&osVersion=4.0.0
  394. def add_info(self, request_dict, userID, user_brand, user_brand_all, response):
  395. deviceSupplier = request_dict.get('deviceSupplier', None)
  396. deviceModel = request_dict.get('deviceModel', None)
  397. osType = request_dict.get('osType', None)
  398. osVersion = request_dict.get('osVersion', None)
  399. country = request_dict.get('country', None)
  400. province = request_dict.get('province', None)
  401. city = request_dict.get('city', '')
  402. area = request_dict.get('area', '')
  403. street = request_dict.get('street', '')
  404. longitude = request_dict.get('longitude', '')
  405. latitude = request_dict.get('latitude', '')
  406. appId = request_dict.get('appId', None)
  407. if city == '':
  408. city = '无'
  409. if area == '':
  410. area = '无'
  411. if street == '':
  412. street = '无'
  413. if longitude == '':
  414. longitude = '无'
  415. if latitude == '':
  416. latitude = '无'
  417. param_area = CommonService.get_param_flag(data=[country, province, city])
  418. must_fill_in = CommonService.get_param_flag(data=[appId, deviceSupplier, deviceModel, osType, osVersion])
  419. if must_fill_in is False:
  420. return response.json(444, 'appId,deviceSupplier,deviceModel,osType,osVersion')
  421. if param_area is True:
  422. if '省' in province:
  423. province = province.replace('省', '')
  424. if '市' in city:
  425. city = city.replace('市', '')
  426. status = 1
  427. country = country
  428. province = province
  429. city = city
  430. area = area
  431. street = street
  432. longitude = longitude
  433. latitude = latitude
  434. else:
  435. status = 0
  436. jsonData = CommonService.getIpIpInfo(ip=self.clientIP, lang='CN')
  437. country = jsonData['country_name']
  438. province = jsonData['region_name']
  439. city = jsonData['city_name']
  440. area = '无'
  441. street = '无'
  442. longitude = jsonData['longitude']
  443. latitude = jsonData['latitude']
  444. if country == '局域网':
  445. city = '无'
  446. longitude = '无'
  447. latitude = '无'
  448. param_flag = CommonService.get_param_flag(data=[deviceSupplier, deviceModel, osType, osVersion])
  449. if param_flag is True:
  450. addTime = int(time.time())
  451. print(time.time())
  452. add_data = {
  453. 'userID': userID,
  454. 'addTime': addTime,
  455. 'deviceSupplier': deviceSupplier,
  456. 'deviceModel': deviceModel,
  457. 'osType': osType,
  458. 'osVersion': osVersion,
  459. 'country': country,
  460. 'province': province,
  461. 'city': city,
  462. 'area': area,
  463. 'street': street,
  464. 'longitude': longitude,
  465. 'latitude': latitude,
  466. 'appId': appId,
  467. 'status_all': status,
  468. 'ExpirationTime_TTL': addTime + 2592000,
  469. 'ip': self.clientIP
  470. }
  471. redisObj = RedisObject()
  472. add_user_brand_all_data = json.dumps(add_data)
  473. logKey = USER_BRAND_ALL
  474. redisObj.rpush(name=logKey, val=add_user_brand_all_data)
  475. # print (redisObj.llen(name=logKey))
  476. # 判断redis列表长度
  477. try:
  478. if redisObj.llen(name=logKey) > 100:
  479. data_list = redisObj.lrange(logKey, 0, -1)
  480. redisObj.del_data(key=logKey)
  481. # 添加user_brand_all表信息
  482. my.user_brand_all_item_put(user_brand_all, data_list)
  483. # 添加user_brand表信息
  484. my.user_brand_item_put(user_brand, userID, addTime, deviceSupplier, deviceModel,
  485. osType, osVersion,
  486. country, province, city, area, street, longitude, latitude, appId, status,
  487. self.clientIP)
  488. except Exception:
  489. my.table_create(USER_BRAND)
  490. my.user_brand_all_table_create(USER_BRAND_ALL)
  491. return response.json(0, {'OK': int(time.time())})
  492. else:
  493. # 参数错误
  494. return response.json(444)
  495. # 查询每个用户的最新登录数据表
  496. def query_info(self, request_dict, userID, user_brand, user_brand_all, response):
  497. page = int(request_dict.get('page', None))
  498. line = int(request_dict.get('line', None))
  499. username = request_dict.get('username', None)
  500. param_flag = CommonService.get_param_flag(data=[page, line])
  501. if param_flag is True:
  502. check_perm = ModelService.check_perm(userID=userID, permID=30)
  503. page_value = []
  504. if check_perm is True:
  505. if username is None or username is '':
  506. # table_Limit_value = my.get_page_line(page,line,user_brand,None,page_value)
  507. # # 页面减1
  508. # page = page-1
  509. # if page < len(table_Limit_value):
  510. # # 分页后查询
  511. # table_value = my.item_get(line,user_brand,table_Limit_value[page])
  512. # table_value = table_value['Items']
  513. # count = my.item_get_count(user_brand)
  514. # return response.json(0, {'datas': table_value, 'count': count})
  515. return response.json(0, {'datas': {}, 'count': 0})
  516. else:
  517. # 查询
  518. user_ID = Device_User.objects.filter(username=username).values('userID', 'NickName')
  519. try:
  520. username = user_ID[0]['userID']
  521. except Exception:
  522. username = username
  523. table_value = my.get_item(user_brand, username)
  524. return response.json(0, {'datas': table_value, 'count': len(table_value)})
  525. else:
  526. return response.json(404)
  527. else:
  528. return response.json(444)
  529. # 删除接口
  530. def delete_by_admin(self, request_dict, userID, user_brand, user_brand_all, response):
  531. id = request_dict.getlist('id', None)
  532. username = request_dict.getlist('username', None)
  533. add_time = request_dict.getlist('add_time', None)
  534. table_name = request_dict.getlist('table_name', None)
  535. param_flag = CommonService.get_param_flag(data=[id, username])
  536. if param_flag is True:
  537. check_perm = ModelService.check_perm(userID=userID, permID=10)
  538. if check_perm is True:
  539. if str(table_name[0]) == 'user_brand':
  540. is_delete = my.item_delete(user_brand, 'user_brand', id[0], add_time[0])
  541. else:
  542. is_delete = my.item_delete(user_brand_all, 'user_brand_all', id[0], add_time[0])
  543. return response.json(0, {'delete_count': is_delete[0]})
  544. else:
  545. return response.json(404)
  546. else:
  547. return response.json(444)
  548. # Query each user record statistics
  549. def query_all_info(self, request_dict, userID, user_brand, user_brand_all, response):
  550. page = int(request_dict.get('page', None))
  551. line = int(request_dict.get('line', None))
  552. username = request_dict.get('username', None)
  553. param_flag = CommonService.get_param_flag(data=[page, line])
  554. if param_flag is True:
  555. check_perm = ModelService.check_perm(userID=userID, permID=30)
  556. page_value = []
  557. if check_perm is True:
  558. if username is None or username is '':
  559. # table_Limit_value = my.get_page_line(page, line, user_brand_all, None, page_value)
  560. # page = page - 1
  561. # if page < len(table_Limit_value):
  562. # table_value = my.item_get(line, user_brand_all, table_Limit_value[page])
  563. # table_value = table_value['Items']
  564. # count = my.item_get_count(user_brand_all)
  565. # return response.json(0, {'datas': table_value, 'count': count})
  566. return response.json(0, {'datas': {}, 'count': 0})
  567. else:
  568. # 查询
  569. user_ID = Device_User.objects.filter(username=username).values('userID', 'NickName')
  570. try:
  571. username = user_ID[0]['userID']
  572. except Exception:
  573. username = username
  574. table_value = my.get_item(user_brand_all, username)
  575. return response.json(0, {'datas': table_value, 'count': len(table_value)})
  576. else:
  577. return response.json(404)
  578. else:
  579. return response.json(444)
  580. # Brand statistics interface
  581. def query_deviceSupplier_info(self, request_dict, userID, user_brand, user_brand_all, response):
  582. check_perm = ModelService.check_perm(userID=userID, permID=30)
  583. if check_perm is True:
  584. table_value = my.item_get_brand(user_brand)
  585. send_jsons = []
  586. counts = 0
  587. for i in table_value:
  588. send_jsons.append(table_value[counts]['deviceSupplier'])
  589. counts = counts + 1
  590. send_jsons = Counter(send_jsons)
  591. return response.json(0, {'datas': send_jsons, 'counts': counts})
  592. else:
  593. return response.json(404)
  594. # Interface to area statistics
  595. def query_area_info(self, request_dict, userID, user_brand, user_brand_all, response):
  596. check_perm = ModelService.check_perm(userID=userID, permID=30)
  597. district = request_dict.get('district', None)
  598. if check_perm is True:
  599. # 按照用户去重复查询
  600. table_value = my.item_get_brand(user_brand)
  601. send_jsons = []
  602. counts = 0
  603. for i in table_value:
  604. send_jsons.append(table_value[counts][district])
  605. counts = counts + 1
  606. send_jsons = Counter(send_jsons)
  607. return response.json(0, {'datas': send_jsons, 'counts': counts})
  608. else:
  609. return response.json(404)