SerialNumberController.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import logging
  4. import random
  5. import time
  6. from django.db import transaction
  7. from django.views import View
  8. from Model.models import SerialNumberModel, CompanySerialModel, UIDCompanySerialModel, CompanyModel, RegionModel, \
  9. CountryModel, UIDModel
  10. from Object.RedisObject import RedisObject
  11. from Object.uidManageResponseObject import uidManageResponseObject
  12. from Object.TokenObject import TokenObject
  13. from Service.AlgorithmService import AlgorithmBaseOn35
  14. from Service.CommonService import CommonService
  15. from Service.ModelService import ModelService
  16. class SerialNumberView(View):
  17. def get(self, request, *args, **kwargs):
  18. request.encoding = 'utf-8'
  19. operation = kwargs.get('operation', None)
  20. request_dict = request.GET
  21. return self.validate(request_dict, operation)
  22. def post(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. operation = kwargs.get('operation', None)
  25. request_dict = request.POST
  26. return self.validate(request_dict, operation)
  27. def validate(self, request_dict, operation):
  28. token = TokenObject(request_dict.get('token', None))
  29. response = uidManageResponseObject()
  30. if operation == 'getUID':
  31. return self.do_get_uid(request_dict, response)
  32. elif operation == 'getSerial':
  33. return self.do_get_serial_number(request_dict, response)
  34. else:
  35. if token.code != 0:
  36. return response.json(token.code)
  37. if operation == 'create':
  38. return self.do_create(request_dict, response)
  39. elif operation == 'list':
  40. return self.do_list(token.userID, request_dict, response)
  41. elif operation == 'update':
  42. return self.do_update(token.userID, request_dict, response)
  43. elif operation == 'attachUID':
  44. return self.do_attach_uid(request_dict, response)
  45. elif operation == 'detachUID':
  46. return self.do_detach_uid(token.userID, request_dict, response)
  47. else:
  48. return response.json(404)
  49. def do_create(self, request_dict, response):
  50. quantity = request_dict.get('quantity', None)
  51. if quantity:
  52. start_time = time.strftime('%Y-%m-%d %H:%M:%S')
  53. print('start create ' + start_time)
  54. quantity = int(quantity)
  55. tmp = []
  56. algorithm = AlgorithmBaseOn35()
  57. sum = SerialNumberModel.objects.count()
  58. for i in range(quantity):
  59. serial_number = algorithm.getLetter(sum)
  60. tmp_len = 6 - len(serial_number)
  61. # 前面补0
  62. for j in range(tmp_len):
  63. serial_number = '0' + serial_number
  64. tmp.append(serial_number)
  65. sum += 1
  66. # 把序列号的顺序打乱
  67. random.shuffle(tmp)
  68. data = []
  69. now_time = int(time.time())
  70. for item in tmp:
  71. data.append(SerialNumberModel(serial_number=item, add_time=now_time))
  72. if len(data) == 10000:
  73. SerialNumberModel.objects.bulk_create(data)
  74. data.clear()
  75. if len(data) > 0:
  76. SerialNumberModel.objects.bulk_create(data)
  77. data.clear()
  78. start_time = time.strftime('%Y-%m-%d %H:%M:%S')
  79. print('start create ' + start_time)
  80. redis = RedisObject()
  81. redis.del_data(key='serial_number_count')
  82. return response.json(0)
  83. else:
  84. return response.json(444)
  85. # 提供给pc端获取序列号
  86. def do_get_serial_number(self, request_dict, response):
  87. quantity = request_dict.get('quantity', None)
  88. company_id = request_dict.get('company_id', None)
  89. token = request_dict.get('token', None)
  90. time_stamp = request_dict.get('time_stamp', None)
  91. if token and time_stamp and quantity and company_id:
  92. token = int(CommonService.decode_data(token))
  93. time_stamp = int(time_stamp)
  94. now_time = int(time.time())
  95. distance = now_time - time_stamp
  96. if token != time_stamp or distance > 300 or distance < 0:
  97. return response.json(404)
  98. redisObject = RedisObject()
  99. key = 'serial_lock'
  100. value = redisObject.lpop(key)
  101. count = 0
  102. while value is False and count < 5:
  103. time.sleep(1)
  104. value = redisObject.lpop(key)
  105. count += 1
  106. if count == 5 and value is False:
  107. return response.json(5)
  108. quantity = int(quantity)
  109. company_serial_qs = CompanySerialModel.objects.filter(company__secret=company_id, status=0)
  110. if not company_serial_qs.exists():
  111. redisObject.rpush(key, value)
  112. return response.json(373)
  113. # 存在对应的企业
  114. company_serial_qs = company_serial_qs[0:quantity]
  115. company_serial_qs = company_serial_qs.values('id', 'serial_number__serial_number', 'company__mark')
  116. data = []
  117. ids = []
  118. for serial in company_serial_qs:
  119. ids.append(serial['id'])
  120. data.append(serial['serial_number__serial_number'] + serial['company__mark'])
  121. CompanySerialModel.objects.filter(id__in=ids).update(status=1)
  122. redisObject.rpush(key, value)
  123. return response.json(0, data)
  124. else:
  125. return response.json(444)
  126. def do_list(self, userID, request_dict, response):
  127. perm = ModelService.check_perm_uid_manage(userID, 0)
  128. if not perm:
  129. return response.json(309)
  130. page = request_dict.get('page', None)
  131. line = request_dict.get('limit', None)
  132. serial_number = request_dict.get('serial_number', None)
  133. status = request_dict.get('status', None)
  134. if page and line:
  135. page = int(page)
  136. line = int(line)
  137. serial_qs = SerialNumberModel.objects.filter()
  138. if serial_number:
  139. serial_qs = serial_qs.filter(serial_number__contains=serial_number)
  140. if status:
  141. serial_qs = serial_qs.filter(status=status)
  142. count = serial_qs.count()
  143. start = (page - 1) * line
  144. end = start + line
  145. serial_qs = serial_qs[start: end].values()
  146. res = {
  147. 'count': count,
  148. 'data': list(serial_qs)
  149. }
  150. return response.json(0, res)
  151. else:
  152. return response.json(444)
  153. @transaction.atomic
  154. def do_attach_uid(self, request_dict, response):
  155. serial_number = request_dict.get('serial_number', None)
  156. country_id = request_dict.get('country_id', None)
  157. company_id = request_dict.get('company_id', None)
  158. if serial_number and len(serial_number) == 9 and country_id and company_id:
  159. mark = serial_number[6:9]
  160. serial = serial_number[0:6]
  161. savePoint = transaction.savepoint()
  162. try:
  163. try:
  164. # 判断序列号是否已和UID关联
  165. company_serial_qs = CompanySerialModel.objects.filter(company__secret=company_id,
  166. serial_number__serial_number=serial)
  167. if not company_serial_qs.exists():
  168. return response.json(173)
  169. # 当序列号已关联UID
  170. company_serial = company_serial_qs[0]
  171. if company_serial.status == 0:
  172. # 该序列号未绑定企业
  173. return response.json(173)
  174. elif company_serial.status == 1:
  175. # 确定所在区域
  176. country_qs = CountryModel.objects.filter(number=country_id)
  177. if not country_qs.exists():
  178. return response.json(374)
  179. region = country_qs.values('region_id')[0]
  180. count = 0
  181. while count < 3:
  182. uid_qs = UIDModel.objects.filter(vpg__company_id=company_serial.company.id, vpg__region_id=region['region_id'],
  183. status=0)
  184. if uid_qs.exists():
  185. uid = uid_qs[0]
  186. print(uid)
  187. # uid.status = 2
  188. # uid.update_time = int(time.time())
  189. result = UIDModel.objects.filter(id=uid.id, status=0).update(**{
  190. 'status': 2, 'update_time': int(time.time())
  191. })
  192. if int(result) <= 0:
  193. count += 1
  194. continue
  195. now_time = int(time.time())
  196. uid_serial = UIDCompanySerialModel(uid_id=uid.id, company_serial_id=company_serial.id,
  197. add_time=now_time, update_time=now_time)
  198. uid_serial.save()
  199. company_serial.status = 2
  200. company_serial.save()
  201. res = {
  202. 'uid': CommonService.encode_data(uid.uid),
  203. 'mac': CommonService.encode_data(uid.mac),
  204. 'extra': uid.uid_extra
  205. }
  206. return response.json(0, res)
  207. else:
  208. return response.json(375)
  209. return response.json(5)
  210. else:
  211. uid_qs = UIDCompanySerialModel.objects.filter(company_serial_id=company_serial.id)
  212. if uid_qs.exists():
  213. uid = uid_qs.values('uid__uid', 'uid__mac', 'uid__uid_extra')[0]
  214. res = {
  215. 'uid': CommonService.encode_data(uid['uid__uid']),
  216. 'mac': CommonService.encode_data(uid['uid__mac']),
  217. 'extra': uid['uid__uid_extra']
  218. }
  219. return response.json(0, res)
  220. else:
  221. return response.json(173)
  222. except Exception as e:
  223. # print('--------------------------error 5000')
  224. # print(repr(e))
  225. if savePoint:
  226. transaction.rollback(savePoint)
  227. djangoLogger = logging.getLogger('django')
  228. djangoLogger.exception(repr(e))
  229. return response.json(176, str(e))
  230. except Exception as e:
  231. # print('--------------------------error 5001')
  232. # print(repr(e))
  233. djangoLogger = logging.getLogger('django')
  234. djangoLogger.exception(repr(e))
  235. return response.json(176, str(e))
  236. else:
  237. return response.json(444)
  238. def do_get_uid(self, request_dict, response):
  239. serial_number = request_dict.get('serial_number', None)
  240. token = request_dict.get('token', None)
  241. time_stamp = request_dict.get('time_stamp', None)
  242. if token and time_stamp and serial_number and len(serial_number) == 9:
  243. token = int(CommonService.decode_data(token))
  244. time_stamp = int(time_stamp)
  245. now_time = int(time.time())
  246. distance = now_time - time_stamp
  247. if token != time_stamp or distance > 300 or distance < 0:
  248. return response.json(404)
  249. mark = serial_number[6:9]
  250. serial = serial_number[0:6]
  251. uid_company_serial_qs = UIDCompanySerialModel.objects.filter(company_serial__company__mark=mark, company_serial__serial_number__serial_number=serial)
  252. if uid_company_serial_qs.exists():
  253. uid = uid_company_serial_qs.values('uid__uid', 'uid__mac', 'uid__uid_extra')[0]
  254. res = {
  255. 'uid': CommonService.encode_data(uid['uid__uid']),
  256. 'mac': CommonService.encode_data(uid['uid__mac']),
  257. 'extra': uid['uid__uid_extra']
  258. }
  259. return response.json(0, res)
  260. else:
  261. return response.json(173)
  262. else:
  263. return response.json(444)
  264. def do_detach_uid(self, userID, request_dict, response):
  265. uid = request_dict.get('uid', None)
  266. if uid:
  267. uid = CommonService.decode_data(uid)
  268. uid_serial_qs = UIDCompanySerialModel.objects.filter(uid__uid=uid)
  269. if uid_serial_qs.exists():
  270. uid_serial = uid_serial_qs[0]
  271. company_serial_qs = CompanySerialModel.objects.filter(id=uid_serial.company_serial.id)
  272. if company_serial_qs.exists():
  273. company_serial = company_serial_qs[0]
  274. company_serial.status = 1
  275. company_serial.save()
  276. uid_qs = UIDModel.objects.filter(uid=uid)
  277. if uid_qs.exists():
  278. uid = uid_qs[0]
  279. uid.status = 0
  280. uid.save()
  281. uid_serial.delete()
  282. return response.json(0)
  283. else:
  284. return response.json(173)
  285. else:
  286. return response.json(444)
  287. def do_update(self, userID, request_dict, response):
  288. perm = ModelService.check_perm_uid_manage(userID, 0)
  289. if not perm:
  290. return response.json(309)
  291. id = request_dict.get('id', None)
  292. status = request_dict.get('status', None)
  293. if id and status:
  294. serial_number_qs = SerialNumberModel.objects.filter(id=id)
  295. if serial_number_qs.exists():
  296. serial_number_qs.update(**{'status': status})
  297. return response.json(0)
  298. else:
  299. return response.json(173)
  300. else:
  301. return response.json(444)