UserBrandController.py 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732
  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. deviceSupplier = request_dict.get('deviceSupplier', None)
  461. deviceModel = request_dict.get('deviceModel', None)
  462. osType = request_dict.get('osType', None)
  463. osVersion = request_dict.get('osVersion', None)
  464. country = request_dict.get('country', None)
  465. province = request_dict.get('province', None)
  466. city = request_dict.get('city', '')
  467. area = request_dict.get('area', '')
  468. street = request_dict.get('street', '')
  469. longitude = request_dict.get('longitude', '')
  470. latitude = request_dict.get('latitude', '')
  471. appId = request_dict.get('appId', None)
  472. if city == '':
  473. city = '无'
  474. if area == '':
  475. area = '无'
  476. if street == '':
  477. street = '无'
  478. if longitude == '':
  479. longitude = '无'
  480. if latitude == '':
  481. latitude = '无'
  482. param_area = CommonService.get_param_flag(data=[country, province, city])
  483. must_fill_in = CommonService.get_param_flag(data=[appId, deviceSupplier, deviceModel, osType, osVersion])
  484. if must_fill_in is False:
  485. return response.json(444, 'appId,deviceSupplier,deviceModel,osType,osVersion')
  486. if param_area is True:
  487. if '省' in province:
  488. province = province.replace('省', '')
  489. if '市' in city:
  490. city = city.replace('市', '')
  491. status = 1
  492. country = country
  493. province = province
  494. city = city
  495. area = area
  496. street = street
  497. longitude = longitude
  498. latitude = latitude
  499. else:
  500. status = 0
  501. jsonData = CommonService.getIpIpInfo(ip=self.clientIP, lang='CN')
  502. country = jsonData['country_name']
  503. province = jsonData['region_name']
  504. city = jsonData['city_name']
  505. area = '无'
  506. street = '无'
  507. longitude = jsonData['longitude']
  508. latitude = jsonData['latitude']
  509. if country == '局域网':
  510. city = '无'
  511. longitude = '无'
  512. latitude = '无'
  513. param_flag = CommonService.get_param_flag(data=[deviceSupplier, deviceModel, osType, osVersion])
  514. if param_flag is True:
  515. addTime = int(time.time())
  516. print(time.time())
  517. add_data = {
  518. 'userID': userID,
  519. 'addTime': addTime,
  520. 'deviceSupplier': deviceSupplier,
  521. 'deviceModel': deviceModel,
  522. 'osType': osType,
  523. 'osVersion': osVersion,
  524. 'country': country,
  525. 'province': province,
  526. 'city': city,
  527. 'area': area,
  528. 'street': street,
  529. 'longitude': longitude,
  530. 'latitude': latitude,
  531. 'appId': appId,
  532. 'status_all': status,
  533. 'ExpirationTime_TTL': addTime + 2592000,
  534. 'ip': self.clientIP
  535. }
  536. # 增加用户扩展信息
  537. redisObj = RedisObject()
  538. add_user_brand_all_data = json.dumps(add_data)
  539. logKey = USER_BRAND_ALL
  540. redisObj.rpush(name=logKey, val=add_user_brand_all_data)
  541. # print (redisObj.llen(name=logKey))
  542. # 判断redis列表长度
  543. try:
  544. if redisObj.llen(name=logKey) > 100:
  545. data_list = redisObj.lrange(logKey, 0, -1)
  546. redisObj.del_data(key=logKey)
  547. # 添加user_brand_all表信息
  548. my.user_brand_all_item_put(user_brand_all, data_list)
  549. # 添加user_brand表信息
  550. my.user_brand_item_put(user_brand, userID, addTime, deviceSupplier, deviceModel,
  551. osType, osVersion,
  552. country, province, city, area, street, longitude, latitude, appId, status,
  553. self.clientIP)
  554. except Exception:
  555. my.table_create(USER_BRAND)
  556. my.user_brand_all_table_create(USER_BRAND_ALL)
  557. return response.json(0, {'OK': int(time.time())})
  558. else:
  559. # 参数错误
  560. return response.json(444)
  561. # 查询每个用户的最新登录数据表
  562. def query_info(self, request_dict, userID, user_brand, user_brand_all, response):
  563. page = int(request_dict.get('page', None))
  564. line = int(request_dict.get('line', None))
  565. username = request_dict.get('username', None)
  566. param_flag = CommonService.get_param_flag(data=[page, line])
  567. if param_flag is True:
  568. check_perm = ModelService.check_perm(userID=userID, permID=30)
  569. page_value = []
  570. if check_perm is True:
  571. if username is None or username is '':
  572. # table_Limit_value = my.get_page_line(page,line,user_brand,None,page_value)
  573. # # 页面减1
  574. # page = page-1
  575. # if page < len(table_Limit_value):
  576. # # 分页后查询
  577. # table_value = my.item_get(line,user_brand,table_Limit_value[page])
  578. # table_value = table_value['Items']
  579. # count = my.item_get_count(user_brand)
  580. # return response.json(0, {'datas': table_value, 'count': count})
  581. return response.json(0, {'datas': {}, 'count': 0})
  582. else:
  583. # 查询
  584. user_ID = Device_User.objects.filter(username=username).values('userID', 'NickName')
  585. try:
  586. username = user_ID[0]['userID']
  587. except Exception:
  588. username = username
  589. table_value = my.get_table_info(user_brand, username)
  590. return response.json(0, {'datas': table_value, 'count': len(table_value)})
  591. else:
  592. return response.json(404)
  593. else:
  594. return response.json(444)
  595. # 删除接口
  596. def delete_by_admin(self, request_dict, userID, user_brand, user_brand_all, response):
  597. id = request_dict.getlist('id', None)
  598. username = request_dict.getlist('username', None)
  599. add_time = request_dict.getlist('add_time', None)
  600. table_name = request_dict.getlist('table_name', None)
  601. param_flag = CommonService.get_param_flag(data=[id, username])
  602. if param_flag is True:
  603. check_perm = ModelService.check_perm(userID=userID, permID=10)
  604. if check_perm is True:
  605. if str(table_name[0]) == 'user_brand':
  606. is_delete = my.item_delete(user_brand, 'user_brand', id[0], add_time[0])
  607. else:
  608. is_delete = my.item_delete(user_brand_all, 'user_brand_all', id[0], add_time[0])
  609. return response.json(0, {'delete_count': is_delete[0]})
  610. else:
  611. return response.json(404)
  612. else:
  613. return response.json(444)
  614. # Query each user record statistics
  615. def query_all_info(self, request_dict, userID, user_brand, user_brand_all, response):
  616. page = int(request_dict.get('page', None))
  617. line = int(request_dict.get('line', None))
  618. username = request_dict.get('username', None)
  619. param_flag = CommonService.get_param_flag(data=[page, line])
  620. # 增加用户扩展信息
  621. try:
  622. redisObj = RedisObject()
  623. logKey = USER_BRAND_ALL
  624. data_list = redisObj.lrange(logKey, 0, -1)
  625. redisObj.del_data(key=logKey)
  626. # 添加user_brand_all表信息
  627. my.user_brand_all_item_put(user_brand_all, data_list)
  628. except Exception:
  629. print ('有误')
  630. print ('添加了数据')
  631. if param_flag is True:
  632. check_perm = ModelService.check_perm(userID=userID, permID=30)
  633. page_value = []
  634. if check_perm is True:
  635. if username is None or username is '':
  636. return response.json(0, {'datas': {}, 'count': 0})
  637. else:
  638. # 查询
  639. user_ID = Device_User.objects.filter(username=username).values('userID', 'NickName')
  640. try:
  641. username = user_ID[0]['userID']
  642. except Exception:
  643. username = username
  644. table_value = my.get_table_info(user_brand_all, username)
  645. return response.json(0, {'datas': table_value, 'count': len(table_value)})
  646. else:
  647. return response.json(404)
  648. else:
  649. return response.json(444)
  650. # Brand statistics interface
  651. def query_deviceSupplier_info(self, request_dict, userID, user_brand, user_brand_all, response):
  652. check_perm = ModelService.check_perm(userID=userID, permID=30)
  653. if check_perm is True:
  654. table_value = my.item_get_brand(user_brand)
  655. send_jsons = []
  656. counts = 0
  657. for i in table_value:
  658. send_jsons.append(table_value[counts]['deviceSupplier'])
  659. counts = counts + 1
  660. send_jsons = Counter(send_jsons)
  661. return response.json(0, {'datas': send_jsons, 'counts': counts})
  662. else:
  663. return response.json(404)
  664. # Interface to area statistics
  665. def query_area_info(self, request_dict, userID, user_brand, user_brand_all, response):
  666. check_perm = ModelService.check_perm(userID=userID, permID=30)
  667. district = request_dict.get('district', None)
  668. if check_perm is True:
  669. # 按照用户去重复查询
  670. table_value = my.item_get_brand(user_brand)
  671. send_jsons = []
  672. counts = 0
  673. for i in table_value:
  674. send_jsons.append(table_value[counts][district])
  675. counts = counts + 1
  676. send_jsons = Counter(send_jsons)
  677. return response.json(0, {'datas': send_jsons, 'counts': counts})
  678. else:
  679. return response.json(404)