SerialNumberController.py 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import logging
  4. import random
  5. import time
  6. from bulk_update.helper import bulk_update
  7. from django.db import transaction
  8. from django.db.models import Count
  9. from django.views import View
  10. from Model.models import SerialNumberModel, UserModel, UserSerialNumberModel, UserUIDModel
  11. from Object.RedisObject import RedisObject
  12. from Object.ResponseObject import ResponseObject
  13. from Object.TokenObject import TokenObject
  14. from Service.AlgorithmService import AlgorithmBaseOn35
  15. from Service.CommonService import CommonService
  16. from Service.ModelService import ModelService
  17. class SerialNumberView(View):
  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,token.userID, response)
  36. elif operation == 'create':
  37. return self.do_create(request_dict, response)
  38. elif operation == 'allot':
  39. return self.do_allot(request_dict, response)
  40. else:
  41. return response.json(309)
  42. # 查询当前可用的UID的数量
  43. def do_quantity(self, request_dict, userID, response):
  44. user_qs = UserModel.objects.filter(id=userID)
  45. if not user_qs.exists():
  46. return response.json(9)
  47. user = user_qs[0]
  48. chenyunsuper = SerialNumberModel.objects.filter(p2p=1).count()
  49. tutksuper = SerialNumberModel.objects.filter(p2p=2).count()
  50. result = UserSerialNumberModel.objects.filter(user__id=user.id, serial_number__p2p= 1, serial_number__use_status=1).aggregate(num=Count('serial_number__use_status'))
  51. chenyundev = result['num']
  52. result2 = UserSerialNumberModel.objects.filter(user__id=user.id, serial_number__p2p=2,serial_number__use_status=1).aggregate(num=Count('serial_number__use_status'))
  53. tutkdev = result2['num']
  54. chenyun = SerialNumberModel.objects.filter(use_status=1 , p2p=1).count()
  55. tutk = SerialNumberModel.objects.filter(use_status=1, p2p=2).count()
  56. res_data = {'code': 0, 'chenyun': chenyun, 'tutk': tutk, 'chenyunsuper': chenyunsuper, 'tutksuper': tutksuper, 'chenyundev': chenyundev, 'tutkdev': tutkdev}
  57. return response.json(0, {'data': res_data})
  58. def do_create(self, request_dict, response):
  59. quantity = int(request_dict.get('quantity', 0))
  60. p2p = int(request_dict.get('p2p', 0))
  61. if not quantity:
  62. return response.json(444)
  63. try:
  64. try:
  65. sum = SerialNumberModel.objects.last().id
  66. except:
  67. sum = 0
  68. serial_number_bulk = []
  69. now_time = int(time.time())
  70. algorithm = AlgorithmBaseOn35()
  71. for i in range(quantity):
  72. serial_number = algorithm.getLetter(sum)
  73. sum += 1 # sum每次递增1
  74. # 前面补0至六位
  75. serial_number = (6-len(serial_number))*'0' + serial_number
  76. serial_number_bulk.append(SerialNumberModel(serial_number=serial_number, add_time=now_time, p2p=p2p))
  77. # 开启事务写入
  78. with transaction.atomic():
  79. SerialNumberModel.objects.bulk_create(serial_number_bulk)
  80. return response.json(0)
  81. except Exception as e:
  82. print(e)
  83. return response.json(500, repr(e))
  84. # 分配序列号
  85. @transaction.atomic
  86. def do_allot(self, request_dict, response):
  87. username = request_dict.get('username', None)
  88. quantity = int(request_dict.get('quantity', None))
  89. area = request_dict.get('area', None)
  90. token = request_dict.get('token', None)
  91. token = TokenObject(token)
  92. if token.code != 0:
  93. return response.json(token.code)
  94. user = UserModel.objects.get(id=token.userID)
  95. if not user or '0' not in user.permission:
  96. return response.json(404)
  97. # 要分配的对象
  98. allot_user_qs = UserModel.objects.filter(username=username)
  99. if not allot_user_qs.exists():
  100. return response.json(444, 'username')
  101. # 取出对应区域可用的UID分配给allot_user
  102. sn_qs = SerialNumberModel.objects.filter(p2p=area, use_status=0)
  103. count = sn_qs.count()
  104. if count < quantity:
  105. return response.json(444, '序列号不足')
  106. updates = []
  107. datas = []
  108. count = 0
  109. if sn_qs.exists():
  110. sn_qs = sn_qs[0:quantity]
  111. now_time = int(time.time())
  112. for i in range(len(sn_qs)):
  113. item = sn_qs[i]
  114. serialNumberModel = SerialNumberModel(
  115. id=item.id,
  116. serial_number=item.serial_number,
  117. status=item.status,
  118. use_status=1,
  119. p2p=item.p2p,
  120. add_time=item.add_time
  121. )
  122. user_serial_number = UserSerialNumberModel()
  123. user_serial_number.serial_number = serialNumberModel
  124. user_serial_number.user = allot_user_qs[0]
  125. user_serial_number.add_time = now_time
  126. user_serial_number.update_time = now_time
  127. datas.append(user_serial_number)
  128. updates.append(serialNumberModel)
  129. if len(updates) % 5000 == 0:
  130. bulk_update(updates)
  131. UserSerialNumberModel.objects.bulk_create(datas)
  132. if len(updates) > 0:
  133. bulk_update(updates)
  134. UserSerialNumberModel.objects.bulk_create(datas)
  135. del datas
  136. del updates
  137. return response.json(0)
  138. else:
  139. return response.json(444)