SerialNumberController.py 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  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, CompanySerialModel
  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. response = ResponseObject()
  30. if operation == 'create':
  31. return self.do_create(request_dict, response)
  32. elif operation == 'getSerial':
  33. return self.do_get_serial_number(request_dict, response)
  34. token = request_dict.get('token', None)
  35. token = TokenObject(token)
  36. if token.code != 0:
  37. return response.json(token.code)
  38. if operation == 'quantity':
  39. return self.do_quantity(request_dict,token.userID, response)
  40. elif operation == 'allot':
  41. return self.do_allot(request_dict, response)
  42. else:
  43. return response.json(309)
  44. # 查询当前可用的UID的数量
  45. def do_quantity(self, request_dict, userID, response):
  46. user_qs = UserModel.objects.filter(id=userID)
  47. if not user_qs.exists():
  48. return response.json(9)
  49. user = user_qs[0]
  50. chenyunsuper = SerialNumberModel.objects.filter(p2p=1).count()
  51. tutksuper = SerialNumberModel.objects.filter(p2p=2).count()
  52. result = UserSerialNumberModel.objects.filter(user__id=user.id, serial_number__p2p=1, serial_number__use_status=1).aggregate(num=Count('serial_number__use_status'))
  53. chenyundev = result['num']
  54. result2 = UserSerialNumberModel.objects.filter(user__id=user.id, serial_number__p2p=2, serial_number__use_status=1).aggregate(num=Count('serial_number__use_status'))
  55. tutkdev = result2['num']
  56. chenyun = SerialNumberModel.objects.filter(use_status=1, p2p=1).count()
  57. tutk = SerialNumberModel.objects.filter(use_status=1, p2p=2).count()
  58. res_data = {'code': 0, 'chenyun': chenyun, 'tutk': tutk, 'chenyunsuper': chenyunsuper, 'tutksuper': tutksuper, 'chenyundev': chenyundev, 'tutkdev': tutkdev}
  59. return response.json(0, {'data': res_data})
  60. def do_create(self, request_dict, response):
  61. quantity = int(request_dict.get('quantity', 0))
  62. p2p = int(request_dict.get('p2p', 0))
  63. if not quantity:
  64. return response.json(444)
  65. try:
  66. try:
  67. sum = SerialNumberModel.objects.last().id
  68. except:
  69. sum = 0
  70. serial_number_bulk = []
  71. now_time = int(time.time())
  72. algorithm = AlgorithmBaseOn35()
  73. for i in range(quantity):
  74. serial_number = algorithm.getLetter(sum)
  75. sum += 1 # sum每次递增1
  76. # 前面补0至六位
  77. serial_number = (6-len(serial_number))*'0' + serial_number
  78. serial_number_bulk.append(SerialNumberModel(serial_number=serial_number, add_time=now_time, p2p=p2p))
  79. # 开启事务写入
  80. with transaction.atomic():
  81. SerialNumberModel.objects.bulk_create(serial_number_bulk)
  82. return response.json(0)
  83. except Exception as e:
  84. print(e)
  85. return response.json(500, repr(e))
  86. # 分配序列号
  87. @transaction.atomic
  88. def do_allot(self, request_dict, response):
  89. username = request_dict.get('username', None)
  90. quantity = int(request_dict.get('quantity', None))
  91. area = request_dict.get('area', None)
  92. token = request_dict.get('token', None)
  93. token = TokenObject(token)
  94. if token.code != 0:
  95. return response.json(token.code)
  96. user = UserModel.objects.get(id=token.userID)
  97. if not user or '0' not in user.permission:
  98. return response.json(404)
  99. # 要分配的对象
  100. allot_user_qs = UserModel.objects.filter(username=username)
  101. if not allot_user_qs.exists():
  102. return response.json(444, 'username')
  103. # 取出对应区域可用的UID分配给allot_user
  104. sn_qs = SerialNumberModel.objects.filter(p2p=area, use_status=0)[0:quantity]
  105. sns = []
  106. for sn in sn_qs:
  107. sns.append(sn.serial_number)
  108. cs_qs = CompanySerialModel.objects.filter(serial_number__in=sns, status=1)
  109. sns = []
  110. for cs in cs_qs:
  111. sns.append(cs.serial_number)
  112. sn_qs = SerialNumberModel.objects.filter(serial_number__in=sns)
  113. count = sn_qs.count()
  114. if count < quantity:
  115. return response.json(444, '序列号不足')
  116. updates = []
  117. datas = []
  118. count = 0
  119. if sn_qs.exists():
  120. sn_qs = sn_qs[0:quantity]
  121. now_time = int(time.time())
  122. for i in range(len(sn_qs)):
  123. item = sn_qs[i]
  124. serialNumberModel = SerialNumberModel(
  125. id=item.id,
  126. serial_number=item.serial_number,
  127. status=item.status,
  128. use_status=1,
  129. p2p=item.p2p,
  130. add_time=item.add_time
  131. )
  132. user_serial_number = UserSerialNumberModel()
  133. user_serial_number.serial_number = serialNumberModel
  134. user_serial_number.user = allot_user_qs[0]
  135. user_serial_number.add_time = now_time
  136. user_serial_number.update_time = now_time
  137. datas.append(user_serial_number)
  138. updates.append(serialNumberModel)
  139. if len(updates) % 5000 == 0:
  140. bulk_update(updates)
  141. UserSerialNumberModel.objects.bulk_create(datas)
  142. if len(updates) > 0:
  143. bulk_update(updates)
  144. UserSerialNumberModel.objects.bulk_create(datas)
  145. del datas
  146. del updates
  147. return response.json(0)
  148. else:
  149. return response.json(444)
  150. # 提供给pc端获取序列号
  151. def do_get_serial_number(self, request_dict, response):
  152. quantity = 1 #只能取一个
  153. company_id = request_dict.get('company_id', None)
  154. token = request_dict.get('token', None)
  155. time_stamp = request_dict.get('time_stamp', None)
  156. p2p_type = request_dict.get('p2p_type', None)
  157. mac = request_dict.get('mac', None)
  158. if token and time_stamp and quantity and company_id:
  159. token = int(CommonService.decode_data(token))
  160. time_stamp = int(time_stamp)
  161. now_time = int(time.time())
  162. distance = now_time - time_stamp
  163. if token != time_stamp or distance > 60000 or distance < -60000: # 为了全球化时间控制在一天内
  164. return response.json(404)
  165. redisObject = RedisObject()
  166. key = 'serial_lock'
  167. value = redisObject.lpop(key)
  168. count = 0
  169. while value is False and count < 5:
  170. time.sleep(1)
  171. value = redisObject.lpop(key)
  172. count += 1
  173. if count == 5 and value is False: # 暂时注释
  174. return response.json(5)
  175. company_serial_qs = CompanySerialModel.objects.filter(company__secret=company_id, status=0,
  176. p2p=p2p_type)
  177. if not company_serial_qs.exists():
  178. redisObject.rpush(key, value)
  179. return response.json(373)
  180. # 存在对应的企业
  181. company_serial_qs = company_serial_qs[0:quantity]
  182. # company_serial_qs = company_serial_qs.values('id', 'serial_number__serial_number', 'company__mark')
  183. save_point = transaction.savepoint() # 设置事务保存点
  184. try:
  185. ids = []
  186. for serial in company_serial_qs:
  187. ids.append(serial.id)
  188. SerialNumberModel.objects.filter(serial_number=serial.serial_number).update(use_status=2)
  189. CompanySerialModel.objects.filter(id__in=ids).update(status=1)
  190. except Exception as e:
  191. if save_point:
  192. transaction.savepoint_rollback(save_point) # 事务回滚
  193. redisObject.rpush(key, value)
  194. return response.json(0, {'serial_number': company_serial_qs[0].serial_number + company_serial_qs[0].company.mark, 'mac': mac})
  195. else:
  196. return response.json(444)