UserBrandController.py 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733
  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 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. # 已经查询全部
  240. def item_get_brand(self, table_name):
  241. dynamodb = self.session.resource('dynamodb')
  242. table = dynamodb.Table(table_name)
  243. last_evaluated_key = None
  244. i = 0
  245. table_info = []
  246. while True:
  247. # 刚开始,不需要传入startkey
  248. if last_evaluated_key is None:
  249. response = table.scan()
  250. else:
  251. # 构建分页的起点,传入下一页面的起点,这是由主键来控制的,last_evaluated_key的值就是本表中的uid
  252. try:
  253. response = table.scan(ExclusiveStartKey=last_evaluated_key)
  254. except Exception:
  255. break
  256. # print type(response) #字典
  257. i = i + 1
  258. print (i)
  259. if response['Items'] != []:
  260. table_info.extend(response['Items'])
  261. # 判断有没有这个LastEvaluatedKey,如果有,那么还有页面没有拉取玩,将这个值带入request的ExclusiveStartKey中,继续读取页面
  262. try:
  263. if response['LastEvaluatedKey']:
  264. last_evaluated_key = response['LastEvaluatedKey']
  265. continue
  266. else:
  267. break
  268. except Exception:
  269. break
  270. return table_info
  271. def put_item(self, table, item_dict=None):
  272. try:
  273. response = table.put_item(Item=item_dict)
  274. except Exception as e:
  275. logger.error("Failed to put item in to {0}:error{1}".format(table, e))
  276. return response
  277. def update_table(self, table_name, user_id, username, add_time, deviceSupplier, deviceModel, osType, osVersion,
  278. country, province, city, area, street, longitude, latitude, appId, ip, status_all
  279. ):
  280. dynamodb = self.session.resource('dynamodb')
  281. table = dynamodb.Table(table_name)
  282. try:
  283. response = table.update_item(
  284. Key={
  285. 'userID': user_id,
  286. 'username': username
  287. },
  288. 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",
  289. ExpressionAttributeValues={
  290. ':add_time': add_time,
  291. ':deviceSupplier': deviceSupplier,
  292. ':deviceModel': deviceModel,
  293. ':osType': osType,
  294. ':osVersion': osVersion,
  295. ':country': country,
  296. ':province': province,
  297. ':city': city,
  298. ':area': area,
  299. ':street': street,
  300. ':longitude': longitude,
  301. ':latitude': latitude,
  302. ':appId': appId,
  303. ':ip': ip,
  304. ':status_all': status_all,
  305. }, ReturnValues="UPDATED_NEW")
  306. except ClientError as e:
  307. if e.response['Error']['Code'] == "ConditionalCheckFailedException":
  308. logger.error(e.response['Error']['Message'])
  309. else:
  310. print('Failed update the dynamodb by event_id,not Failed Conditional')
  311. else:
  312. print('修改成功')
  313. def table_delete(self, table_name):
  314. dynamodb = self.session.resource('dynamodb')
  315. table = dynamodb.Table(table_name)
  316. table.delete()
  317. print('删除表成功')
  318. def item_delete(self, table_name, name, user_id, add_time):
  319. dynamodb = self.session.resource('dynamodb')
  320. table = dynamodb.Table(table_name)
  321. try:
  322. if name == 'user_brand':
  323. table.delete_item(
  324. Key={
  325. 'userID': user_id,
  326. }
  327. )
  328. else:
  329. table.delete_item(
  330. Key={
  331. 'userID': user_id,
  332. 'addTime': int(add_time),
  333. }
  334. )
  335. return 'ok'
  336. except Exception:
  337. logger.error("Failed to put item in to {0}:error{1}".format(table))
  338. return 'no'
  339. # 搜索查询并分页查询全部
  340. def get_table_info(self, table_name, username):
  341. """
  342. 对表进行分页扫描,这里尝试的是对visit_info表进行扫描
  343. """
  344. # 通过dynamodb服务获取目标table的操作对象
  345. dynamodb = self.session.resource('dynamodb')
  346. table_handle = dynamodb.Table(table_name)
  347. # 这个值是在分页查询的时候,用来记录页面的最后一个主键的下一个,以方便下一个页面的开启
  348. last_evaluated_key = None
  349. i = 0
  350. table_info =[]
  351. while True:
  352. # 刚开始,不需要传入startkey
  353. if last_evaluated_key is None:
  354. response = table_handle.scan(
  355. FilterExpression=Attr('deviceSupplier').eq(username)
  356. | Key('osType').eq(username)
  357. | Key('deviceModel').eq(username)
  358. | Key('userID').eq(username)
  359. | Key('osVersion').eq(username)
  360. | Key('country').eq(username)
  361. | Key('appId').eq(username)
  362. | Key('province').eq(username)
  363. | Key('city').eq(username)
  364. | Key('area').eq(username)
  365. | Key('street').eq(username)
  366. | Key('longitude').eq(username)
  367. | Key('latitude').eq(username)
  368. | Key('status_all').eq(username)
  369. | Key('ip').eq(username))
  370. else:
  371. # 构建分页的起点,传入下一页面的起点,这是由主键来控制的,last_evaluated_key的值就是本表中的uid
  372. try:
  373. response = table_handle.scan(
  374. ExclusiveStartKey=last_evaluated_key,
  375. FilterExpression=Attr('deviceSupplier').eq(username)
  376. | Key('osType').eq(username)
  377. | Key('deviceModel').eq(username)
  378. | Key('userID').eq(username)
  379. | Key('osVersion').eq(username)
  380. | Key('country').eq(username)
  381. | Key('appId').eq(username)
  382. | Key('province').eq(username)
  383. | Key('city').eq(username)
  384. | Key('area').eq(username)
  385. | Key('street').eq(username)
  386. | Key('longitude').eq(username)
  387. | Key('latitude').eq(username)
  388. | Key('status_all').eq(username)
  389. | Key('ip').eq(username))
  390. except Exception:
  391. break
  392. # response 有一个标准的json格式,包含了这次scan结果的各种信息
  393. # print type(response) #字典
  394. i = i+1
  395. print (i)
  396. if response['Items']!=[]:
  397. table_info.extend(response['Items'])
  398. # 判断有没有这个LastEvaluatedKey,如果有,那么还有页面没有拉取玩,将这个值带入request的ExclusiveStartKey中,继续读取页面
  399. try:
  400. if response['LastEvaluatedKey']:
  401. last_evaluated_key = response['LastEvaluatedKey']
  402. continue
  403. else:
  404. break
  405. except Exception:
  406. break
  407. for k, v in enumerate(table_info):
  408. user_ID = Device_User.objects.filter(userID=table_info[k]['userID']).values('userID', 'username', 'NickName')
  409. try:
  410. table_info[k]['username'] = user_ID[0]['username']
  411. except Exception:
  412. table_info[k]['username'] = ''
  413. return table_info
  414. pass
  415. my = MyserviceDynamodb()
  416. # print(my.table_delete('user_brand'))
  417. # print(my.table_delete('user_brand_all'))
  418. # my.table_create(USER_BRAND)
  419. # my.user_brand_all_table_create(USER_BRAND_ALL)
  420. # print(my.item_put('user_brand'))
  421. # table_value = my.get_table('user_brand')
  422. class UserBrandInfo(View):
  423. @method_decorator(csrf_exempt)
  424. def dispatch(self, *args, **kwargs):
  425. return super(UserBrandInfo, self).dispatch(*args, **kwargs)
  426. def get(self, request, *args, **kwargs):
  427. request.encoding = 'utf-8'
  428. operation = kwargs.get('operation')
  429. return self.validation(request.GET, request, operation)
  430. def post(self, request, *args, **kwargs):
  431. request.encoding = 'utf-8'
  432. operation = kwargs.get('operation')
  433. return self.validation(request.POST, request, operation)
  434. def validation(self, request_dict, request, operation):
  435. self.clientIP = CommonService.get_ip_address(request)
  436. response = ResponseObject()
  437. token = request_dict.get('token', None)
  438. tko = TokenObject(token)
  439. if tko.code == 0:
  440. response.lang = tko.lang
  441. userID = tko.userID
  442. if operation == 'add':
  443. return self.add_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  444. elif operation == 'queryByAdmin':
  445. return self.query_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  446. elif operation == 'queryAllByAdmin':
  447. return self.query_all_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  448. elif operation == 'deleteByAdmin':
  449. return self.delete_by_admin(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  450. elif operation == 'queryDeviceSupplier':
  451. return self.query_deviceSupplier_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  452. elif operation == 'queryArea':
  453. return self.query_area_info(request_dict, userID, USER_BRAND, USER_BRAND_ALL, response)
  454. else:
  455. return response.json(444)
  456. else:
  457. return response.json(tko.code)
  458. # http://192.168.136.39:8000/userbrandinfo?operation=add&token=test&deviceSupplier=小米&deviceModel=HM NOTE 1TD&osType=WEB&osVersion=4.0.0
  459. def add_info(self, request_dict, userID, user_brand, user_brand_all, response):
  460. return response.json(0, {'OK': int(time.time())})
  461. deviceSupplier = request_dict.get('deviceSupplier', None)
  462. deviceModel = request_dict.get('deviceModel', None)
  463. osType = request_dict.get('osType', None)
  464. osVersion = request_dict.get('osVersion', None)
  465. country = request_dict.get('country', None)
  466. province = request_dict.get('province', None)
  467. city = request_dict.get('city', '')
  468. area = request_dict.get('area', '')
  469. street = request_dict.get('street', '')
  470. longitude = request_dict.get('longitude', '')
  471. latitude = request_dict.get('latitude', '')
  472. appId = request_dict.get('appId', None)
  473. if city == '':
  474. city = '无'
  475. if area == '':
  476. area = '无'
  477. if street == '':
  478. street = '无'
  479. if longitude == '':
  480. longitude = '无'
  481. if latitude == '':
  482. latitude = '无'
  483. param_area = CommonService.get_param_flag(data=[country, province, city])
  484. must_fill_in = CommonService.get_param_flag(data=[appId, deviceSupplier, deviceModel, osType, osVersion])
  485. if must_fill_in is False:
  486. return response.json(444, 'appId,deviceSupplier,deviceModel,osType,osVersion')
  487. if param_area is True:
  488. if '省' in province:
  489. province = province.replace('省', '')
  490. if '市' in city:
  491. city = city.replace('市', '')
  492. status = 1
  493. country = country
  494. province = province
  495. city = city
  496. area = area
  497. street = street
  498. longitude = longitude
  499. latitude = latitude
  500. else:
  501. status = 0
  502. jsonData = CommonService.getIpIpInfo(ip=self.clientIP, lang='CN')
  503. country = jsonData['country_name']
  504. province = jsonData['region_name']
  505. city = jsonData['city_name']
  506. area = '无'
  507. street = '无'
  508. longitude = jsonData['longitude']
  509. latitude = jsonData['latitude']
  510. if country == '局域网':
  511. city = '无'
  512. longitude = '无'
  513. latitude = '无'
  514. param_flag = CommonService.get_param_flag(data=[deviceSupplier, deviceModel, osType, osVersion])
  515. if param_flag is True:
  516. addTime = int(time.time())
  517. print(time.time())
  518. add_data = {
  519. 'userID': userID,
  520. 'addTime': addTime,
  521. 'deviceSupplier': deviceSupplier,
  522. 'deviceModel': deviceModel,
  523. 'osType': osType,
  524. 'osVersion': osVersion,
  525. 'country': country,
  526. 'province': province,
  527. 'city': city,
  528. 'area': area,
  529. 'street': street,
  530. 'longitude': longitude,
  531. 'latitude': latitude,
  532. 'appId': appId,
  533. 'status_all': status,
  534. 'ExpirationTime_TTL': addTime + 2592000,
  535. 'ip': self.clientIP
  536. }
  537. # 增加用户扩展信息
  538. redisObj = RedisObject()
  539. add_user_brand_all_data = json.dumps(add_data)
  540. logKey = USER_BRAND_ALL
  541. redisObj.rpush(name=logKey, val=add_user_brand_all_data)
  542. # print (redisObj.llen(name=logKey))
  543. # 判断redis列表长度
  544. try:
  545. if redisObj.llen(name=logKey) > 100:
  546. data_list = redisObj.lrange(logKey, 0, -1)
  547. redisObj.del_data(key=logKey)
  548. # 添加user_brand_all表信息
  549. my.user_brand_all_item_put(user_brand_all, data_list)
  550. # 添加user_brand表信息
  551. my.user_brand_item_put(user_brand, userID, addTime, deviceSupplier, deviceModel,
  552. osType, osVersion,
  553. country, province, city, area, street, longitude, latitude, appId, status,
  554. self.clientIP)
  555. except Exception:
  556. my.table_create(USER_BRAND)
  557. my.user_brand_all_table_create(USER_BRAND_ALL)
  558. return response.json(0, {'OK': int(time.time())})
  559. else:
  560. # 参数错误
  561. return response.json(444)
  562. # 查询每个用户的最新登录数据表
  563. def query_info(self, request_dict, userID, user_brand, user_brand_all, response):
  564. page = int(request_dict.get('page', None))
  565. line = int(request_dict.get('line', None))
  566. username = request_dict.get('username', None)
  567. param_flag = CommonService.get_param_flag(data=[page, line])
  568. if param_flag is True:
  569. check_perm = ModelService.check_perm(userID=userID, permID=30)
  570. page_value = []
  571. if check_perm is True:
  572. if username is None or username is '':
  573. # table_Limit_value = my.get_page_line(page,line,user_brand,None,page_value)
  574. # # 页面减1
  575. # page = page-1
  576. # if page < len(table_Limit_value):
  577. # # 分页后查询
  578. # table_value = my.item_get(line,user_brand,table_Limit_value[page])
  579. # table_value = table_value['Items']
  580. # count = my.item_get_count(user_brand)
  581. # return response.json(0, {'datas': table_value, 'count': count})
  582. return response.json(0, {'datas': {}, 'count': 0})
  583. else:
  584. # 查询
  585. user_ID = Device_User.objects.filter(username=username).values('userID', 'NickName')
  586. try:
  587. username = user_ID[0]['userID']
  588. except Exception:
  589. username = username
  590. table_value = my.get_table_info(user_brand, username)
  591. return response.json(0, {'datas': table_value, 'count': len(table_value)})
  592. else:
  593. return response.json(404)
  594. else:
  595. return response.json(444)
  596. # 删除接口
  597. def delete_by_admin(self, request_dict, userID, user_brand, user_brand_all, response):
  598. id = request_dict.getlist('id', None)
  599. username = request_dict.getlist('username', None)
  600. add_time = request_dict.getlist('add_time', None)
  601. table_name = request_dict.getlist('table_name', None)
  602. param_flag = CommonService.get_param_flag(data=[id, username])
  603. if param_flag is True:
  604. check_perm = ModelService.check_perm(userID=userID, permID=10)
  605. if check_perm is True:
  606. if str(table_name[0]) == 'user_brand':
  607. is_delete = my.item_delete(user_brand, 'user_brand', id[0], add_time[0])
  608. else:
  609. is_delete = my.item_delete(user_brand_all, 'user_brand_all', id[0], add_time[0])
  610. return response.json(0, {'delete_count': is_delete[0]})
  611. else:
  612. return response.json(404)
  613. else:
  614. return response.json(444)
  615. # Query each user record statistics
  616. def query_all_info(self, request_dict, userID, user_brand, user_brand_all, response):
  617. page = int(request_dict.get('page', None))
  618. line = int(request_dict.get('line', None))
  619. username = request_dict.get('username', None)
  620. param_flag = CommonService.get_param_flag(data=[page, line])
  621. # 增加用户扩展信息
  622. try:
  623. redisObj = RedisObject()
  624. logKey = USER_BRAND_ALL
  625. data_list = redisObj.lrange(logKey, 0, -1)
  626. redisObj.del_data(key=logKey)
  627. # 添加user_brand_all表信息
  628. my.user_brand_all_item_put(user_brand_all, data_list)
  629. except Exception:
  630. print ('有误')
  631. print ('添加了数据')
  632. if param_flag is True:
  633. check_perm = ModelService.check_perm(userID=userID, permID=30)
  634. page_value = []
  635. if check_perm is True:
  636. if username is None or username is '':
  637. return response.json(0, {'datas': {}, 'count': 0})
  638. else:
  639. # 查询
  640. user_ID = Device_User.objects.filter(username=username).values('userID', 'NickName')
  641. try:
  642. username = user_ID[0]['userID']
  643. except Exception:
  644. username = username
  645. table_value = my.get_table_info(user_brand_all, username)
  646. return response.json(0, {'datas': table_value, 'count': len(table_value)})
  647. else:
  648. return response.json(404)
  649. else:
  650. return response.json(444)
  651. # Brand statistics interface
  652. def query_deviceSupplier_info(self, request_dict, userID, user_brand, user_brand_all, response):
  653. check_perm = ModelService.check_perm(userID=userID, permID=30)
  654. if check_perm is True:
  655. table_value = my.item_get_brand(user_brand)
  656. send_jsons = []
  657. counts = 0
  658. for i in table_value:
  659. send_jsons.append(table_value[counts]['deviceSupplier'])
  660. counts = counts + 1
  661. send_jsons = Counter(send_jsons)
  662. return response.json(0, {'datas': send_jsons, 'counts': counts})
  663. else:
  664. return response.json(404)
  665. # Interface to area statistics
  666. def query_area_info(self, request_dict, userID, user_brand, user_brand_all, response):
  667. check_perm = ModelService.check_perm(userID=userID, permID=30)
  668. district = request_dict.get('district', None)
  669. if check_perm is True:
  670. # 按照用户去重复查询
  671. table_value = my.item_get_brand(user_brand)
  672. send_jsons = []
  673. counts = 0
  674. for i in table_value:
  675. send_jsons.append(table_value[counts][district])
  676. counts = counts + 1
  677. send_jsons = Counter(send_jsons)
  678. return response.json(0, {'datas': send_jsons, 'counts': counts})
  679. else:
  680. return response.json(404)