UIDController.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import json
  4. import time
  5. from django.http import StreamingHttpResponse
  6. from django.utils.decorators import method_decorator
  7. from django.views import View
  8. from django.views.decorators.csrf import csrf_exempt
  9. from django.db.models import Avg,Max,Min,Count,Sum, Q # 引入函数
  10. from Model.models import UIDModel, UserModel, UserUIDModel, HistoryUIDModel
  11. from Object.RedisObject import RedisObject
  12. from Object.ResponseObject import ResponseObject
  13. from Object.TokenObject import TokenObject
  14. class UIDView(View):
  15. @method_decorator(csrf_exempt)
  16. def dispatch(self, request, *args, **kwargs):
  17. return super(UIDView, self).dispatch(request, *args, **kwargs)
  18. def get(self, request, *args, **kwargs):
  19. request.encoding = 'utf-8'
  20. request_dict = request.GET
  21. operation = kwargs.get('operation')
  22. return self.validate(request_dict, operation)
  23. def post(self, request, *args, **kwargs):
  24. request.encoding = 'utf-8'
  25. request_dict = request.POST
  26. operation = kwargs.get('operation')
  27. return self.validate(request_dict, operation)
  28. def validate(self, request_dict, operation):
  29. token = request_dict.get('token', None)
  30. response = ResponseObject()
  31. token = TokenObject(token)
  32. if token.code != 0:
  33. return response.json(token.code)
  34. if operation == 'quantity':
  35. return self.do_quantity(request_dict, response)
  36. elif operation == 'allot':
  37. return self.do_allot(request_dict, response)
  38. elif operation == 'remove':
  39. return self.do_remove(request_dict, response)
  40. elif operation == 'download':
  41. return self.download_txt(token, response)
  42. elif operation == 'download_1':
  43. return self.download_txt_two(token, response)
  44. else:
  45. return response.json(309)
  46. # 查询当前可用的UID的数量
  47. def do_quantity(self, request_dict, response):
  48. token = request_dict.get('token', None)
  49. token = TokenObject(token)
  50. if token.code != 0:
  51. return response.json(token.code)
  52. user_qs = UserModel.objects.filter(id=token.userID)
  53. if user_qs.exists():
  54. user = user_qs[0]
  55. if user.permission == '0':
  56. return self.do_admin_quantity(request_dict, response, user.username)
  57. else:
  58. return self.do_not_admin_quantity(request_dict, response, user.username)
  59. else:
  60. return response.json(9)
  61. # 管理员的查询UID数量操作
  62. def do_admin_quantity(self, request_dict, response, admin):
  63. datas = []
  64. domestic = UIDModel.objects.filter(area=0, status=0).count()
  65. foreign = UIDModel.objects.filter(area=1, status=0).count()
  66. item = {}
  67. item['isAdmin'] = 1
  68. item['domestic'] = domestic
  69. item['foreign'] = foreign
  70. item['username'] = admin
  71. datas.append(item)
  72. user_qs = UserModel.objects.filter(~Q(Q(permission='0')))
  73. for user in user_qs:
  74. item = {'isAdmin': 0}
  75. result = UserUIDModel.objects.filter(user__id=user.id, uid__status=1, uid__area=0).aggregate(num=Count('uid__status'))
  76. item['domestic'] = result['num']
  77. result = UserUIDModel.objects.filter(user__id=user.id, uid__status=1, uid__area=1).aggregate(num=Count('uid__status'))
  78. item['foreign'] = result['num']
  79. item['username'] = user.username
  80. datas.append(item)
  81. return response.json(0, {'data': datas})
  82. # 非管理员的查询UID数量操作
  83. def do_not_admin_quantity(self, request_dict, response, username):
  84. user_qs = UserModel.objects.filter(username=username)
  85. if user_qs.exists():
  86. user = user_qs[0]
  87. datas = []
  88. item = {'isAdmin': 0}
  89. result = UserUIDModel.objects.filter(user__id=user.id, uid__status=1, uid__area=0).aggregate(num=Count('uid__status'))
  90. item['domestic'] = result['num']
  91. result = UserUIDModel.objects.filter(user__id=user.id, uid__status=1, uid__area=1).aggregate(num=Count('uid__status'))
  92. item['foreign'] = result['num']
  93. item['username'] = user.username
  94. datas.append(item)
  95. return response.json(0, {'data': datas})
  96. else:
  97. return response.json(444)
  98. # 分配UID
  99. def do_allot(self, request_dict, response):
  100. username = request_dict.get('username', None)
  101. quantity = int(request_dict.get('quantity', None))
  102. area = request_dict.get('area', None)
  103. token = request_dict.get('token', None)
  104. token = TokenObject(token)
  105. if token.code != 0:
  106. return response.json(token.code)
  107. user = UserModel.objects.get(id=token.userID)
  108. if not user or '0' not in user.permission:
  109. return response.json(404)
  110. # 要分配的对象
  111. allot_user_qs = UserModel.objects.filter(username=username)
  112. if not allot_user_qs.exists():
  113. return response.json(444, 'username')
  114. # 取出对应区域可用的UID分配给allot_user
  115. uid_qs = UIDModel.objects.filter(area=area, status=0)
  116. count = uid_qs.count()
  117. if count < quantity:
  118. return response.json(444, '设备UID不足')
  119. updates = []
  120. datas = []
  121. if uid_qs.exists():
  122. uid_qs = uid_qs[0:quantity]
  123. now_time = int(time.time())
  124. for item in uid_qs:
  125. item.status = 1
  126. item.update_time = time.time()
  127. user_uid = UserUIDModel()
  128. user_uid.uid = item
  129. user_uid.user = allot_user_qs[0]
  130. user_uid.add_time = now_time
  131. user_uid.update_time = now_time
  132. datas.append(user_uid)
  133. updates.append(item)
  134. if len(datas) % 5000 == 0:
  135. UserUIDModel.objects.bulk_create(datas)
  136. UIDModel.objects.bulk_update(updates, fields=['status', 'update_time'])
  137. datas.clear()
  138. updates.clear()
  139. if len(datas) > 0:
  140. UserUIDModel.objects.bulk_create(datas)
  141. UIDModel.objects.bulk_update(updates, fields=['status', 'update_time'])
  142. datas.clear()
  143. updates.clear()
  144. redisObject = RedisObject()
  145. values = uid_qs.values('uid')
  146. print(values)
  147. redisObject.set_data(key=token.token, val=json.dumps(list(values)), expire=3600)
  148. del datas
  149. del updates
  150. return response.json(0)
  151. else:
  152. return response.json(444)
  153. # 把UID表中的数据移动到HistoryUID表中
  154. def do_remove(self, request_dict, response):
  155. token = TokenObject(request_dict.get('token', None))
  156. id = request_dict.get('id', None)
  157. start = request_dict.get('start', None)
  158. stop = request_dict.get('stop', None)
  159. if token.code != 0:
  160. return response.json(token.code)
  161. # 通过userID查找用户,判断是否是管理员
  162. user_qs = UserModel.objects.filter(id=token.userID)
  163. if user_qs.exists():
  164. user = user_qs[0]
  165. if user.permission != '0':
  166. return response.json(404)
  167. else:
  168. return response.json(9)
  169. if id:
  170. return self.do_remove_by_id(id, response)
  171. elif start and stop:
  172. return self.do_bulk_remove(int(start), int(stop), response)
  173. else:
  174. return response.json(444, 'id,start,stop')
  175. # 移除单条UID记录,id:记录id
  176. def do_remove_by_id(self, id, response):
  177. id = int(id)
  178. uid_qs = UIDModel.objects.filter(id=id)
  179. if not uid_qs.exists():
  180. return response.json(173)
  181. uid = uid_qs[0]
  182. if uid:
  183. data = {
  184. 'uid': uid.uid,
  185. 'uid_extra': uid.uid_extra,
  186. 'status': uid.status,
  187. 'add_time': uid.add_time,
  188. 'update_time': uid.update_time,
  189. 'area': uid.area
  190. }
  191. HistoryUIDModel.objects.create(**data)
  192. uid.delete()
  193. return response.json(0)
  194. else:
  195. return response.json(444, 'id')
  196. # 批量移除UID记录。start:开始的UID记录的id;stop:结束的UID记录的id
  197. def do_bulk_remove(self, start, stop, response):
  198. uid_qs = UIDModel.objects.filter(id__range=(start, stop))
  199. histories = []
  200. if uid_qs.exists():
  201. for item in uid_qs:
  202. histories.append(HistoryUIDModel(
  203. uid=item.uid,
  204. uid_extra=item.uid_extra,
  205. status=item.status,
  206. add_time=item.add_time,
  207. update_time=item.update_time,
  208. area=item.area
  209. ))
  210. if len(histories) % 5000 == 0:
  211. HistoryUIDModel.objects.bulk_create(histories)
  212. histories.clear()
  213. if len(histories) > 0:
  214. HistoryUIDModel.objects.bulk_create(histories)
  215. histories.clear()
  216. uid_qs.delete()
  217. return response.json(0)
  218. else:
  219. return response.json(173)
  220. def download_txt(self, token, response):
  221. redisObject = RedisObject()
  222. uid_qs = redisObject.get_data(key=token.token)
  223. if uid_qs is False:
  224. return response.json(308)
  225. uid_qs = json.loads(uid_qs)
  226. content = ''
  227. for item in uid_qs:
  228. # print(item)
  229. content += item['uid']
  230. content += '\r\n'
  231. redisObject.del_data(key=token.token)
  232. content = content[0:len(content) - 1]
  233. response = StreamingHttpResponse(content)
  234. response['Content-Type'] = 'application/octet-stream'
  235. filename = 'uid_need_to_set_up_push.txt'
  236. response['Content-Disposition'] = 'attachment;filename=' + filename
  237. return response
  238. def download_txt_two(self, token, response):
  239. uid_qs = UIDModel.objects.filter(status=1)
  240. if not uid_qs.exists():
  241. return response.json(308)
  242. uid_qs = uid_qs.values()
  243. content = ''
  244. for item in uid_qs:
  245. # print(item)
  246. content += item['uid']
  247. content += '\r\n'
  248. content = content[0:len(content) - 1]
  249. response = StreamingHttpResponse(content)
  250. response['Content-Type'] = 'application/octet-stream'
  251. filename = 'uid_need_to_set_up_push.txt'
  252. response['Content-Disposition'] = 'attachment;filename=' + filename
  253. return response